mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 08:58:24 +00:00 
			
		
		
		
	Implements runner apis based on https://docs.github.com/en/rest/actions/self-hosted-runners?apiVersion=2022-11-28#list-self-hosted-runners-for-an-organization - Add Post endpoints for registration-token, google/go-github revealed this as problem - We should deprecate Get Endpoints, leaving them for compatibility - Get endpoint of admin has api path /admin/runners/registration-token that feels wrong, /admin/actions/runners/registration-token seems more consistent with user/org/repo api - Get Runner Api - List Runner Api - Delete Runner Api - Tests admin / user / org / repo level endpoints Related to #33750 (implements point 1 and 2) Via needs discovered in #32461, this runner api is needed to allow cleanup of runners that are deallocated without user interaction. --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			159 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			5.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package structs
 | |
| 
 | |
| import (
 | |
| 	"time"
 | |
| )
 | |
| 
 | |
| // ActionTask represents a ActionTask
 | |
| type ActionTask struct {
 | |
| 	ID           int64  `json:"id"`
 | |
| 	Name         string `json:"name"`
 | |
| 	HeadBranch   string `json:"head_branch"`
 | |
| 	HeadSHA      string `json:"head_sha"`
 | |
| 	RunNumber    int64  `json:"run_number"`
 | |
| 	Event        string `json:"event"`
 | |
| 	DisplayTitle string `json:"display_title"`
 | |
| 	Status       string `json:"status"`
 | |
| 	WorkflowID   string `json:"workflow_id"`
 | |
| 	URL          string `json:"url"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	CreatedAt time.Time `json:"created_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	UpdatedAt time.Time `json:"updated_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	RunStartedAt time.Time `json:"run_started_at"`
 | |
| }
 | |
| 
 | |
| // ActionTaskResponse returns a ActionTask
 | |
| type ActionTaskResponse struct {
 | |
| 	Entries    []*ActionTask `json:"workflow_runs"`
 | |
| 	TotalCount int64         `json:"total_count"`
 | |
| }
 | |
| 
 | |
| // CreateActionWorkflowDispatch represents the payload for triggering a workflow dispatch event
 | |
| // swagger:model
 | |
| type CreateActionWorkflowDispatch struct {
 | |
| 	// required: true
 | |
| 	// example: refs/heads/main
 | |
| 	Ref string `json:"ref" binding:"Required"`
 | |
| 	// required: false
 | |
| 	Inputs map[string]string `json:"inputs,omitempty"`
 | |
| }
 | |
| 
 | |
| // ActionWorkflow represents a ActionWorkflow
 | |
| type ActionWorkflow struct {
 | |
| 	ID    string `json:"id"`
 | |
| 	Name  string `json:"name"`
 | |
| 	Path  string `json:"path"`
 | |
| 	State string `json:"state"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	CreatedAt time.Time `json:"created_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	UpdatedAt time.Time `json:"updated_at"`
 | |
| 	URL       string    `json:"url"`
 | |
| 	HTMLURL   string    `json:"html_url"`
 | |
| 	BadgeURL  string    `json:"badge_url"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	DeletedAt time.Time `json:"deleted_at,omitempty"`
 | |
| }
 | |
| 
 | |
| // ActionWorkflowResponse returns a ActionWorkflow
 | |
| type ActionWorkflowResponse struct {
 | |
| 	Workflows  []*ActionWorkflow `json:"workflows"`
 | |
| 	TotalCount int64             `json:"total_count"`
 | |
| }
 | |
| 
 | |
| // ActionArtifact represents a ActionArtifact
 | |
| type ActionArtifact struct {
 | |
| 	ID                 int64              `json:"id"`
 | |
| 	Name               string             `json:"name"`
 | |
| 	SizeInBytes        int64              `json:"size_in_bytes"`
 | |
| 	URL                string             `json:"url"`
 | |
| 	ArchiveDownloadURL string             `json:"archive_download_url"`
 | |
| 	Expired            bool               `json:"expired"`
 | |
| 	WorkflowRun        *ActionWorkflowRun `json:"workflow_run"`
 | |
| 
 | |
| 	// swagger:strfmt date-time
 | |
| 	CreatedAt time.Time `json:"created_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	UpdatedAt time.Time `json:"updated_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	ExpiresAt time.Time `json:"expires_at"`
 | |
| }
 | |
