mirror of
https://codeberg.org/timelimit/timelimit-server.git
synced 2025-10-03 09:49:32 +02:00
Add support for rules per day
This commit is contained in:
parent
2a8250c9f7
commit
259c4d94a9
19 changed files with 256 additions and 12 deletions
|
@ -371,6 +371,9 @@
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
@ -1380,6 +1383,9 @@
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
|
|
@ -595,6 +595,9 @@
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
@ -605,6 +608,7 @@
|
||||||
"id",
|
"id",
|
||||||
"maxTime",
|
"maxTime",
|
||||||
"pause",
|
"pause",
|
||||||
|
"perDay",
|
||||||
"session",
|
"session",
|
||||||
"start"
|
"start"
|
||||||
],
|
],
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
# Untitled boolean in SerializedParentAction Schema
|
||||||
|
|
||||||
|
```txt
|
||||||
|
https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/perDay
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Abstract | Extensible | Status | Identifiable | Custom Properties | Additional Properties | Access Restrictions | Defined In |
|
||||||
|
| :------------------ | ---------- | -------------- | ----------------------- | :---------------- | --------------------- | ------------------- | ------------------------------------------------------------------------------------------------- |
|
||||||
|
| Can be instantiated | No | Unknown status | Unknown identifiability | Forbidden | Allowed | none | [SerializedParentAction.schema.json\*](SerializedParentAction.schema.json "open original schema") |
|
||||||
|
|
||||||
|
## perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
|
@ -28,6 +28,7 @@ https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule
|
||||||
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/end") |
|
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/end") |
|
||||||
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/dur") |
|
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/dur") |
|
||||||
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/pause") |
|
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/perDay") |
|
||||||
|
|
||||||
## ruleId
|
## ruleId
|
||||||
|
|
||||||
|
@ -172,3 +173,19 @@ https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule
|
||||||
### pause Type
|
### pause Type
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
## perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is optional
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/perDay")
|
||||||
|
|
||||||
|
### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
# Untitled boolean in SerializedParentAction Schema
|
||||||
|
|
||||||
|
```txt
|
||||||
|
https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/perDay
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Abstract | Extensible | Status | Identifiable | Custom Properties | Additional Properties | Access Restrictions | Defined In |
|
||||||
|
| :------------------ | ---------- | -------------- | ----------------------- | :---------------- | --------------------- | ------------------- | ------------------------------------------------------------------------------------------------- |
|
||||||
|
| Can be instantiated | No | Unknown status | Unknown identifiability | Forbidden | Allowed | none | [SerializedParentAction.schema.json\*](SerializedParentAction.schema.json "open original schema") |
|
||||||
|
|
||||||
|
## perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
|
@ -28,6 +28,7 @@ https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelim
|
||||||
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/end") |
|
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/end") |
|
||||||
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/dur") |
|
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/dur") |
|
||||||
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/pause") |
|
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/perDay") |
|
||||||
|
|
||||||
## type
|
## type
|
||||||
|
|
||||||
|
@ -180,3 +181,19 @@ https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelim
|
||||||
### pause Type
|
### pause Type
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
## perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is optional
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/perDay")
|
||||||
|
|
||||||
|
### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
|
@ -696,6 +696,7 @@ Reference this group by using
|
||||||
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/end") |
|
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/end") |
|
||||||
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/dur") |
|
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/dur") |
|
||||||
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/pause") |
|
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/perDay") |
|
||||||
|
|
||||||
### ruleId
|
### ruleId
|
||||||
|
|
||||||
|
@ -841,6 +842,22 @@ Reference this group by using
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
### perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is optional
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [SerializedParentAction](serializedparentaction-definitions-serializedtimelimitrule-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedTimeLimitRule/properties/perDay")
|
||||||
|
|
||||||
|
#### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
||||||
## Definitions group SerializedDeleteCategoryAction
|
## Definitions group SerializedDeleteCategoryAction
|
||||||
|
|
||||||
Reference this group by using
|
Reference this group by using
|
||||||
|
@ -3751,6 +3768,7 @@ Reference this group by using
|
||||||
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/end") |
|
| [end](#end) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-end.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/end") |
|
||||||
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/dur") |
|
| [dur](#dur) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-dur.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/dur") |
|
||||||
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/pause") |
|
| [pause](#pause) | `number` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-pause.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Optional | cannot be null | [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/perDay") |
|
||||||
|
|
||||||
### type
|
### type
|
||||||
|
|
||||||
|
@ -3904,6 +3922,22 @@ Reference this group by using
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
### perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is optional
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [SerializedParentAction](serializedparentaction-definitions-serializedupdatetimelimitruleaction-properties-perday.md "https://timelimit.io/SerializedParentAction#/definitions/SerializedUpdateTimelimitRuleAction/properties/perDay")
|
||||||
|
|
||||||
|
#### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
||||||
## Definitions group SerializedUpdateUserFlagsAction
|
## Definitions group SerializedUpdateUserFlagsAction
|
||||||
|
|
||||||
Reference this group by using
|
Reference this group by using
|
||||||
|
|
|
@ -0,0 +1,16 @@
|
||||||
|
# Untitled boolean in ServerDataStatus Schema
|
||||||
|
|
||||||
|
```txt
|
||||||
|
https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/perDay
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
| Abstract | Extensible | Status | Identifiable | Custom Properties | Additional Properties | Access Restrictions | Defined In |
|
||||||
|
| :------------------ | ---------- | -------------- | ----------------------- | :---------------- | --------------------- | ------------------- | ------------------------------------------------------------------------------------- |
|
||||||
|
| Can be instantiated | No | Unknown status | Unknown identifiability | Forbidden | Allowed | none | [ServerDataStatus.schema.json\*](ServerDataStatus.schema.json "open original schema") |
|
||||||
|
|
||||||
|
## perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
|
@ -27,6 +27,7 @@ https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule
|
||||||
| [end](#end) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-end.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/end") |
|
| [end](#end) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-end.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/end") |
|
||||||
| [session](#session) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-session.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/session") |
|
| [session](#session) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-session.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/session") |
|
||||||
| [pause](#pause) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-pause.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/pause") |
|
| [pause](#pause) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-pause.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-perday.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/perDay") |
|
||||||
|
|
||||||
## id
|
## id
|
||||||
|
|
||||||
|
@ -155,3 +156,19 @@ https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule
|
||||||
### pause Type
|
### pause Type
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
## perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is required
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-perday.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/perDay")
|
||||||
|
|
||||||
|
### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
|
@ -1709,6 +1709,7 @@ Reference this group by using
|
||||||
| [end](#end) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-end.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/end") |
|
| [end](#end) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-end.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/end") |
|
||||||
| [session](#session) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-session.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/session") |
|
| [session](#session) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-session.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/session") |
|
||||||
| [pause](#pause) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-pause.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/pause") |
|
| [pause](#pause) | `number` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-pause.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/pause") |
|
||||||
|
| [perDay](#perDay) | `boolean` | Required | cannot be null | [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-perday.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/perDay") |
|
||||||
|
|
||||||
### id
|
### id
|
||||||
|
|
||||||
|
@ -1838,6 +1839,22 @@ Reference this group by using
|
||||||
|
|
||||||
`number`
|
`number`
|
||||||
|
|
||||||
|
### perDay
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
`perDay`
|
||||||
|
|
||||||
|
- is required
|
||||||
|
- Type: `boolean`
|
||||||
|
- cannot be null
|
||||||
|
- defined in: [ServerDataStatus](serverdatastatus-definitions-servertimelimitrule-properties-perday.md "https://timelimit.io/ServerDataStatus#/definitions/ServerTimeLimitRule/properties/perDay")
|
||||||
|
|
||||||
|
#### perDay Type
|
||||||
|
|
||||||
|
`boolean`
|
||||||
|
|
||||||
## Definitions group ServerUpdatedCategoryTasks
|
## Definitions group ServerUpdatedCategoryTasks
|
||||||
|
|
||||||
Reference this group by using
|
Reference this group by using
|
||||||
|
|
|
@ -31,10 +31,12 @@ export class UpdateTimelimitRuleAction extends ParentAction {
|
||||||
readonly end: number
|
readonly end: number
|
||||||
readonly sessionDurationMilliseconds: number
|
readonly sessionDurationMilliseconds: number
|
||||||
readonly sessionPauseMilliseconds: number
|
readonly sessionPauseMilliseconds: number
|
||||||
|
readonly perDay: boolean
|
||||||
|
|
||||||
constructor ({
|
constructor ({
|
||||||
ruleId, maximumTimeInMillis, dayMask, applyToExtraTimeUsage,
|
ruleId, maximumTimeInMillis, dayMask, applyToExtraTimeUsage,
|
||||||
start, end, sessionDurationMilliseconds, sessionPauseMilliseconds
|
start, end, sessionDurationMilliseconds, sessionPauseMilliseconds,
|
||||||
|
perDay
|
||||||
}: {
|
}: {
|
||||||
ruleId: string
|
ruleId: string
|
||||||
maximumTimeInMillis: number
|
maximumTimeInMillis: number
|
||||||
|
@ -44,6 +46,7 @@ export class UpdateTimelimitRuleAction extends ParentAction {
|
||||||
end: number
|
end: number
|
||||||
sessionDurationMilliseconds: number
|
sessionDurationMilliseconds: number
|
||||||
sessionPauseMilliseconds: number
|
sessionPauseMilliseconds: number
|
||||||
|
perDay: boolean
|
||||||
}) {
|
}) {
|
||||||
super()
|
super()
|
||||||
|
|
||||||
|
@ -55,6 +58,7 @@ export class UpdateTimelimitRuleAction extends ParentAction {
|
||||||
this.end = end
|
this.end = end
|
||||||
this.sessionDurationMilliseconds = sessionDurationMilliseconds
|
this.sessionDurationMilliseconds = sessionDurationMilliseconds
|
||||||
this.sessionPauseMilliseconds = sessionPauseMilliseconds
|
this.sessionPauseMilliseconds = sessionPauseMilliseconds
|
||||||
|
this.perDay = perDay
|
||||||
|
|
||||||
assertIdWithinFamily({ actionType, field: 'ruleId', value: ruleId })
|
assertIdWithinFamily({ actionType, field: 'ruleId', value: ruleId })
|
||||||
|
|
||||||
|
@ -90,7 +94,7 @@ export class UpdateTimelimitRuleAction extends ParentAction {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static parse = ({ ruleId, time, days, extraTime, start, end, dur, pause }: SerializedUpdateTimelimitRuleAction) => (
|
static parse = ({ ruleId, time, days, extraTime, start, end, dur, pause, perDay }: SerializedUpdateTimelimitRuleAction) => (
|
||||||
new UpdateTimelimitRuleAction({
|
new UpdateTimelimitRuleAction({
|
||||||
ruleId,
|
ruleId,
|
||||||
maximumTimeInMillis: time,
|
maximumTimeInMillis: time,
|
||||||
|
@ -99,7 +103,8 @@ export class UpdateTimelimitRuleAction extends ParentAction {
|
||||||
start: start ?? MinuteOfDay.MIN,
|
start: start ?? MinuteOfDay.MIN,
|
||||||
end: end ?? MinuteOfDay.MAX,
|
end: end ?? MinuteOfDay.MAX,
|
||||||
sessionDurationMilliseconds: dur ?? 0,
|
sessionDurationMilliseconds: dur ?? 0,
|
||||||
sessionPauseMilliseconds: pause ?? 0
|
sessionPauseMilliseconds: pause ?? 0,
|
||||||
|
perDay: perDay ?? false
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -114,4 +119,5 @@ export interface SerializedUpdateTimelimitRuleAction {
|
||||||
end?: number
|
end?: number
|
||||||
dur?: number
|
dur?: number
|
||||||
pause?: number
|
pause?: number
|
||||||
|
perDay?: boolean
|
||||||
}
|
}
|
||||||
|
|
|
@ -330,6 +330,9 @@ const definitions = {
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
@ -1300,6 +1303,9 @@ const definitions = {
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
@ -2267,6 +2273,9 @@ const definitions = {
|
||||||
},
|
},
|
||||||
"pause": {
|
"pause": {
|
||||||
"type": "number"
|
"type": "number"
|
||||||
|
},
|
||||||
|
"perDay": {
|
||||||
|
"type": "boolean"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"additionalProperties": false,
|
"additionalProperties": false,
|
||||||
|
@ -2277,6 +2286,7 @@ const definitions = {
|
||||||
"id",
|
"id",
|
||||||
"maxTime",
|
"maxTime",
|
||||||
"pause",
|
"pause",
|
||||||
|
"perDay",
|
||||||
"session",
|
"session",
|
||||||
"start"
|
"start"
|
||||||
]
|
]
|
||||||
|
|
|
@ -0,0 +1,38 @@
|
||||||
|
/*
|
||||||
|
* server component for the TimeLimit App
|
||||||
|
* Copyright (C) 2019 - 2020 Jonas Lochmann
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, version 3 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import { QueryInterface, Sequelize, Transaction } from 'sequelize'
|
||||||
|
import { attributesVersion3 as ruleAttributes } from '../../timelimitrule'
|
||||||
|
|
||||||
|
export async function up (queryInterface: QueryInterface, sequelize: Sequelize) {
|
||||||
|
await sequelize.transaction({
|
||||||
|
type: Transaction.TYPES.EXCLUSIVE
|
||||||
|
}, async (transaction) => {
|
||||||
|
// timelimit rule table
|
||||||
|
await queryInterface.addColumn('TimelimitRules', 'perDay', {
|
||||||
|
...ruleAttributes.perDay
|
||||||
|
}, { transaction })
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function down (queryInterface: QueryInterface, sequelize: Sequelize) {
|
||||||
|
await sequelize.transaction({
|
||||||
|
type: Transaction.TYPES.EXCLUSIVE
|
||||||
|
}, async (transaction) => {
|
||||||
|
await queryInterface.removeColumn('TimelimitRules', 'perDay', { transaction })
|
||||||
|
})
|
||||||
|
}
|
|
@ -37,7 +37,12 @@ interface TimelimitRuleAttributesVersion2 {
|
||||||
sessionPauseMilliseconds: number
|
sessionPauseMilliseconds: number
|
||||||
}
|
}
|
||||||
|
|
||||||
type TimelimitRuleAttributes = TimelimitRuleAttributesVersion1 & TimelimitRuleAttributesVersion2
|
interface TimelimitRuleAttributesVersion3 {
|
||||||
|
perDay: number
|
||||||
|
}
|
||||||
|
|
||||||
|
type TimelimitRuleAttributes = TimelimitRuleAttributesVersion1 &
|
||||||
|
TimelimitRuleAttributesVersion2 & TimelimitRuleAttributesVersion3
|
||||||
|
|
||||||
export type TimelimitRuleModel = Sequelize.Model & TimelimitRuleAttributes
|
export type TimelimitRuleModel = Sequelize.Model & TimelimitRuleAttributes
|
||||||
export type TimelimitRuleModelStatic = typeof Sequelize.Model & {
|
export type TimelimitRuleModelStatic = typeof Sequelize.Model & {
|
||||||
|
@ -120,9 +125,22 @@ export const attributesVersion2: SequelizeAttributes<TimelimitRuleAttributesVers
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export const attributesVersion3: SequelizeAttributes<TimelimitRuleAttributesVersion3> = {
|
||||||
|
perDay: {
|
||||||
|
type: Sequelize.INTEGER,
|
||||||
|
validate: {
|
||||||
|
min: 0,
|
||||||
|
max: 1
|
||||||
|
},
|
||||||
|
allowNull: false,
|
||||||
|
defaultValue: 0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
export const attributes: SequelizeAttributes<TimelimitRuleAttributes> = {
|
export const attributes: SequelizeAttributes<TimelimitRuleAttributes> = {
|
||||||
...attributesVersion1,
|
...attributesVersion1,
|
||||||
...attributesVersion2
|
...attributesVersion2,
|
||||||
|
...attributesVersion3
|
||||||
}
|
}
|
||||||
|
|
||||||
export const createTimelimitRuleModel = (sequelize: Sequelize.Sequelize): TimelimitRuleModelStatic => sequelize.define('TimelimitRule', attributes) as TimelimitRuleModelStatic
|
export const createTimelimitRuleModel = (sequelize: Sequelize.Sequelize): TimelimitRuleModelStatic => sequelize.define('TimelimitRule', attributes) as TimelimitRuleModelStatic
|
||||||
|
|
|
@ -54,7 +54,8 @@ export async function dispatchCreateTimeLimitRule ({ action, cache, fromChildSel
|
||||||
startMinuteOfDay: action.rule.start,
|
startMinuteOfDay: action.rule.start,
|
||||||
endMinuteOfDay: action.rule.end,
|
endMinuteOfDay: action.rule.end,
|
||||||
sessionDurationMilliseconds: action.rule.sessionDurationMilliseconds,
|
sessionDurationMilliseconds: action.rule.sessionDurationMilliseconds,
|
||||||
sessionPauseMilliseconds: action.rule.sessionPauseMilliseconds
|
sessionPauseMilliseconds: action.rule.sessionPauseMilliseconds,
|
||||||
|
perDay: action.rule.perDay ? 1 : 0
|
||||||
}, { transaction: cache.transaction })
|
}, { transaction: cache.transaction })
|
||||||
|
|
||||||
cache.categoriesWithModifiedTimeLimitRules.add(action.rule.categoryId)
|
cache.categoriesWithModifiedTimeLimitRules.add(action.rule.categoryId)
|
||||||
|
|
|
@ -42,6 +42,7 @@ export async function dispatchUpdateTimelimitRule ({ action, cache }: {
|
||||||
ruleEntry.endMinuteOfDay = action.end
|
ruleEntry.endMinuteOfDay = action.end
|
||||||
ruleEntry.sessionDurationMilliseconds = action.sessionDurationMilliseconds
|
ruleEntry.sessionDurationMilliseconds = action.sessionDurationMilliseconds
|
||||||
ruleEntry.sessionPauseMilliseconds = action.sessionPauseMilliseconds
|
ruleEntry.sessionPauseMilliseconds = action.sessionPauseMilliseconds
|
||||||
|
ruleEntry.perDay = action.perDay ? 1 : 0
|
||||||
|
|
||||||
await ruleEntry.save({ transaction: cache.transaction })
|
await ruleEntry.save({ transaction: cache.transaction })
|
||||||
|
|
||||||
|
|
|
@ -44,7 +44,8 @@ export async function getRules ({ database, transaction, categoryIdsToSyncRules,
|
||||||
'startMinuteOfDay',
|
'startMinuteOfDay',
|
||||||
'endMinuteOfDay',
|
'endMinuteOfDay',
|
||||||
'sessionDurationMilliseconds',
|
'sessionDurationMilliseconds',
|
||||||
'sessionPauseMilliseconds'
|
'sessionPauseMilliseconds',
|
||||||
|
'perDay'
|
||||||
],
|
],
|
||||||
transaction
|
transaction
|
||||||
})).map((item) => ({
|
})).map((item) => ({
|
||||||
|
@ -56,7 +57,8 @@ export async function getRules ({ database, transaction, categoryIdsToSyncRules,
|
||||||
startMinuteOfDay: item.startMinuteOfDay,
|
startMinuteOfDay: item.startMinuteOfDay,
|
||||||
endMinuteOfDay: item.endMinuteOfDay,
|
endMinuteOfDay: item.endMinuteOfDay,
|
||||||
sessionDurationMilliseconds: item.sessionDurationMilliseconds,
|
sessionDurationMilliseconds: item.sessionDurationMilliseconds,
|
||||||
sessionPauseMilliseconds: item.sessionPauseMilliseconds
|
sessionPauseMilliseconds: item.sessionPauseMilliseconds,
|
||||||
|
perDay: item.perDay
|
||||||
}))
|
}))
|
||||||
|
|
||||||
const getCategoryRulesVersion = (categoryId: string) => (
|
const getCategoryRulesVersion = (categoryId: string) => (
|
||||||
|
@ -73,7 +75,8 @@ export async function getRules ({ database, transaction, categoryIdsToSyncRules,
|
||||||
start: item.startMinuteOfDay,
|
start: item.startMinuteOfDay,
|
||||||
end: item.endMinuteOfDay,
|
end: item.endMinuteOfDay,
|
||||||
session: item.sessionDurationMilliseconds,
|
session: item.sessionDurationMilliseconds,
|
||||||
pause: item.sessionPauseMilliseconds
|
pause: item.sessionPauseMilliseconds,
|
||||||
|
perDay: item.perDay !== 0 ? true : false
|
||||||
})),
|
})),
|
||||||
version: getCategoryRulesVersion(categoryId)
|
version: getCategoryRulesVersion(categoryId)
|
||||||
}))
|
}))
|
||||||
|
|
|
@ -28,10 +28,12 @@ export class TimelimitRule {
|
||||||
readonly end: number
|
readonly end: number
|
||||||
readonly sessionDurationMilliseconds: number
|
readonly sessionDurationMilliseconds: number
|
||||||
readonly sessionPauseMilliseconds: number
|
readonly sessionPauseMilliseconds: number
|
||||||
|
readonly perDay: boolean
|
||||||
|
|
||||||
constructor ({
|
constructor ({
|
||||||
ruleId, categoryId, maxTimeInMillis, dayMask, applyToExtraTimeUsage,
|
ruleId, categoryId, maxTimeInMillis, dayMask, applyToExtraTimeUsage,
|
||||||
start, end, sessionDurationMilliseconds, sessionPauseMilliseconds
|
start, end, sessionDurationMilliseconds, sessionPauseMilliseconds,
|
||||||
|
perDay
|
||||||
}: {
|
}: {
|
||||||
ruleId: string
|
ruleId: string
|
||||||
categoryId: string
|
categoryId: string
|
||||||
|
@ -42,6 +44,7 @@ export class TimelimitRule {
|
||||||
end: number
|
end: number
|
||||||
sessionDurationMilliseconds: number
|
sessionDurationMilliseconds: number
|
||||||
sessionPauseMilliseconds: number
|
sessionPauseMilliseconds: number
|
||||||
|
perDay: boolean
|
||||||
}) {
|
}) {
|
||||||
this.ruleId = ruleId
|
this.ruleId = ruleId
|
||||||
this.categoryId = categoryId
|
this.categoryId = categoryId
|
||||||
|
@ -52,6 +55,7 @@ export class TimelimitRule {
|
||||||
this.end = end
|
this.end = end
|
||||||
this.sessionDurationMilliseconds = sessionDurationMilliseconds
|
this.sessionDurationMilliseconds = sessionDurationMilliseconds
|
||||||
this.sessionPauseMilliseconds = sessionPauseMilliseconds
|
this.sessionPauseMilliseconds = sessionPauseMilliseconds
|
||||||
|
this.perDay = perDay
|
||||||
|
|
||||||
assertIdWithinFamily(ruleId)
|
assertIdWithinFamily(ruleId)
|
||||||
assertIdWithinFamily(categoryId)
|
assertIdWithinFamily(categoryId)
|
||||||
|
@ -98,7 +102,7 @@ export class TimelimitRule {
|
||||||
dur: this.sessionDurationMilliseconds
|
dur: this.sessionDurationMilliseconds
|
||||||
})
|
})
|
||||||
|
|
||||||
static parse = ({ ruleId, categoryId, time, days, extraTime, start, end, dur, pause }: SerializedTimeLimitRule) => (
|
static parse = ({ ruleId, categoryId, time, days, extraTime, start, end, dur, pause, perDay }: SerializedTimeLimitRule) => (
|
||||||
new TimelimitRule({
|
new TimelimitRule({
|
||||||
ruleId,
|
ruleId,
|
||||||
categoryId,
|
categoryId,
|
||||||
|
@ -108,7 +112,8 @@ export class TimelimitRule {
|
||||||
start: start ?? MinuteOfDay.MIN,
|
start: start ?? MinuteOfDay.MIN,
|
||||||
end: end ?? MinuteOfDay.MAX,
|
end: end ?? MinuteOfDay.MAX,
|
||||||
sessionDurationMilliseconds: dur ?? 0,
|
sessionDurationMilliseconds: dur ?? 0,
|
||||||
sessionPauseMilliseconds: pause ?? 0
|
sessionPauseMilliseconds: pause ?? 0,
|
||||||
|
perDay: perDay ?? false
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -123,6 +128,7 @@ export interface SerializedTimeLimitRule {
|
||||||
end?: number
|
end?: number
|
||||||
dur?: number
|
dur?: number
|
||||||
pause?: number
|
pause?: number
|
||||||
|
perDay?: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
export class ParseTimeLimitRuleException extends Error {}
|
export class ParseTimeLimitRuleException extends Error {}
|
||||||
|
|
|
@ -187,6 +187,7 @@ export interface ServerTimeLimitRule {
|
||||||
end: number // endMinuteOfDay
|
end: number // endMinuteOfDay
|
||||||
session: number // maximum session duration
|
session: number // maximum session duration
|
||||||
pause: number // session pause duration
|
pause: number // session pause duration
|
||||||
|
perDay: boolean
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface ServerUpdatedCategoryTasks {
|
export interface ServerUpdatedCategoryTasks {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue