Tres activadores diferentes te permiten programar una automatización con anticipación:
El primero, Time.ScheduledTimeEvent
, te permite programar una automatización para que comience en un instante preciso en el futuro o de forma recurrente, según la hora del reloj o un evento solar (es decir, el amanecer o el atardecer).
Por ejemplo, este activador inicia la automatización a las 10 p.m. todos los días:
starter<_>(structure, Time.ScheduledTimeEvent) { parameter(Time.ScheduledTimeEvent.clockTime(LocalTime.of(22, 0, 0, 0))) }
Como alternativa, puedes especificar un evento de hora solar en lugar de la hora del reloj. El parámetro para este tipo de iniciador es un SolarTimeStruct
que consta de lo siguiente:
type
, que esSolarTimeType.Sunrise
oSolarTimeType.Sunset
.offset
, que te permite cambiar la hora de inicio en relación con el evento solar en cualquier cantidad de tiempo. Los valores positivos introducen una demora después del evento solar, y los valores negativos hacen que el dispositivo de arranque se active antes del evento solar.
El siguiente ejemplo es un activador que inicia la automatización 15 minutos antes del amanecer todos los días:
starter<_>(structure, Time.ScheduledTimeEvent) { parameter( Time.ScheduledTimeEvent.solarTime( SolarTimeStruct(SolarTimeType.Sunrise, java.time.Duration.ofMinutes(-15)) ) ) }
Los otros dos activadores son activadores de eventos programados recurrentes, que te permiten crear automatizaciones que se ejecutan periódicamente según criterios más específicos que pueden incluir condiciones basadas en el tiempo y el calendario.
Time.RecurringClockTimeScheduledEvent
te permite programar una automatización en función de una o más condiciones de fecha y hora.
Este iniciador usa una sintaxis similar a la que usa la utilidad cron
de Unix para especificar la programación de una automatización recurrente.
Time.RecurringSolarTimeScheduledEvent
te permite programar una automatización en función de la hora del amanecer o el atardecer,
opcionalmente en combinación con una condición basada en el calendario.
cron
expresiones
Es posible que ya conozcas cron
, un comando que se usa en los sistemas Unix y Linux para programar trabajos recurrentes.
Los activadores de eventos programados recurrentes usan una sintaxis de expresión de programación similar a la que usa cron
, por lo que las expresiones de programación que se usan con estos activadores se conocen como expresiones de cron
.
Existen diferentes "sabores" de cron
y varias variaciones de sintaxis en estas implementaciones. Las expresiones cron
de inicio de eventos programados recurrentes usan la misma sintaxis que el programador de Quartz.
La sintaxis de la expresión cron
de Quartz se explica en la documentación de CronExpression
de Quartz.
Ejemplos
Estos son algunos ejemplos para ilustrarlo.
Caso de uso | Segundo | Minuto | Hora | Día del mes | Mes | Día de la semana | Año |
---|---|---|---|---|---|---|---|
Se ejecuta cada 24 horas, a la medianoche. | 0 |
0 |
0 |
? |
* |
* |
* |
Se ejecuta todos los martes a las 6 a.m. | 0 |
30 |
19 |
? |
* |
3 |
* |
Se ejecuta cada hora, a los quince minutos, durante el mes de febrero. | 0 |
15 |
* |
? |
2 |
* |
* |
Se ejecuta una vez por hora | 0 |
0 |
* |
? |
* |
* |
* |
Se ejecuta cada 24 horas, a la medianoche, de enero a marzo, en el día hábil más cercano al 1ᵉʳ día del mes. | 0 |
0 |
0 |
? |
1-3 |
1W |
* |
El segundo jueves de febrero, una vez por hora, a los quince minutos | 0 |
15 |
* |
? |
2 |
5#2 |
* |
Se ejecuta cada hora y cuarto, todos los días, el último día de febrero | 0 |
15 |
* |
L |
2 |
? |
* |
Se ejecuta a las 6:00 a.m. todos los martes y jueves | 0 |
30 |
19 |
? |
* |
3,5 |
* |
RecurringClockTimeScheduledEvent
En un iniciador de RecurringClockTimeScheduledEvent
, la cadena de expresión cron
se asigna al campo Time.RecurringClockTimeScheduledEvent.cronExpression
.
El siguiente es un ejemplo de un activador RecurringClockTimeScheduledEvent
que inicia la automatización a las 8 p.m. todos los miércoles de abril:
starter<_>(structure, event = Time.RecurringClockTimeScheduledEvent) { parameter(Time.RecurringClockTimeScheduledEvent.cronExpression("0 0 20 ? 4 4 *")) }
RecurringSolarTimeScheduleEvent
El iniciador RecurringSolarTimeScheduleEvent
toma dos parámetros:
- Un
SolarTimeStruct
. cronExpression
: Es un subconjunto de una expresióncron
que consta solo de los campos Día del mes, Mes, Día de la semana y Año. La hora solar determina la hora exacta en la que se iniciará la automatización, por lo que se omiten los campos de segundos, minutos y horas.
El siguiente ejemplo es un activador que hace que una automatización comience una hora después del amanecer, todos los miércoles de abril:
starter<_>(structure, event = Time.RecurringSolarTimeScheduledEvent) { parameter( Time.RecurringSolarTimeScheduledEvent.solarTime( TimeTrait.SolarTimeStruct(SolarTimeType.Sunrise, Duration.ofHours(1)) ) ) parameter(Time.RecurringSolarTimeScheduledEvent.cronExpression("? 4 4 *")) }