Trois déclencheurs différents vous permettent de planifier une automatisation à l'avance :
Le premier déclencheur, Time.ScheduledTimeEvent,
vous permet de planifier 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
(c'est-à-dire le lever ou le 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 solaire au lieu de l'heure. Le
paramètre de ce type de déclencheur est un
SolarTimeStruct
composé des éléments suivants :
type, qui estSolarTimeType.SunriseouSolarTimeType.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, et les valeurs négatives font que le déclencheur se déclenche avant l'événement solaire.
L'exemple suivant est un déclencheur qui lance l'automatisation 15 minutes avant le lever du soleil tous les jours :
starter<_>(structure, Time.ScheduledTimeEvent) { parameter( Time.ScheduledTimeEvent.solarTime( SolarTimeStruct(SolarTimeType.Sunrise, java.time.Duration.ofMinutes(-15)) ) ) }
Les deux autres 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 l'heure 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 utilisée par l'utilitaire Unix cron pour spécifier la planification d'une automatisation récurrente.
Time.RecurringSolarTimeScheduledEvent
vous permet de planifier une automatisation en fonction de l'heure du lever ou du coucher du soleil, éventuellement en combinaison avec une condition basée sur le 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 "versions" de cron, ainsi que plusieurs variations de syntaxe entre ces implémentations. Les expressions cron
du déclencheur d'événements planifiés récurrents utilisent la même syntaxe que le planificateur Quartz.
La syntaxe de l'expression cron de Quartz est expliquée dans la documentation de Quartz's
CronExpression.
Exemples
Voici quelques exemples pour illustrer cela.
| Cas d'utilisation | Deuxième | Minute | Heure | Jour du mois | Mois | Jour de la semaine | Année |
|---|---|---|---|---|---|---|---|
| Exécuter toutes les 24 heures, à minuit | 0 |
0 |
0 |
? |
* |
* |
* |
| Exécuter à 6h tous les mardis | 0 |
30 |
19 |
? |
* |
3 |
* |
| Exécuter à 15 minutes après l'heure, toutes les heures, pendant le mois de février | 0 |
15 |
* |
? |
2 |
* |
* |
| Exécuter une fois par heure | 0 |
0 |
* |
? |
* |
* |
* |
| Exécuter toutes les 24 heures, à minuit, de janvier à mars, le jour de la semaine le plus proche du 1er du mois | 0 |
0 |
0 |
? |
1-3 |
1W |
* |
| Le deuxième jeudi de février, une fois par heure, à 15 minutes après l'heure | 0 |
15 |
* |
? |
2 |
5#2 |
* |
| Exécuter à 15 minutes après l'heure, toutes les heures, le dernier jour du mois de février | 0 |
15 |
* |
L |
2 |
? |
* |
| Exécuter à 6h 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
Time.RecurringClockTimeScheduledEvent.cronExpression
champ.
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 accepte deux paramètres :
- Une
SolarTimeStruct. cronExpression: sous-ensemble d'une expressioncronne comprenant que les champs Jour du mois, Mois, Jour de la semaine et Année. L'heure solaire détermine l'heure exacte à laquelle l'automatisation démarrera. Par conséquent, les champs Seconde, Minute et Heure sont omis.
L'exemple suivant est un déclencheur qui lance 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 *")) }