2019-08-04 09:34:59 +08:00
|
|
|
# `@actions/github`
|
|
|
|
|
|
|
|
> A hydrated Octokit client.
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
Returns an [Octokit SDK] client. See https://octokit.github.io/rest.js for the API.
|
|
|
|
|
|
|
|
```
|
|
|
|
const github = require('@actions/github');
|
2019-08-07 04:25:08 +08:00
|
|
|
const core = require('@actions/core');
|
2019-08-04 09:34:59 +08:00
|
|
|
|
|
|
|
// This should be a token with access to your repository scoped in as a secret.
|
2019-08-07 04:25:08 +08:00
|
|
|
const myToken = core.getInput('myToken');
|
2019-08-04 09:34:59 +08:00
|
|
|
|
2019-08-07 04:25:08 +08:00
|
|
|
const octokit = new github.GitHub(myToken);
|
2019-08-04 09:34:59 +08:00
|
|
|
|
|
|
|
const pulls = await octokit.pulls.get({
|
|
|
|
owner: 'octokit',
|
|
|
|
repo: 'rest.js',
|
|
|
|
pull_number: 123,
|
|
|
|
mediaType: {
|
|
|
|
format: 'diff'
|
|
|
|
}
|
2019-08-07 04:25:08 +08:00
|
|
|
});
|
2019-08-04 09:34:59 +08:00
|
|
|
|
2019-08-07 04:25:08 +08:00
|
|
|
console.log(pulls);
|
2019-08-04 09:34:59 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
You can also make GraphQL requests:
|
|
|
|
|
|
|
|
```
|
2019-08-07 04:25:08 +08:00
|
|
|
const result = await octokit.graphql(query, variables);
|
2019-08-04 09:34:59 +08:00
|
|
|
```
|
|
|
|
|
|
|
|
Finally, you can get the context of the current action:
|
|
|
|
|
|
|
|
```
|
|
|
|
const github = require('@actions/github');
|
|
|
|
|
2019-08-07 04:25:08 +08:00
|
|
|
const context = github.context;
|
2019-08-04 09:34:59 +08:00
|
|
|
|
|
|
|
const newIssue = await octokit.issues.create({
|
|
|
|
...context.repo,
|
|
|
|
title: 'New issue!',
|
|
|
|
body: 'Hello Universe!'
|
2019-08-07 04:25:08 +08:00
|
|
|
});
|
|
|
|
```
|