Scheduling Actions

Every driver can schedule events to occur in a number of different ways. Schedules are automatically cleared when a driver is terminated.

  • Integer arguments are in milliseconds. 1000 == 1 second

  • Strings can be used for a friendly representation of the time

    • '30s' == 30 seconds

    • '5m' == 5 minutes

    • '1w2d3h5m' == 1 week, 2 days, 3 hours and 5 minutes

    • '2Y1M' == 2 years, 1 month

Function

Arguments

Description

schedule.in

String or Integer

schedule a task to run once in the time specified (formats above)

schedule.at

Time or String

schedule a task at a time represented by a Time object or a parsable time string

schedule.every

String or Integer

schedule a task to run every time period on repeat

schedule.cron

String

A schedule that will fire based on a CRON string

schedule.clear

shortcut for cancelling any active schedules

Examples

schedule.every('1m') do
    # perform some action, such as polling
end

schedule.in(500) do
    # ...
end

schedule.at(Time.now + 2.hours) do
    # ...
end

schedule.at('2018-02-02T15:32:41+11:00') do
    # ...
end

# Every day at 8am
schedule.cron('0 8 * * *') do
    # ...
end

# Canceling an individual schedule
@email_sched = schedule.in(500) do
    send_email
end
@email_sched.cancel

There are often situations where you want to run the block immediately.

def connected
    schedule.every('1m', :run_now) do
        poll_current_state
    end
end

CRON also supports time zones - which should always be configured

schedule.cron('0 8 * * *', timezone: 'Sydney') do
    # ...
end

See the list of supported time zone strings and information about time zones.

Last updated