GitHub Action
github-action-scheduler
Github Action to run a Schedule.
This is a general-purpose scheduling action. While it does not do anything with the schedule, it outputs variables that allow you to run subsequent steps on a schedule.
The scheduling mechanism in this action is simple, yet powerful.
When you execute this action, you must give the step an id
to allow access to the step outputs.
So, by assigning the step with: id: schedule
, you will be able to access the outputs as ${{ steps.schedule.outputs.EXAMPLE }}
.
This means you can run multiple schedules, each with a unique ID.
Each schedule has a name
property. This name
is used as an output for the step. If the schedule matches the current date and time, the name
output will be 'true'
. Otherwise, it will be 'false'
.
In your config JSON, you will define each schedule with a name
property.
{
"name": "example",
},
The name will convert to "screaming snake case", which is snake_case
with all capital letters. So, example
, will convert to EXAMPLE
.
For your convenience, the action prints how to access the output in the logs.
In your workflow yaml, you access it by utilizing the if
property of a subsequent step.
if: ${{ steps.schedule.outputs.EXAMPLE == 'true' }}
if: ${{ steps.schedule.outputs.EXAMPLE != 'true' }}
if: ${{ steps.schedule.outputs.EXAMPLE == 'false' }}
if: ${{ steps.schedule.outputs.EXAMPLE != 'false' }}
You can define a schedule based on the day(s) of the week. This is useful for recurring events that happen on a particular day of the week.
{
"name": "weekdays",
"days": ["monday", "tuesday", "wednesday", "thursday", "friday"]
},
{
"name": "weekends",
"days": ["saturday", "sunday"]
}
You can define date schedules. This is useful for one-off events that happen on specific days, such as holidays.
{
"name": "holidays",
"dates": ["2024-07-04", "2024-12-25"]
}
Dates can use one of these formats. The date parser requires an exact match, so you cannot include any extra characters and you cannot use any delimiter except "-".
Format | Example | Description |
---|---|---|
YYYY-MM-DD | 2024-07-04 | Run this schedule on this year, month, and day. No repeats. |
MM-DD | 07-04 | Run this schedule on this month and day. Repeat each year. |
DD | 04 | Run this schedule on this day. Repeat each month. |
Each field within the date uses the following formats.
Format | Allowed Values | Description |
---|---|---|
YYYY | 0001-9999 | The year. Must be 4 digits. Prefix with one or more 0s if less than 999. |
MM | 01-12 | The month. Must be 2 digits. Prefix with 0 if less than 10. |
DD | 01-31 | The day. Must be 2 digits. Prefix with 0 if less than 10. |
Here is an example JSON scheduled. Save it as a Repository Github Variable.
{
"timeZone": "America/New_York",
"schedules": [
{
"name": "unlock",
"days": ["monday", "tuesday", "wednesday", "thursday", "friday"],
"startHour": 9,
"endHour": 18
},
{
"name": "lock (weekends)",
"days": ["saturday", "sunday"],
"startHour": 0,
"endHour": 24
},
{
"name": "lock (custom)",
"dates": ["2024-07-26"],
"startHour": 0,
"endHour": 24
}
]
}
The schema for the schedule JSON is in config.ts
.
Here is a sample Workflow YAML Configuration. It shows:
- How to run the schedule on a cron timer, when pushing to a branch, or manually using workflow dispatch.
- How to pass in the scheduled stored as a Github Variable.
- How to access the outputs.
name: Example
on:
schedule:
- cron: "0 * * * *" # Every Hour
push:
branches:
- main # On push to main branch
workflow_dispatch: # Run Manually with workflow dispatch
jobs:
Schedule:
runs-on: ubuntu-latest
steps:
- name: Check out repository code
uses: actions/checkout@v4
- name: Schedule Branch Lock
id: schedule # Make sure to give it an ID
uses: JustinDFuller/github-action-scheduler@v0
with:
config: ${{ vars.SCHEDULE }} # Pass in the Schedule Variable
# Print the outputs of the above example schedule.
- run: echo steps.schedule.outputs.UNLOCK=${{ steps.schedule.outputs.UNLOCK }}
- run: echo steps.schedule.outputs.LOCK_WEEKENDS=${{ steps.schedule.outputs.LOCK_WEEKENDS }}
- run: echo steps.schedule.outputs.LOCK_CUSTOM=${{ steps.schedule.outputs.LOCK_CUSTOM }}
There is a working demo in .github/workflows/demo.yml. You can see sample outputs here.
- Open the
settings
page for your repository.
- On the left-hand navigation menu, navigate to
Secrets and Variables
->Actions
.
- Switch to the
Variables
tab.
- Click
New Repository Variable
.
- In the
Name
field, enter the name you want to use to access this variable in your Github Action. In theValue
field, enter the Schedule Config JSON.
Click Save. This example variable would be available as ${{ var.SCHEDULE }}
.