What's new
Features & Limitations
This action can assign any project to a given issue, with the following caveats:
- Issues are assigned without a column, and are in
Awaiting triage
state - You may need to specify a different GITHUB_TOKEN if you need privileged permissions, e.g. access organization projects
- If you have multiple projects with the same name, the behavior is undefined
- If the issue is already assigned to a project, it will potentially overwrite it. If it's already assigned to the same project, nothing happens.
- Unless you know the node ID of the project, the project must be public, otherwise it will not show up when listing projects.
Usage
The action accepts two environment variables, and 4 optional arguments:
Environment variables
GITHUB_TOKEN
: it reads the token to use for authentication with the API via environment variablesPROJECT_ID
: if you already know the project's node ID (not the number in the URL), then you can set it here and it will skip the steps of finding the right project. This is the workaround if you have multiple projects of the same name.
Arguments/input
NOTE: all of this can be omitted if you specify the
PROJECT_ID
. They are only used to find the project ID. Otherwise, the project type, owner, and name, are all mandatory.
project_type
: one oforg
,repo
,user
. Selectorg
if your project is owned by an organization,repo
if it's under a particular repository, anduser
if it's a user project.project_owner
: depending on the type, it will be:org
: the organization key, e.g.zeebe-io
hererepo
: the repo's owner, e.g.zeebe-io
here.user
: the username of repo's owner
project_repo
: the name of the repository. Only required if the type isrepo
.project_name
: the name of the project, case-sensitive.
Examples
Repository project
Here's an example that assigns new and reopened issues to the given project. This project is a repository project, and as such must specify the owner of the repository, the repository name, and the project name.
name: Assign new issues to the default project
on:
issues:
types: [ opened, reopened ]
jobs:
assign:
name: Assign to project
runs-on: ubuntu-latest
steps:
- name: Assign to project
uses: zeebe-io/project-action@develop
with:
project_type: "repo"
project_owner: "zeebe-io"
project_repo: "project-action"
project_name: "Test"
Organization project
For organization project, the default GITHUB_TOKEN is typically not enough. You will need to create a new token with admin read rights for your organization, and create a secret to hold that token.
For organization projects, you only need to specify the type, owner, and name of the project. In this case, owner refers to the organization itself.
name: Assign new issues to the default project
on:
issues:
types: [ opened, reopened ]
jobs:
assign:
name: Assign to project
runs-on: ubuntu-latest
steps:
- name: Assign to project
uses: zeebe-io/project-action@develop
env:
GITHUB_TOKEN: ${{ secrets.ORG_TOKEN }}
with:
project_type: "org"
project_owner: "zeebe-io"
project_name: "Zeebe"
User project
For a user project, the default GITHUB_TOKEN is typically not enough. You will need to create a new token with admin read rights for such a project, and create a secret to hold that token.
For user projects, you only need to specify the type, owner, and name of the project. In this case, owner refers to the username of the user owning the project.
name: Assign new issues to the default project
on:
issues:
types: [ opened, reopened ]
jobs:
assign:
name: Assign to project
runs-on: ubuntu-latest
steps:
- name: Assign to project
uses: zeebe-io/project-action@develop
env:
GITHUB_TOKEN: ${{ secrets.USER_TOKEN }}
with:
project_type: "user"
project_owner: "npepinpe"
project_name: "Project"
Using an ID directly
You can bypass having to find the node ID of your project if you already know it. If you know it, then you can omit the project type, owner, name, and repo, and simply specify the ID as an environment variable.
In that case, depending on the type of the project (org, repo, or user), you may need to also specify a new token which has the correct permissions to read that project.
name: Assign new issues to the default project
on:
issues:
types: [ opened, reopened ]
jobs:
assign:
name: Assign to project
runs-on: ubuntu-latest
steps:
- name: Assign to project
uses: zeebe-io/project-action@develop
env:
GITHUB_TOKEN: ${{ secrets.USER_TOKEN }}
PROJECT_ID: ${{ secrets.PROJECT_ID }}