- Created by Myrle Krantz, last modified by Graham on Mar 24, 2018
You are viewing an old version of this page. View the current version.
Compare with Current View Page History
« Previous Version 2 Next »
Draft: GSoC 2018 Proposal
Project: Fineract SMS/Email Notification Microservice.
Applicant: Ebenezer Kwesi Akyen Graham
Project Problem:
This project is a new feature request in the Apache and Mifos Initiative idea list for the Apache Fineract CN. The SMS/Email Notifications service would be a microservice developed on Apache Fineract CN to enable MFI members to get notified on events occurring on their accounts. This will impact the KYC of the organisation
Proposed Solution
My proposed solution is that notification topics are defined and potential recipients ( MFI members (Staff or Customers) ) are subscribed to the topic when their account is created. Hence, in the occurrence of an event which matches the topic, a topic mapper will provide all staff members who need to be notified of the event. NB: Topic definition and topic mappings are persisted into the database.
So, when an actual event occurs, the system knows the subscribers to notify and now the notification has to be generated. An event listener will listen for Spring Event Emitters generated. Then the notification service will start by creating a notification object for the event, the notification then converted into an Email or SMS. To personalise the message, a subscriber prefines their language and communication preference during account creation. This is used to localize and separate notifications into SMS and Emails.
The localised messages are now formatted using a template associated to a topic.
The prepared messages will be passed to the Email services such as google’s SMTP server or Twilio SMS to be transmitted. I propose that the system allows multiple configurations to accommodate cases where the application supports multiple organisations who use different services.
Data (Notification, Notification mapping, Templates, Topics, Topics mappings, Subscribers) generated will be persisted into the Microservice’s database.
Subsystems Breakdown
EventListener
An event listener will listen for Spring EventEmitters generated. For instance for a new client creation the NotificationEventListener will capture the event emittered and generate the notification content
NotificationEventListener
Has a JmsListener to listen to emitted event
Initiates the NotificationEventService
NotificationService
Has an SMSService Object
Has an EmailService Object
Creates a NotificationMapper
Creates a recipient and their notification
Gets recipients details
Localize the message using subscriber preference
Sends the email or SMS
Domain
This package will define the class for the entities in the problem domain.
Notification
States the Recipient
states the action
states the content
NotificationMapper
Takes topic mapping and map notifications to subscribers
NotificationMapperRepository
Accumulate NotificationMappings
Configuration
This will be used to configure the behaviour of the system.
NotificationConfiguration
Has SMSConfiguration
Has EmailConfiguration
SMSConfiguration
Define sender’s Number
Defines and sets sms service authentication credentials
EmailConfiguration
Defines and sets mail service host
Defines and sets mail service ports
Defines and sets authentication credentials
SMSService
Use the Twilio SMS service and google SMTP Server
SMSDomainService
AuthenticateClient
AuthenticationClientRecordsRepository
EmailService
EmailDomainService
AuthenticateClient
AuthenticationClientRecordsRepository
This component will use the template component to form the message format. The template will abstract the various message formats. I believe using Apache Velocity to prepare default themes and allow the user to generate custom templates woube be a good consideration. Also, given that Fineract CN and Velocity [ http://velocity.apache.org/ ] share the same license it will be easier to use them
Template
SMS templates
Email Templates
API & DAO
The DAO will be used to access resources in the Database and also persist data from the notification Microservice into its down database
TopicDAO
Get and set predefined topics
SubscriberDAO
Get and persist subscriber communication preference
Get and persist language preference
NotificationDAO
Get and persist content
Get and persist notification id
Get and persist action
Get and persist action ID
Get and persist office id
Get and persist topic mappings
TopicMapperDAO
Get and persist topic id
Get and persist topic mappings
Testing Fineract CN:
I am setting up a personal VM on Google Cloud to host Fineract CN for testing purposes and understanding the system.
This VM will be using during the program until the Official Apache VM is fully functional.
Project idea:
Response: Fineract CN SMS & Email Notifications
Briefly cover what you expect to complete in this project and when including a detailed description of the project and a project plan.
Response:
Time | Deliverables |
Pre GSoC | Complete setting up VM on Google Cloud to test Fineract CN |
Week 1 | Discuss with Mentor to Finalize the Proposed Solution Design system and prepare essential UML diagrams |
Week 2 | Research and begin implementation Implement Event Listeners Implement Email and SMS service Service Constants Begin system Documentations |
Week 3 - 4 | Official Check in with Mentor Implement Configurations Document this weeks implementations |
Week 5 - 6 | Official Check in with Mentor Implement Domain Classes Document this weeks implementations |
Week 7 - 8 | Official Check in with Mentor Implement APIs Document this weeks implementations |
Week 9 - 12 | Official Check in with Mentor Implement SMS and Email services Implement Web interface for configuration Document this weeks implementations Finalize Documentation and development |
Post GSoC | Iterate over previous implementations Implement localization and templating |
Why are you the right person for this project?
The mission
I am an African enthusiast and the mission of the initiative resonates deeply with me. To give context. I want to help end poverty too and Africa has one of the highest poverty index ever recorded. I am passionate about tech solutions hence I am highly motivated to contribute given that the projects make a high impact on the society through Fintech.
Desire to Contribute
I have been following the Fineract project (Mifos Initiative) for almost a year now and I have always desired to contribute. I believe that participating in GSoC is a step towards becoming a lifelong contributor and a committer.
I am a FOSS enthusiast and this is my way of joining the FOSS community
Technical Skills
Working on this project presents a great opportunity for me to gain real-world experience, which has always been my desire. I equally take internships every year season to learn new skills and impact the society.
I java studied Java, MySQL and JavaScript for almost 2 year and I have about 8 months of technical experience
If in college, current area of study:
Response: BSc (Hons) Computing
Contact information and preferred method of contact (email, Gitter ID, Skype id, telephone number, time zone);
Email: ebenezergraham69@gmail.com
Gitter ID: @ebenezergraham
Skype id: ebenezer.graham
Timezone: +4:00 (GMT)
Career goals
Response: Systems Analyst and a Programmer
Please share any links to source code you have written or websites you have built.
http://ebenezergraham.bitballoon.com/
If you have visited our IRC channel, what nickname did you use?
Response:
mifos-developer@lists.sourceforge.net
Gitter (OpenMF, community-app, Fineract-CN-mobile, DataImportTool)
Have you contributed to other open source projects? If so, which?
Response: Gitschool
Have you any previous experience with AngularJS/Java/Spring/Hibernate/MySQL/Android?
Response: Java and MySQL
What other commitments do you have this summer? (working on this project is a full-time job and must be your primary commitment!)
Response: 20 hours per week to study and take online course
Have you deployed and run the Apache Fineract platform (https://github.com/apache/fineract) and the reference user interface (https://github.com/openMF/community-app)?
Response: Yes I have studied the codebase but haven’t deployed Fineract CN
Have you submitted any patches or source code to Mifos X yet? Please provides links to the commit in GitHub or the JIRA ticket (students looking to be seriously considered should make at least one submission)
Response: Yes
What motivates you the most about working with the Mifos Initiative for Google Summer of Code?
Response: I want to learn new techniques, learn how to engage with an opensource community and I believe GSoC will allow me to learn it in the best possible way.
Have you previously participated in the Google Summer of Code?
Response: No
Are you applying to multiple organizations this year?
Response: No
- No labels