This event platform is build using Symfony with Symfony Messenger with RabbitMQ and API platform with ElasticSearch.
This project tries to separate the write model from the read model for better performance and since the data in is from different vendors that can be round independently of the user faced API. The architecture is based on CQRS with segregation between writing data and reading data.
The idea is that instances (docker containers) can be started for each vendor importing events by sending messages into the message queue and workers processing the data (e.g. in other containers) and when data have been normalized it is stored and index into ElasticSearch for fast data fetching (also enabling geospatial searching). This will also allow the development of data importers in new vendors (e.g. fetching data from APIs) without any downtime for the frontend.
All data on this platform is soft deleted as base rule, we may make commands to purge data older than a relative given date and thereby make hard deletions as deferred manual action.
This diagram tries to visualize the data flow for data in the system. This could be dived into the following containers in a production setup.
- Vendors (feed readers/API consumers)
- Workers (handling import related messages)
- API
- UI (administrative and manual event creation)
In the administrative user interface the following should be possible:
- Create new events.
- Clone events (edit and save as new event).
- Only edit events created by current users organisations.
- All vendor imported events are not editable in the UI.
The API output should make it possible to:
- Geo encoding filter
- Postel code filter (or filter)
Things that requires more ivestigated:
- Tags (controlled and free (ukendt))
- Vendor ranking
- Duplicated content detection and handling (event hash, score)
The user model as two types of users. Symfony created user (super admin, which should only be one or two off) and MitID verified users. The idea is that each organization/institution have an appointed admin that is allowed to send user invitation out for his/her organization. Each user can be part of more than on organization it just requires that they get an invitation and thereby get there account linked to a given organization.
When users are returned from the user verification process the uuid from MitID is stored on the user account and MitID is then used to log in users. Also, users that have not been logged ind for at given timeframe (e.g. 3 months) should be disabled automatically. The organization admin can also enable/disabled access for a given user and if a user is not member of any organization should automatically be disabled.
- Which roles should exist in the system. Should editors be limited to some actions (feeds only editor, only view etc.).
- Is the users only municipality base (context handler) or should MitID be implemented using nemLogin.
To use the public API, sites have to registry with a username and e-mail-address to get an API-key. The reason for this is that it is the only way that the system admin can see where request are coming from in the case of mis-usage and have contact information to communicate with the mis-user.
This will also prevent must automatic mis-usage from the internet of the service that just probing the system or trying to automatically hack it.
The database entity model.