| 
 | |
| // ActionWorkflowRun represents a WorkflowRun
 | |
| type ActionWorkflowRun struct {
 | |
| 	ID           int64  `json:"id"`
 | |
| 	RepositoryID int64  `json:"repository_id"`
 | |
| 	HeadSha      string `json:"head_sha"`
 | |
| }
 | |
| 
 | |
| // ActionArtifactsResponse returns ActionArtifacts
 | |
| type ActionArtifactsResponse struct {
 | |
| 	Entries    []*ActionArtifact `json:"artifacts"`
 | |
| 	TotalCount int64             `json:"total_count"`
 | |
| }
 | |
| 
 | |
| // ActionWorkflowStep represents a step of a WorkflowJob
 | |
| type ActionWorkflowStep struct {
 | |
| 	Name       string `json:"name"`
 | |
| 	Number     int64  `json:"number"`
 | |
| 	Status     string `json:"status"`
 | |
| 	Conclusion string `json:"conclusion,omitempty"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	StartedAt time.Time `json:"started_at,omitempty"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	CompletedAt time.Time `json:"completed_at,omitempty"`
 | |
| }
 | |
| 
 | |
| // ActionWorkflowJob represents a WorkflowJob
 | |
| type ActionWorkflowJob struct {
 | |
| 	ID         int64                 `json:"id"`
 | |
| 	URL        string                `json:"url"`
 | |
| 	HTMLURL    string                `json:"html_url"`
 | |
| 	RunID      int64                 `json:"run_id"`
 | |
| 	RunURL     string                `json:"run_url"`
 | |
| 	Name       string                `json:"name"`
 | |
| 	Labels     []string              `json:"labels"`
 | |
| 	RunAttempt int64                 `json:"run_attempt"`
 | |
| 	HeadSha    string                `json:"head_sha"`
 | |
| 	HeadBranch string                `json:"head_branch,omitempty"`
 | |
| 	Status     string                `json:"status"`
 | |
| 	Conclusion string                `json:"conclusion,omitempty"`
 | |
| 	RunnerID   int64                 `json:"runner_id,omitempty"`
 | |
| 	RunnerName string                `json:"runner_name,omitempty"`
 | |
| 	Steps      []*ActionWorkflowStep `json:"steps"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	CreatedAt time.Time `json:"created_at"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	StartedAt time.Time `json:"started_at,omitempty"`
 | |
| 	// swagger:strfmt date-time
 | |
| 	CompletedAt time.Time `json:"completed_at,omitempty"`
 | |
| }
 | |
| 
 | |
| // ActionRunnerLabel represents a Runner Label
 | |
| type ActionRunnerLabel struct {
 | |
| 	ID   int64  `json:"id"`
 | |
| 	Name string `json:"name"`
 | |
| 	Type string `json:"type"`
 | |
| }
 | |
| 
 | |
| // ActionRunner represents a Runner
 | |
| type ActionRunner struct {
 | |
| 	ID        int64                `json:"id"`
 | |
| 	Name      string               `json:"name"`
 | |
| 	Status    string               `json:"status"`
 | |
| 	Busy      bool                 `json:"busy"`
 | |
| 	Ephemeral bool                 `json:"ephemeral"`
 | |
| 	Labels    []*ActionRunnerLabel `json:"labels"`
 | |
| }
 | |
| 
 | |
| // ActionRunnersResponse returns Runners
 | |
| type ActionRunnersResponse struct {
 | |
| 	Entries    []*ActionRunner `json:"runners"`
 | |
| 	TotalCount int64           `json:"total_count"`
 | |
| }
 |