Skip to content

Latest commit

 

History

History
145 lines (128 loc) · 5.18 KB

README.md

File metadata and controls

145 lines (128 loc) · 5.18 KB

TODO

  • Ajouter le champ gender pour Profile Model
  • Adapter le template à angular.
  • Implementer l'envoi de notification par email (gmail)
  • Implementer l'envoi de notification par SMS
  • Implementer verification e-mail lors de l'enregistrement.
  • Implementer password reset.
  • Implementer verification numéro téléphone lors de l'enregistrement.
  • Utiliser postgressql
  • Utiliser Django Internationalization i18n (ou utiliser des codes dans les envois de messages d'erreurs du serveur)
  • Implementer suppression periodique des comptes non actives ?
  • Integer Task Queue (Celery) and Message Broker (Redis or RabbitMQ) to do tasks asynchronously (send mails, notifications ...)
  • To Fix (bug) : in list donations or list blood centers, when going to page 2 and press previous button of the browser, the url changes but the list is not updated. It is because there is no subscription to the url changes.

blood-donation-platform

Profile data model (Profile)

Address model

+======================+
|   Address (model)    |
+======================+
| street (CharField)   |
+----------------------+
| city (CharField)     |
+----------------------+
| country (CharField)  |
+----------------------+
| zip_code (CharField) |
+----------------------+

Profile model

Profile model extends Django AbstractUser model. For more information see : https://docs.djangoproject.com/fr/1.11/topics/auth/customizing/#auth-custom-user

+====================================+
|          Profile (model)           |
+====================================+
| username (CharField)               |
+------------------------------------+
| email (emailField)                 |
+------------------------------------+
| password (CharField)               |
+------------------------------------+
| first_name (CharField)             |
+------------------------------------+
| last_name (CharField)              |
+------------------------------------+
| phone_number (CharField)           |
+------------------------------------+
| address (Address model)            |
+------------------------------------+
| birth_date (DateField)             |
+------------------------------------+
| blood_type  (CharField, choices)   |
+------------------------------------+
| email_notification  (BooleanField) |
+------------------------------------+
| sms_notification  (BooleanField)   |
+------------------------------------+

Here is ana example of Profile model in JSON format (after rendering) :

{
    "username": "alain",
    "email": "[email protected]",
    "firstName": "Alain",
    "lastName": "Alo",
    "phoneNumber": "0626382125",
    "address": {
        "street": "10 rue de lune",
        "city": "Rennes",
        "country": "France",
        "zipCode": "40000"
    },
    "birthDate": "1994-02-12",
    "bloodType": "AB+",
    "emailNotification": true,
    "smsNotification": true
}

Donation data model (Donation)

+==============================+
|       Donation (model)       |
+==============================+
| created_on (DateTimeField)   |
+------------------------------+
| applicant (Profile model)    |
+------------------------------+
| deadline (DateTimeField)     |
+------------------------------+
| description (TextField)      |
+------------------------------+
| city  (CharField)            |
+------------------------------+
| phone_number  (CharField)    |
+------------------------------+
| status  (CharField, choices) |
+------------------------------+

Here is an example of Donation model in JSON format (after rendering) :

{
    "id": 1,
    "url": "http://127.0.0.1:8000/api/donations/1/",
    "createdOn": "2017-08-27T14:43:20.747354Z",
    "applicant": {
        "username": "user1",
        "email": "[email protected]",
        "firstName": "user1",
        "lastName": "user1",
        "phoneNumber": "0626782685",
        "address": {
            "street": "derb 2",
            "city": "Marrakech",
            "country": "Maroc",
            "zipCode": "45000"
        },
        "birthDate": "2017-08-01",
        "bloodType": "O-",
        "emailNotification": true,
        "smsNotification": false
    },
    "bloodType": "O-",
    "deadline": "2017-08-31T12:02:00Z",
    "description": "description here",
    "city": "Marrakech",
    "phoneNumber": "0626682675",
    "status": "URG"
}

Notes

The Django backend is using Python PEP 8 code style, hence it is using under_score_case naming convention. We have implemented a Parser and a Renderer to do the conversion from under_score_case to camelCase and vice versa when sending or receiving JSON data to convert JSON data keys naming convention. This is working only for JSON data.

So it is mandatory to use "Content-Type : application/json" in the http header so as the backend uses JSON Renderer and Parser we have implemented