Requirements to develop.
Do not change the order or insert new reqs in the middle of the list.
-
set up the email sending module. -
save every field as a string, and save (inside the channel class) the `encoding' to use to recover the value from that string. -
let the user define different triggering actions for each channel
have to finish writing some tests -
redefine the Record.save() method, by placing the actions to be triggered there -
set up a cron job that every X (5 mins? 10?) sends a request on a special View that scans the whole DB of Channels, and compares the last_update field with the update_interval (it still has to be created) and trigger a special trigger action the user chose for that channel to signal inactivity --> to be done with the Periodic Tasks from celery.
-
[WEB] make the user choose which kind of field encoding to use from a defined list for each field of the channel.
-
check whether the values are of the correct type at the saving time. -
check (with a test) that requests with wrong field names (instead of field1, .., field43) are not accepted by the upload view. -
check (with a test) that fields (keys) without values (field1=& ...) are not accepted by the upload view. -
At the saving time, check that the values are consistent with their field encoding. -
add an (optional) name to each field (could be placed inside the FieldEncoding, since it has to be unique for every field.. maybe the name can be changed from FieldEncoding to something more generic)done, and changed FieldEncoding to FieldMetadata -
create tests for the ConditionAndReaction class -
[WEB/secondary req.] validate the email the user inserts, by making sure that he really owns that address. Cornercase: if the user already certified their registration email, there's no need to ask to certificate it again.
-
[WEB] translations.
-
Make sure that there are no more than one FieldMetadata object for each field_no (there should be something like a composite pk on the channel and the field_no). -
update the secret_settings_example.py file
(and rename them secret_settings{,_example}.py) -
check and test what happens when many 'fieldX' with the same name (and diff values?) are passed to the upload view to be saved. --> this shouldn't happen, since the field should overwrite each other when are read by django.
-
check what happens when an empty value is passed with a field.
-
Add to the doc the following requirements to install the project on an unmanaged server (maybe isn't a complete list):
- git (to clone the repo)
- python3 and python3-virtualenv
- gcc (to compile uwsgi when installed with pip)
- nginx
Installable via pip [pip install]:
- django
- uwsgi
- postmarker (for the email sending)
- Write down the steps needed to set up the web-part of the project on a shared hosting.