Support for schedules with static dates or recurrences.
waste_collection_schedule:
sources:
- name: static
args:
type: TYPE
dates: DATES
frequency: FREQUENCY
interval: INTERVAL
start: START
until: UNTIL
count: COUNT
excludes: EXCLUDES
weekdays: WEEKDAYS
TYPE
(string) (required)
The type of this source.
DATES
(list) (optional)
A list of dates in format YYYY-MM-DD
which should be added to the source.
Dates defined in this list will be added in addition to calculated dates from the recurrence and will not be affected by the exclude-list.
FREQUENCY
(string) (optional)
Defines the frequency of the recurrence. Must be one of DAILY
, WEEKLY
, MONTHLY
or YEARLY
.
INTERVAL
(int) (optional, default: 1
)
Defines the interval of the recurrence.
START
(string) (optional)
Defines the start of the recurrence in the format YYYY-MM-DD
.
Required if frequency
is set. Always add either until
or count
, otherwise you will get only the next 10 events after start.
UNTIL
(string) (optional)
Defines the end of the recurrence in the format YYYY-MM-DD
.
COUNT
(int) (optional)
Defines the (maximum) number of returned dates. Only used if until
is not specified. Defaults to 10.
EXCLUDES
(list) (optional)
A list of dates in format YYYY-MM-DD
which should be excluded from the recurrence.
WEEKDAYS
(weekday | dictionary of weekday and occurrence) (optional)
Used to define the weekday for weekly or monthly frequencies. A weekday is specified by the following weekday constants: MO, TU, WE, TH, FR, SA, SU
.
weekdays
can be specified in one of the following formats:
-
Single Weekday:
weekdays: MO
-
Dictionary:
weekdays: { MO: 1, FR: -2 }
The additional numerical argument means the nth occurrence of this weekday in the specified frequency (normally only MONTHLY makes sense here). If frequency is set to
MONTHLY
,MO: 1
represents the first Monday of the month.FR: -2
represents the 2nd last Friday of the month.IMPORTANT: The colon must be followed by a space!
This example defines a schedule, every 4 weeks starting on Friday, January 14, 2022 until the end of the year. Two days are removed from the schedule and two days are added instead, which are outside of the recurrence.
waste_collection_schedule:
sources:
- name: static
args:
type: Altpapier
frequency: WEEKLY
interval: 4
start: '2022-01-14'
until: '2022-12-31'
excludes: # Add exception for the recurrence
- '2022-07-29'
- '2022-09-23'
dates: # Manually add dates that are not part of the recurrence
- '2022-07-28'
- '2022-09-22'
Defines a weekly schedule on Wednesday.
waste_collection_schedule:
sources:
- name: static
args:
type: Altpapier
frequency: WEEKLY
weekdays: WE
Defines a schedule for the 2nd last Thursday of a month.
waste_collection_schedule:
sources:
- name: static
args:
type: Altpapier
frequency: MONTHLY
weekdays: {TH: -1}
Defines a bi-weekly schedule for starting on the 01-Feb-2023.
waste_collection_schedule:
sources:
- name: static
args:
type: Altpapier
frequency: WEEKLY
interval: 2
start: '2023-02-01'
until: '2023-12-31'