This page is designed to give a broad overview of the currently done, work in progress and planned microservices. When considering (starting) working on one of these microservices, use the discussion link provided to get more information about a microservice and voice your opinion.
Microservices
Color code: | Suggested | Accepted | In Progress | Done | Rejected | Outdated |
---|
Microservice name | Code | Responsible | Discuss | API | Description | ||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Core backend | (OMS)CORE | Flaviu | Confluence | Responsible for oAuth login with AP, user management etc Should also be able to enable / disable other modules | |||||||||||
Core frontend | (OMS)CORE | Flaviu | Confluence | Responsible for ALL frontend related stuff (should be tied with CB aka should be rendered by CB for security purposes and easier management). Other modules' frontend will be rendered by this one using templates and cross site requests | |||||||||||
Micro service example (and node version) | EXAMPLE | Confluence - Development | An example module. Responsibilities and functionalities:
| ||||||||||||
Core | CORE | Derk, Nico | Confluence | API | The core module providing the very basics required for all other modules. Responsibilities and functionalities:
| ||||||||||
Core-Elixir | CORE | Nico | API | A rewrite of the php core in elixir by Nico. Designed as a drop-in replacement for the core because core-development was stalled a bit due to personal reasons. Responsibilities and functionalities
| |||||||||||
Loginservice | Nico | API | Login and signup-functionality, separated from the core because Nico used it for another project. Responsibilities and functionalities:
| ||||||||||||
Events (and frontend) | EVENTS | Nico, Sergey | Confluence | API | All event-related stuff. Creating, modifying, displaying and deleting events, approving events, managing events' organizers Responsibilities and functionalities:
| ||||||||||
Applications (and frontend) | Nico | JIRA - Issue | Everything related to the events' applications | , applicants acceptance, waiting lists, participants selection, etc.Applications | Acts like a sub-service for events.for the generic events (not statutory and not SU). Applying for the events, managing applications, approving participants. Responsibilities and functionalities:
| ||||||||||
Service registry | REGISTRY | Nico | JIRA | API | Helps with service discovery based on categories or servicenames and provides an access token registry. Responsibilities and functionalities:
| ||||||||||
Traefik | TRAEFIK | Nico | Confluence | Open-source reverse proxy for load balancing and health checking
| |||||||||||
Logging | LOG | Logging microservice for the entire system | |||||||||||||
Alastair | FOOD | Nico | Confluence | Food planning module | : - A | cooking app, my private project | - you don't need to worry about itTunnel | TUNNEL | Nico | JIRAfrom Nico | |||||
The Central Frontend | Nico | Confluence | Joining the frontend pages of all services into one and serving it | ||||||||||||
LDAP support | JIRA - Issue | ||||||||||||||
Notifications | JIRA - Issue | Would allow observers to register and push and receive notifications. | Notifications | Emailer: Most likely will not write something ourselves, should use something existing. Flaviu mainly used sendgrid- cast | NOTIFY | Nico | Confluence | API | Receives notification requests from services and casts them to notification providers | ||||||
Notifications - onscreen | NOTIFY | Nico | API | Stores onscreen notifications which the user can fetch with a simple api call whenever he wants, no push feature | |||||||||||
Notifications - email | NOTIFY | Probably just a wrapper around an existing service like sendgrid | |||||||||||||
Notifications - push | NOTIFY | Push Notifications | |||||||||||||
Cron Module | JIRA - issue | Regularily reoccuring tasks | |||||||||||||
Statutory microservice | Stuff that happens during statutory events (agorae, epms): Agenda, Proposals and voting on proposals, members, etc. - Not parts of events moduleSTATUTORY | Sergey | not there yet |
| |||||||||||
Voting | Candidatures, Evaluation (like impact measurement for events), also Recursion (-; | Antenna Microservice | Local management tools for antennae like members-list, working groups, local comitees, etc. Might just be another frontend to the core, low priority|||||||||||||
Reporting | Generate anonymous reports with user and member statistics. | ||||||||||||||
Survey | Requirements | Add survey/questionnaire support, integrating it within OMS | |||||||||||||
Finance | Fee management. Event budgeting. Parts of this are inside the core module at the moment, will be moved out of oms-core for this. | ||||||||||||||
Storage | A possibility to backup data to external systems easily. | ||||||||||||||
Travel | for example: AEGEE-couchsurfing | ||||||||||||||
Gamification | E.g. create badges like "Visited 5 events" or "Attended 3 Agorae in a row" | ||||||||||||||
Comments | Make commenting everything possible. Reuse of disqus might be the way to do it. | ||||||||||||||
SU Webfrontend | Summer University Website: Will be a little different from the usual events frontend, maintained and developed by SUCT. | SU Mobile App* | Same as SU-Webfrontend. | Events Mobile App* | Derivative from SU app (or the other way around?)