2019-07-11 02:02:56 +08:00
< p align = "center" >
< img src = "res/at-logo.png" >
< / p >
2019-08-13 03:09:43 +08:00
< p align = "center" >
2020-05-07 23:39:38 +08:00
< a href = "https://github.com/actions/toolkit/actions?query=workflow%3Atoolkit-unit-tests" > < img alt = "Toolkit unit tests status" src = "https://github.com/actions/toolkit/workflows/toolkit-unit-tests/badge.svg" > < / a >
< a href = "https://github.com/actions/toolkit/actions?query=workflow%3Atoolkit-audit" > < img alt = "Toolkit audit status" src = "https://github.com/actions/toolkit/workflows/toolkit-audit/badge.svg" > < / a >
2019-08-13 03:09:43 +08:00
< / p >
2019-10-04 00:45:11 +08:00
2019-08-24 21:24:48 +08:00
## GitHub Actions Toolkit
2019-07-11 02:02:56 +08:00
2019-10-03 05:59:33 +08:00
The GitHub Actions ToolKit provides a set of packages to make creating actions easier.
2019-04-20 22:56:56 +08:00
2019-10-04 00:45:11 +08:00
< br / >
< h3 align = "center" > Get started with the < a href = "https://github.com/actions/javascript-action" > javascript-action template< / a > !< / h3 >
< br / >
2019-04-20 22:56:56 +08:00
## Packages
2020-05-27 22:33:23 +08:00
:heavy_check_mark: [@actions/core ](packages/core )
2019-08-01 23:26:17 +08:00
2019-10-03 05:59:33 +08:00
Provides functions for inputs, outputs, results, logging, secrets and variables. Read more [here ](packages/core )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/core
2019-10-03 05:59:33 +08:00
```
< br / >
2020-05-27 22:33:23 +08:00
:runner: [@actions/exec ](packages/exec )
2019-10-03 05:59:33 +08:00
Provides functions to exec cli tools and process output. Read more [here ](packages/exec )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/exec
2019-10-03 05:59:33 +08:00
```
< br / >
2020-01-11 01:00:22 +08:00
:ice_cream: [@actions/glob ](packages/glob )
Provides functions to search for files matching glob patterns. Read more [here ](packages/glob )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/glob
2020-01-11 01:00:22 +08:00
```
< br / >
2022-05-03 23:10:13 +08:00
:phone: [@actions/http-client ](packages/http-client )
A lightweight HTTP client optimized for building actions. Read more [here ](packages/http-client )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/http -client
2022-05-03 23:10:13 +08:00
```
< br / >
2020-05-27 22:33:23 +08:00
:pencil2: [@actions/io ](packages/io )
2019-10-03 05:59:33 +08:00
2021-03-11 22:57:31 +08:00
Provides disk i/o functions like cp, mv, rmRF, which etc. Read more [here ](packages/io )
2019-10-03 05:59:33 +08:00
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/io
2019-10-03 05:59:33 +08:00
```
< br / >
2020-05-27 22:33:23 +08:00
:hammer: [@actions/tool-cache ](packages/tool-cache )
2019-10-03 05:59:33 +08:00
Provides functions for downloading and caching tools. e.g. setup-* actions. Read more [here ](packages/tool-cache )
2020-05-27 22:33:23 +08:00
See @actions/cache for caching workflow dependencies.
2020-05-08 03:03:20 +08:00
2019-10-03 05:59:33 +08:00
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/tool -cache
2019-10-03 05:59:33 +08:00
```
< br / >
2020-05-27 22:33:23 +08:00
:octocat: [@actions/github ](packages/github )
2019-10-03 05:59:33 +08:00
Provides an Octokit client hydrated with the context that the current action is being run in. Read more [here ](packages/github )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/github
2019-10-03 05:59:33 +08:00
```
< br / >
2019-04-22 23:46:19 +08:00
2020-05-27 22:33:23 +08:00
:floppy_disk: [@actions/artifact ](packages/artifact )
2020-02-21 04:05:07 +08:00
Provides functions to interact with actions artifacts. Read more [here ](packages/artifact )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/artifact
2020-02-21 04:05:07 +08:00
```
< br / >
2020-05-27 22:33:23 +08:00
:dart: [@actions/cache ](packages/cache )
2020-05-06 23:10:18 +08:00
2020-05-08 03:03:20 +08:00
Provides functions to cache dependencies and build outputs to improve workflow execution time. Read more [here ](packages/cache )
2020-05-06 23:10:18 +08:00
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/cache
2020-05-06 23:10:18 +08:00
```
< br / >
2024-02-18 11:14:10 +08:00
:lock_with_ink_pen: [@actions/attest ](packages/attest )
Provides functions to write attestations for workflow artifacts. Read more [here ](packages/attest )
```bash
2025-04-09 22:46:07 +08:00
npm install @actions/attest
2024-02-18 11:14:10 +08:00
```
< br / >
2019-08-01 23:26:17 +08:00
## Creating an Action with the Toolkit
2019-04-22 23:46:19 +08:00
2019-10-03 05:59:33 +08:00
:question: [Choosing an action type ](docs/action-types.md )
Outlines the differences and why you would want to create a JavaScript or a container based action.
< br / >
< br / >
2019-10-04 00:45:11 +08:00
:curly_loop: [Versioning ](docs/action-versioning.md )
Actions are downloaded and run from the GitHub graph of repos. This contains guidance for versioning actions and safe releases.
< br / >
< br / >
2019-12-13 02:43:34 +08:00
:warning: [Problem Matchers ](docs/problem-matchers.md )
Problem Matchers are a way to scan the output of actions for a specified regex pattern and surface that information prominently in the UI.
< br / >
< br / >
2020-02-12 22:26:59 +08:00
:warning: [Proxy Server Support ](docs/proxy-support.md )
2020-05-27 22:33:23 +08:00
Self-hosted runners can be configured to run behind proxy servers.
2020-02-12 22:26:59 +08:00
< br / >
< br / >
2019-10-04 01:51:11 +08:00
< h3 > < a href = "https://github.com/actions/hello-world-javascript-action" > Hello World JavaScript Action< / a > < / h3 >
2019-10-03 05:59:33 +08:00
Illustrates how to create a simple hello world javascript action.
```javascript
...
const nameToGreet = core.getInput('who-to-greet');
console.log(`Hello ${nameToGreet}!`);
...
```
< br / >
2019-10-04 01:51:11 +08:00
< h3 > < a href = "https://github.com/actions/javascript-action" > JavaScript Action Walkthrough< / a > < / h3 >
2020-05-27 22:33:23 +08:00
2019-10-04 01:51:11 +08:00
Walkthrough and template for creating a JavaScript Action with tests, linting, workflow, publishing, and versioning.
2019-10-03 05:59:33 +08:00
2019-10-04 00:45:11 +08:00
```javascript
async function run() {
2020-05-27 22:33:23 +08:00
try {
2019-10-04 00:45:11 +08:00
const ms = core.getInput('milliseconds');
console.log(`Waiting ${ms} milliseconds ...`)
...
```
```javascript
2019-10-03 05:59:33 +08:00
PASS ./index.test.js
2020-05-27 22:33:23 +08:00
✓ throws invalid number
✓ wait 500 ms
2019-10-03 05:59:33 +08:00
✓ test runs
2020-05-27 22:33:23 +08:00
Test Suites: 1 passed, 1 total
2019-10-03 05:59:33 +08:00
Tests: 3 passed, 3 total
2019-10-04 00:45:11 +08:00
```
2019-10-03 05:59:33 +08:00
< br / >
2019-10-04 01:51:11 +08:00
< h3 > < a href = "https://github.com/actions/typescript-action" > TypeScript Action Walkthrough< / a > < / h3 >
2019-10-03 05:59:33 +08:00
Walkthrough creating a TypeScript Action with compilation, tests, linting, workflow, publishing, and versioning.
```javascript
import * as core from '@actions/core';
async function run() {
try {
const ms = core.getInput('milliseconds');
console.log(`Waiting ${ms} milliseconds ...`)
...
2019-10-04 00:45:11 +08:00
```
```javascript
PASS ./index.test.js
2020-05-27 22:33:23 +08:00
✓ throws invalid number
✓ wait 500 ms
2019-10-04 00:45:11 +08:00
✓ test runs
2019-10-03 05:59:33 +08:00
2020-05-27 22:33:23 +08:00
Test Suites: 1 passed, 1 total
2019-10-04 00:45:11 +08:00
Tests: 3 passed, 3 total
2019-10-03 05:59:33 +08:00
```
< br / >
< br / >
2019-10-04 01:51:11 +08:00
< h3 > < a href = "docs/container-action.md" > Docker Action Walkthrough< / a > < / h3 >
2019-10-03 05:59:33 +08:00
Create an action that is delivered as a container and run with docker.
```docker
FROM alpine:3.10
COPY LICENSE README.md /
COPY entrypoint.sh /entrypoint.sh
ENTRYPOINT ["/entrypoint.sh"]
```
< br / >
2019-04-22 23:46:19 +08:00
2019-10-04 01:51:11 +08:00
< h3 > < a href = "https://github.com/actions/container-toolkit-action" > Docker Action Walkthrough with Octokit< / a > < / h3 >
2019-09-11 15:35:39 +08:00
2019-10-03 05:59:33 +08:00
Create an action that is delivered as a container which uses the toolkit. This example uses the GitHub context to construct an Octokit client.
2019-09-11 15:35:39 +08:00
2019-10-04 00:45:11 +08:00
```docker
FROM node:slim
COPY . .
RUN npm install --production
ENTRYPOINT ["node", "/lib/main.js"]
```
2019-10-03 05:59:33 +08:00
```javascript
2019-10-04 00:45:11 +08:00
const myInput = core.getInput('myInput');
core.debug(`Hello ${myInput} from inside a container`);
2019-04-22 23:46:19 +08:00
2019-10-04 00:45:11 +08:00
const context = github.context;
2020-05-27 22:33:23 +08:00
console.log(`We can even get context data, like the repo: ${context.repo.repo}`)
2019-10-03 05:59:33 +08:00
```
< br / >
2019-04-22 23:46:19 +08:00
2025-06-10 23:39:47 +08:00
## Note
2019-04-22 23:46:19 +08:00
2025-06-10 23:39:47 +08:00
Thank you for your interest in this GitHub repo, however, right now we are not taking contributions.
We continue to focus our resources on strategic areas that help our customers be successful while making developers' lives easier. While GitHub Actions remains a key part of this vision, we are allocating resources towards other areas of Actions and are not taking contributions to this repository at this time. The GitHub public roadmap is the best place to follow along for any updates on features we’ re working on and what stage they’ re in.
We are taking the following steps to better direct requests related to GitHub Actions, including:
1. We will be directing questions and support requests to our [Community Discussions area ](https://github.com/orgs/community/discussions/categories/actions )
2. High Priority bugs can be reported through Community Discussions or you can report these to our support team https://support.github.com/contact/bug-report.
2025-06-12 17:28:03 +08:00
3. Security Issues should be handled as per our [security.md ](SECURITY.md ).
2025-06-10 23:39:47 +08:00
We will still provide security updates for this project and fix major breaking changes during this time.
You are welcome to still raise bugs in this repo.
2019-10-09 20:47:27 +08:00
## Code of Conduct
See [our code of conduct ](CODE_OF_CONDUCT.md ).