2020-07-31 16:22:34 +02:00
// Copyright 2020 The go-github AUTHORS. All rights reserved.
//
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
package github
import (
"context"
"fmt"
)
// RunnerApplicationDownload represents a binary for the self-hosted runner application that can be downloaded.
type RunnerApplicationDownload struct {
2021-08-10 11:49:43 +02:00
OS * string ` json:"os,omitempty" `
Architecture * string ` json:"architecture,omitempty" `
DownloadURL * string ` json:"download_url,omitempty" `
Filename * string ` json:"filename,omitempty" `
TempDownloadToken * string ` json:"temp_download_token,omitempty" `
SHA256Checksum * string ` json:"sha256_checksum,omitempty" `
}
// ActionsEnabledOnOrgRepos represents all the repositories in an organization for which Actions is enabled.
type ActionsEnabledOnOrgRepos struct {
TotalCount int ` json:"total_count" `
Repositories [ ] * Repository ` json:"repositories" `
2020-07-31 16:22:34 +02:00
}
// ListRunnerApplicationDownloads lists self-hosted runner application binaries that can be downloaded and run.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#list-runner-applications-for-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) ListRunnerApplicationDownloads ( ctx context . Context , owner , repo string ) ( [ ] * RunnerApplicationDownload , * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners/downloads" , owner , repo )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var rads [ ] * RunnerApplicationDownload
resp , err := s . client . Do ( ctx , req , & rads )
if err != nil {
return nil , resp , err
}
return rads , resp , nil
}
// RegistrationToken represents a token that can be used to add a self-hosted runner to a repository.
type RegistrationToken struct {
Token * string ` json:"token,omitempty" `
ExpiresAt * Timestamp ` json:"expires_at,omitempty" `
}
// CreateRegistrationToken creates a token that can be used to add a self-hosted runner.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#create-a-registration-token-for-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) CreateRegistrationToken ( ctx context . Context , owner , repo string ) ( * RegistrationToken , * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners/registration-token" , owner , repo )
req , err := s . client . NewRequest ( "POST" , u , nil )
if err != nil {
return nil , nil , err
}
registrationToken := new ( RegistrationToken )
resp , err := s . client . Do ( ctx , req , registrationToken )
if err != nil {
return nil , resp , err
}
return registrationToken , resp , nil
}
// Runner represents a self-hosted runner registered with a repository.
type Runner struct {
2021-08-10 11:49:43 +02:00
ID * int64 ` json:"id,omitempty" `
Name * string ` json:"name,omitempty" `
OS * string ` json:"os,omitempty" `
Status * string ` json:"status,omitempty" `
Busy * bool ` json:"busy,omitempty" `
Labels [ ] * RunnerLabels ` json:"labels,omitempty" `
}
// RunnerLabels represents a collection of labels attached to each runner.
type RunnerLabels struct {
ID * int64 ` json:"id,omitempty" `
Name * string ` json:"name,omitempty" `
Type * string ` json:"type,omitempty" `
2020-07-31 16:22:34 +02:00
}
// Runners represents a collection of self-hosted runners for a repository.
type Runners struct {
TotalCount int ` json:"total_count" `
Runners [ ] * Runner ` json:"runners" `
}
// ListRunners lists all the self-hosted runners for a repository.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#list-self-hosted-runners-for-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) ListRunners ( ctx context . Context , owner , repo string , opts * ListOptions ) ( * Runners , * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners" , owner , repo )
u , err := addOptions ( u , opts )
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
runners := & Runners { }
resp , err := s . client . Do ( ctx , req , & runners )
if err != nil {
return nil , resp , err
}
return runners , resp , nil
}
// GetRunner gets a specific self-hosted runner for a repository using its runner ID.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#get-a-self-hosted-runner-for-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) GetRunner ( ctx context . Context , owner , repo string , runnerID int64 ) ( * Runner , * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners/%v" , owner , repo , runnerID )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
runner := new ( Runner )
resp , err := s . client . Do ( ctx , req , runner )
if err != nil {
return nil , resp , err
}
return runner , resp , nil
}
// RemoveToken represents a token that can be used to remove a self-hosted runner from a repository.
type RemoveToken struct {
Token * string ` json:"token,omitempty" `
ExpiresAt * Timestamp ` json:"expires_at,omitempty" `
}
// CreateRemoveToken creates a token that can be used to remove a self-hosted runner from a repository.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#create-a-remove-token-for-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) CreateRemoveToken ( ctx context . Context , owner , repo string ) ( * RemoveToken , * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners/remove-token" , owner , repo )
req , err := s . client . NewRequest ( "POST" , u , nil )
if err != nil {
return nil , nil , err
}
removeToken := new ( RemoveToken )
resp , err := s . client . Do ( ctx , req , removeToken )
if err != nil {
return nil , resp , err
}
return removeToken , resp , nil
}
// RemoveRunner forces the removal of a self-hosted runner in a repository using the runner id.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#delete-a-self-hosted-runner-from-a-repository
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) RemoveRunner ( ctx context . Context , owner , repo string , runnerID int64 ) ( * Response , error ) {
u := fmt . Sprintf ( "repos/%v/%v/actions/runners/%v" , owner , repo , runnerID )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}
// ListOrganizationRunnerApplicationDownloads lists self-hosted runner application binaries that can be downloaded and run.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#list-runner-applications-for-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) ListOrganizationRunnerApplicationDownloads ( ctx context . Context , owner string ) ( [ ] * RunnerApplicationDownload , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners/downloads" , owner )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
var rads [ ] * RunnerApplicationDownload
resp , err := s . client . Do ( ctx , req , & rads )
if err != nil {
return nil , resp , err
}
return rads , resp , nil
}
// CreateOrganizationRegistrationToken creates a token that can be used to add a self-hosted runner to an organization.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#create-a-registration-token-for-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) CreateOrganizationRegistrationToken ( ctx context . Context , owner string ) ( * RegistrationToken , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners/registration-token" , owner )
req , err := s . client . NewRequest ( "POST" , u , nil )
if err != nil {
return nil , nil , err
}
registrationToken := new ( RegistrationToken )
resp , err := s . client . Do ( ctx , req , registrationToken )
if err != nil {
return nil , resp , err
}
return registrationToken , resp , nil
}
// ListOrganizationRunners lists all the self-hosted runners for an organization.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#list-self-hosted-runners-for-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) ListOrganizationRunners ( ctx context . Context , owner string , opts * ListOptions ) ( * Runners , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners" , owner )
u , err := addOptions ( u , opts )
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
runners := & Runners { }
resp , err := s . client . Do ( ctx , req , & runners )
if err != nil {
return nil , resp , err
}
return runners , resp , nil
}
2021-08-10 11:49:43 +02:00
// ListEnabledReposInOrg lists the selected repositories that are enabled for GitHub Actions in an organization.
//
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#list-selected-repositories-enabled-for-github-actions-in-an-organization
func ( s * ActionsService ) ListEnabledReposInOrg ( ctx context . Context , owner string , opts * ListOptions ) ( * ActionsEnabledOnOrgRepos , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/permissions/repositories" , owner )
u , err := addOptions ( u , opts )
if err != nil {
return nil , nil , err
}
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
repos := & ActionsEnabledOnOrgRepos { }
resp , err := s . client . Do ( ctx , req , repos )
if err != nil {
return nil , resp , err
}
return repos , resp , nil
}
2021-10-26 15:19:21 +08:00
// SetEnabledReposInOrg replaces the list of selected repositories that are enabled for GitHub Actions in an organization..
//
// GitHub API docs: https://docs.github.com/en/rest/reference/actions#set-selected-repositories-enabled-for-github-actions-in-an-organization
func ( s * ActionsService ) SetEnabledReposInOrg ( ctx context . Context , owner string , repositoryIDs [ ] int64 ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/permissions/repositories" , owner )
req , err := s . client . NewRequest ( "PUT" , u , struct {
IDs [ ] int64 ` json:"selected_repository_ids" `
} { IDs : repositoryIDs } )
if err != nil {
return nil , err
}
resp , err := s . client . Do ( ctx , req , nil )
if err != nil {
return resp , err
}
return resp , nil
}
// AddEnabledReposInOrg adds a repository to the list of selected repositories that are enabled for GitHub Actions in an organization.
//
// GitHub API docs: https://docs.github.com/en/rest/reference/actions#enable-a-selected-repository-for-github-actions-in-an-organization
func ( s * ActionsService ) AddEnabledReposInOrg ( ctx context . Context , owner string , repositoryID int64 ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/permissions/repositories/%v" , owner , repositoryID )
req , err := s . client . NewRequest ( "PUT" , u , nil )
if err != nil {
return nil , err
}
resp , err := s . client . Do ( ctx , req , nil )
if err != nil {
return resp , err
}
return resp , nil
}
// RemoveEnabledRepoInOrg removes a single repository from the list of enabled repos for GitHub Actions in an organization.
//
// GitHub API docs: https://docs.github.com/en/rest/reference/actions#disable-a-selected-repository-for-github-actions-in-an-organization
func ( s * ActionsService ) RemoveEnabledRepoInOrg ( ctx context . Context , owner string , repositoryID int64 ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/permissions/repositories/%v" , owner , repositoryID )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
resp , err := s . client . Do ( ctx , req , nil )
if err != nil {
return resp , err
}
return resp , nil
}
2020-07-31 16:22:34 +02:00
// GetOrganizationRunner gets a specific self-hosted runner for an organization using its runner ID.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#get-a-self-hosted-runner-for-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) GetOrganizationRunner ( ctx context . Context , owner string , runnerID int64 ) ( * Runner , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners/%v" , owner , runnerID )
req , err := s . client . NewRequest ( "GET" , u , nil )
if err != nil {
return nil , nil , err
}
runner := new ( Runner )
resp , err := s . client . Do ( ctx , req , runner )
if err != nil {
return nil , resp , err
}
return runner , resp , nil
}
// CreateOrganizationRemoveToken creates a token that can be used to remove a self-hosted runner from an organization.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#create-a-remove-token-for-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) CreateOrganizationRemoveToken ( ctx context . Context , owner string ) ( * RemoveToken , * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners/remove-token" , owner )
req , err := s . client . NewRequest ( "POST" , u , nil )
if err != nil {
return nil , nil , err
}
removeToken := new ( RemoveToken )
resp , err := s . client . Do ( ctx , req , removeToken )
if err != nil {
return nil , resp , err
}
return removeToken , resp , nil
}
// RemoveOrganizationRunner forces the removal of a self-hosted runner from an organization using the runner id.
//
2021-08-10 11:49:43 +02:00
// GitHub API docs: https://docs.github.com/en/free-pro-team@latest/rest/reference/actions/#delete-a-self-hosted-runner-from-an-organization
2020-07-31 16:22:34 +02:00
func ( s * ActionsService ) RemoveOrganizationRunner ( ctx context . Context , owner string , runnerID int64 ) ( * Response , error ) {
u := fmt . Sprintf ( "orgs/%v/actions/runners/%v" , owner , runnerID )
req , err := s . client . NewRequest ( "DELETE" , u , nil )
if err != nil {
return nil , err
}
return s . client . Do ( ctx , req , nil )
}