We are running the web application which stores and exposes Patients and their Payments. The application must stay in sync with external users's system data and provide some additional analytics on top of the data.
As a sample, basic SQLAlchemy models are provided in models.py file. Feel free to extend and modify them, but do not delete existing fields.
external_id field must contain id of an object in external system, and is
unique in the external source. It is the only field guaranteed not to change.
All other fields in external source can change, including payment amount!
You can use flask/django or other framework of choice, just convert the models by yourself. You can modify the project structure as you like, the boilerplate code is provided only as an example.
-
Implement web service which exposes methods
-
GET /patients?payment_min=10&payments_max=20
- Returns list of patients with total amount of payments in supplied range (in this example between $10 and $20)
- filters are optional
-
GET /payments?external_id=
- Returns the list of payments, probably filtered by patient's external_id
- filters are optional
-
-
Implement data sync Just for the sake of simplicity we assume all the data comes in one piece, which should be replicated in the database. If something is missing in the upload, it means object has been deleted in external system.
- Option 1. POST /patients and POST /payments methods
- Option 2. Import json files from the command line
-
created
andupdated
model fields should be set appropriately to their names: when the object was created and when it was updated last time.
Sample data is provided in patients.json and payments.json files.
- Code as you will code for a production use. You can omit some of the boring stuff if you leave the comment that it should be there. Make performance/reliability decisions as for production with 1000x more data/load.
- Challenge completion time is important, build the working version as fast as you can
- To sum up 2 previous points: do not waste time on what is NOT in the task requirements, e.g. devops.
- Clone the repo or start a new one. Do not fork it!
- Upload in public or private repository on github. In case of private, please share the access.
- Keep your commit history.