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 solo 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:00 p.m. todos los días:
starter<_>(structure, Time.ScheduledTimeEvent) { parameter(Time.ScheduledTimeEvent.clockTime(LocalTime.of(22, 0, 0, 0))) }
Como alternativa, puedes especificar el evento de hora solar en lugar de la hora del reloj. El parámetro para este tipo de activador 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 por cualquier cantidad de tiempo. Los valores positivos introducen una demora después del evento solar, mientras que los valores negativos hacen que el activador 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 dos últimos 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 hora o fecha.
Este activador usa una sintaxis similar a la que usa la utilidad cron
de Unix para especificar el programa de una automatización recurrente.
Time.RecurringSolarTimeScheduledEvent
te permite programar una automatización en función de la hora del amanecer o del atardecer, de manera opcional, en combinación con una condición basada en el calendario.
Expresiones cron
Es posible que ya conozcas cron
, un comando que se usa en sistemas Unix y Linux para programar tareas recurrentes.
Los activadores de eventos programados recurrentes usan una sintaxis de expresión de programación similar a la que usa cron
y, por este motivo, las expresiones de programación que se usan con estos activadores se denominan expresiones cron
.
Existen varios "tipos" diferentes de cron
y varias variaciones de sintaxis en estas implementaciones. Las expresiones cron
del activador 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
A continuación, se incluyen algunos ejemplos para ilustrarlo.
Caso de uso | Segundo | Minuto | Hora | Día del mes | Mes | Día de la semana | Año |
---|---|---|---|---|---|---|---|
Ejecutar cada 24 horas a la medianoche | 0 |
0 |
0 |
? |
* |
* |
* |
Ejecutar a las 6:00 a.m. todos los martes | 0 |
30 |
19 |
? |
* |
3 |
* |
Ejecutar a los cuartos de hora, cada hora, durante el mes de febrero | 0 |
15 |
* |
? |
2 |
* |
* |
Ejecutar una vez por hora | 0 |
0 |
* |
? |
* |
* |
* |
Ejecutar cada 24 horas, a la medianoche, de enero a marzo, 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 |
* |
Ejecutar a los cuartos de hora, cada hora, el último día del mes de febrero | 0 |
15 |
* |
L |
2 |
? |
* |
Ejecutar a las 6:00 a.m. todos los martes y jueves | 0 |
30 |
19 |
? |
* |
3,5 |
* |
RecurringClockTimeScheduledEvent
En un activador 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:00 p.m. todos los miércoles de abril:
starter<_>(structure, event = Time.RecurringClockTimeScheduledEvent) { parameter(Time.RecurringClockTimeScheduledEvent.cronExpression("0 0 20 ? 4 4 *")) }
RecurringSolarTimeScheduleEvent
El activador 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 comenzará la automatización, por lo que se omiten los campos Segundo, Minuto y Hora.
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 *")) }