Trois déclencheurs différents vous permettent de programmer une automatisation à l'avance:
Le premier, Time.ScheduledTimeEvent
, vous permet de programmer une automatisation pour qu'elle démarre à un instant précis dans le futur ou de manière récurrente, en fonction de l'heure ou d'un événement solaire (lever ou coucher du soleil).
Par exemple, ce déclencheur lance l'automatisation à 22h tous les jours :
starter<_>(structure, Time.ScheduledTimeEvent) { parameter(Time.ScheduledTimeEvent.clockTime(LocalTime.of(22, 0, 0, 0))) }
Vous pouvez également spécifier un événement en heure solaire au lieu de l'heure de l'horloge. Le paramètre de ce type de déclencheur est un SolarTimeStruct
composé des éléments suivants:
type
, qui correspond àSolarTimeType.Sunrise
ouSolarTimeType.Sunset
.offset
, qui vous permet de décaler l'heure de début par rapport à l'événement solaire de n'importe quelle durée. Les valeurs positives introduisent un délai après l'événement solaire, tandis que les valeurs négatives déclenchent le déclencheur avant l'événement solaire.
L'exemple suivant est un déclencheur qui lance l'automatisation 15 minutes avant le lever du soleil chaque jour:
starter<_>(structure, Time.ScheduledTimeEvent) { parameter( Time.ScheduledTimeEvent.solarTime( SolarTimeStruct(SolarTimeType.Sunrise, java.time.Duration.ofMinutes(-15)) ) ) }
Les deux derniers déclencheurs sont des déclencheurs d'événements planifiés récurrents, qui vous permettent de créer des automatisations qui s'exécutent périodiquement selon des critères plus spécifiques pouvant inclure des conditions basées sur le temps et le calendrier.
Time.RecurringClockTimeScheduledEvent
vous permet de planifier une automatisation en fonction d'une ou de plusieurs conditions d'heure ou de date.
Ce déclencheur utilise une syntaxe semblable à celle de l'utilitaire Unix cron
pour spécifier la planification d'une automatisation récurrente.
Time.RecurringSolarTimeScheduledEvent
vous permet de programmer une automatisation en fonction du lever ou du coucher du soleil, éventuellement en combinaison avec une condition basée sur un calendrier.
Expressions cron
Vous connaissez peut-être déjà cron
, une commande utilisée sur les systèmes Unix et Linux pour planifier des tâches récurrentes.
Les déclencheurs d'événements planifiés récurrents utilisent une syntaxe d'expression de planification semblable à celle utilisée par cron
. C'est pourquoi les expressions de planification utilisées avec ces déclencheurs sont appelées expressions cron
.
Il existe plusieurs "saveurs" différentes de cron
et plusieurs variantes de syntaxe dans ces implémentations. Les expressions cron
du déclencheur d'événement planifié récurrent utilisent la même syntaxe que le planificateur Quartz.
La syntaxe des expressions cron
de Quartz est expliquée dans la documentation sur CronExpression
.
Exemples
Voici quelques exemples pour illustrer.
Cas d'utilisation | Deuxième | Minute | Heure | Jour du mois | Mois | Jour de la semaine | Année |
---|---|---|---|---|---|---|---|
Exécution toutes les 24 heures, à minuit | 0 |
0 |
0 |
? |
* |
* |
* |
Exécution à 6h du matin tous les mardis | 0 |
30 |
19 |
? |
* |
3 |
* |
Exécution à 15h00, toutes les heures, pendant le mois de février | 0 |
15 |
* |
? |
2 |
* |
* |
Exécuter une fois par heure | 0 |
0 |
* |
? |
* |
* |
* |
Exécution toutes les 24 heures, à minuit, de janvier à mars, le jour ouvré le plus proche du 1er du mois | 0 |
0 |
0 |
? |
1-3 |
1W |
* |
Le deuxième jeudi de février, une fois par heure, à un quart de l'heure | 0 |
15 |
* |
? |
2 |
5#2 |
* |
Exécution à 15 heures, toutes les heures, le dernier jour du mois de février | 0 |
15 |
* |
L |
2 |
? |
* |
Exécution à 6h00 du matin tous les mardis et jeudis | 0 |
30 |
19 |
? |
* |
3,5 |
* |
RecurringClockTimeScheduledEvent
Dans un déclencheur RecurringClockTimeScheduledEvent
, la chaîne d'expression cron
est attribuée au champ Time.RecurringClockTimeScheduledEvent.cronExpression
.
Voici un exemple de déclencheur RecurringClockTimeScheduledEvent
qui lance l'automatisation à 20h, tous les mercredis d'avril :
starter<_>(structure, event = Time.RecurringClockTimeScheduledEvent) { parameter(Time.RecurringClockTimeScheduledEvent.cronExpression("0 0 20 ? 4 4 *")) }
RecurringSolarTimeScheduleEvent
Le déclencheur RecurringSolarTimeScheduleEvent
prend deux paramètres:
- Un
SolarTimeStruct
. cronExpression
: sous-ensemble d'une expressioncron
composé uniquement des champs Jour du mois, Mois, Jour de la semaine et Année. L'heure solaire détermine l'heure exacte à laquelle l'automatisation commencera. Par conséquent, les champs Seconde, Minute et Heure sont omis.
L'exemple suivant est un déclencheur qui déclenche une automatisation une heure après le lever du soleil, tous les mercredis d'avril:
starter<_>(structure, event = Time.RecurringSolarTimeScheduledEvent) { parameter( Time.RecurringSolarTimeScheduledEvent.solarTime( TimeTrait.SolarTimeStruct(SolarTimeType.Sunrise, Duration.ofHours(1)) ) ) parameter(Time.RecurringSolarTimeScheduledEvent.cronExpression("? 4 4 *")) }