Design Decisions Yet to be Applied
Here is a list of the decisions on database design which have been done recently, but usually not fully applied on the db schema currently for backward-compatibility reasons.
- 18/06/20 - Mathias, Damien.
groups_attempts.nbSubmissionsAttempts
should be renamed to something likenbSubmissionsBeforeCompletion
and only updated while the task is not validated. - 20/05/19 - Michel, Damien, Dmitry. Every submission has an attempt. If
items.bHasAttempts
is false, there can be only one attempt. As a consequence, many columns are not deprecated inusers_items
as they would be duplicated ingroups_attempts
. See this page - 22/05/19 - Michel, Damien, Dmitry. Clean format of token messages. See token page for more info.
- 05/19 - Michel, Damien, Dmitry.
sState
/sAnswer
of bothusers_items
andusers_answers
are currently updated at the same time (duplicated) on purpose during the transition to a better system. See this page for more details. - 14/08/19 - Michel, Damien about additional time:
- On 08/2019, extra time given to a user or group for a contest is managed in the db either through
users_items
orgroups_attemps
(not used actually). Storing it inusers_items
, keyed byuser_id,item_id
is not suitable from team participation, storing it ingroups_attempts
, keyed bygroup_id, item_id, attempt_id
, make it attempt-specific (so can be resetted), while, in practice, in a contest, the time does not have to be resetted for each attempt (case of Alkindi contest). This extra time should then be stored in a table keyed bygroup_id, item_id
. This is the casegroups_items
table, the same used for permission. - One extra benefit of that is not to apply extra time on end-users, but also on groups, allowing the give 2min extra to the whole group, 10min to a groups with disabilities, and 5min to a specific user which has a technical problem, causing him to get possibly 17min extra.
- The actual additional time is computed as the sum of all the additional time his group and all its ancestors got on the contest item.
- For the transition, all past additional times can be dropped.
- For the services to change additional time, we give to the frontend the computed additional time and the additional to the group, and let it return the new value for the group. It might be interesting to prevent parallel modification by sending the expected value so that the backend may fail if it does not match.
- On 08/2019, extra time given to a user or group for a contest is managed in the db either through
- Discussion on 6/09/2019 - Mathias, Damien
- Replacing the current way the contest qualification work (currently: for teams, requiring to have a given number of users in a group; for users, requiring gray access on the contest itself and so an addition to a parent chapter to give access to this contest at a specific time; when ok, give a new partial permission which will be removed at the end of the contest):
- New attribute in
groups_items
:bGrayedAccessDate
allowing to give explicitely gray access (currently it is only obtained from propagation). It does not propagate through the item hierarchy (as it is now). - New attributes in
groups_items
:canEnterFrom
andcanEnterUntil
, defining a time slot during which you can join (typically through the “start contest” button) theitems.idAccessGroup
, which is a group with partial access on the item. - For teams, the condition “having a given number of members in a group” is transformed to “having all grey access to the contesnt and having a given number of members with enter-access”
- New attribute in
- Replacing the current way to end a contest (currently: check at each access if the time is not over for the user and remove him the access if no)
- Every group membership (
groups_groups
) gets a expiration time. This expiratin time is used in the abovementioneditems.idAccessGroup
so that the user/team access expires once his time is over.
- Every group membership (
- Replace unlockItem by “joinGroup”: solving an item can make the user join a group which has access (instead of creating partial access)
- Replacing the current way the contest qualification work (currently: for teams, requiring to have a given number of users in a group; for users, requiring gray access on the contest itself and so an addition to a parent chapter to give access to this contest at a specific time; when ok, give a new partial permission which will be removed at the end of the contest):
- 16/09/2019 - Mathias & Damien
- The combination of
items_items.bAlwaysVisible
anditems_items.bAccessRestricted
can represents 4 states while actually they are used to represent 3 possible ways of propagating partial access from an item to its child. We will merge these attribute to oneitems_items.partial_propagation
(name to be defined) allowing 3 values:no
,as partial
,as grey
(to be defined).
- The combination of
- 18/09/2019 - Mathias & Damien
- Many
items.*
anditems_strings.*
(description in particular) attributes should actually be visible to “grayed” access. Nothing related to the task itself should be written in it anyway (typically “tasks” does not have any description), and it would allow to have the contest description available to all with grayed access. - It should be possible to give “grayed” access explicitely givable to a group (not only through partial access). It allows to let people see the contest before entering (entering in it would give access to a group with has partial access).
- Many