mirror of
https://github.com/bapung/gitea-runner-operator.git
synced 2026-06-22 07:58:44 +00:00
add filters
This commit is contained in:
10
config/manager/image_pull_secret_patch.yaml
Normal file
10
config/manager/image_pull_secret_patch.yaml
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
apiVersion: apps/v1
|
||||||
|
kind: Deployment
|
||||||
|
metadata:
|
||||||
|
name: controller-manager
|
||||||
|
namespace: system
|
||||||
|
spec:
|
||||||
|
template:
|
||||||
|
spec:
|
||||||
|
imagePullSecrets:
|
||||||
|
- name: ghcr-secret
|
||||||
@@ -1,2 +1,11 @@
|
|||||||
resources:
|
resources:
|
||||||
- manager.yaml
|
- manager.yaml
|
||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
images:
|
||||||
|
- name: controller
|
||||||
|
newName: ghcr.io/bapung/gitea-runner-operator
|
||||||
|
newTag: sha-b638d72
|
||||||
|
|
||||||
|
patchesStrategicMerge:
|
||||||
|
- image_pull_secret_patch.yaml
|
||||||
|
|||||||
@@ -10,6 +10,6 @@ roleRef:
|
|||||||
kind: ClusterRole
|
kind: ClusterRole
|
||||||
name: manager-role
|
name: manager-role
|
||||||
subjects:
|
subjects:
|
||||||
- kind: ServiceAccount
|
- kind: ServiceAccount
|
||||||
name: controller-manager
|
name: controller-manager
|
||||||
namespace: system
|
namespace: gitea-runner-operator-system
|
||||||
|
|||||||
@@ -1,3 +1,16 @@
|
|||||||
|
apiVersion: v1
|
||||||
|
kind: Secret
|
||||||
|
metadata:
|
||||||
|
name: gitea-credentials
|
||||||
|
labels:
|
||||||
|
app.kubernetes.io/name: gitea-runner-operator
|
||||||
|
app.kubernetes.io/managed-by: kustomize
|
||||||
|
stringData:
|
||||||
|
# The Gitea API Token (for the Operator to poll for jobs)
|
||||||
|
auth-token: "3430680995113a33a17715bb552882d504f5cf98"
|
||||||
|
# The Runner Registration Token (for the Runner to register itself)
|
||||||
|
registration-token: "5r4lpLA9rKCZZEHyUyKHeA187DoaElcTBySITRRi"
|
||||||
|
---
|
||||||
apiVersion: gitea.bpg.pw/v1alpha1
|
apiVersion: gitea.bpg.pw/v1alpha1
|
||||||
kind: RunnerGroup
|
kind: RunnerGroup
|
||||||
metadata:
|
metadata:
|
||||||
@@ -6,4 +19,28 @@ metadata:
|
|||||||
app.kubernetes.io/managed-by: kustomize
|
app.kubernetes.io/managed-by: kustomize
|
||||||
name: runnergroup-sample
|
name: runnergroup-sample
|
||||||
spec:
|
spec:
|
||||||
# TODO(user): Add fields here
|
# The base URL of your Gitea instance
|
||||||
|
giteaURL: "https://gitea.bpg.pw"
|
||||||
|
|
||||||
|
# Scope of the runners (global, org, or repo)
|
||||||
|
scope: "repo"
|
||||||
|
org: "bapung" # Required if scope is 'org' or 'repo'
|
||||||
|
repo: "dummy-service-workflow" # Required if scope is 'repo'
|
||||||
|
|
||||||
|
# Labels to identify this runner group
|
||||||
|
labels:
|
||||||
|
- "linux"
|
||||||
|
- "amd64"
|
||||||
|
|
||||||
|
# Maximum number of runners to spawn concurrently
|
||||||
|
maxActiveRunners: 5
|
||||||
|
|
||||||
|
# Reference to the Secret containing the API token
|
||||||
|
authToken:
|
||||||
|
name: gitea-credentials
|
||||||
|
key: auth-token
|
||||||
|
|
||||||
|
# Reference to the Secret containing the Registration token
|
||||||
|
registrationToken:
|
||||||
|
name: gitea-credentials
|
||||||
|
key: registration-token
|
||||||
|
|||||||
@@ -153,56 +153,60 @@ func (c *HTTPClient) getQueuedRunsGlobal(ctx context.Context, giteaURL, authToke
|
|||||||
// fetchWorkflowJobs fetches workflow jobs from a given endpoint with label filtering and pagination
|
// fetchWorkflowJobs fetches workflow jobs from a given endpoint with label filtering and pagination
|
||||||
func (c *HTTPClient) fetchWorkflowJobs(ctx context.Context, endpoint, authToken string, labels []string) (int, error) {
|
func (c *HTTPClient) fetchWorkflowJobs(ctx context.Context, endpoint, authToken string, labels []string) (int, error) {
|
||||||
totalCount := 0
|
totalCount := 0
|
||||||
page := 1
|
statuses := []string{"queued", "waiting", "pending"}
|
||||||
limit := 50 // Default page size
|
|
||||||
|
|
||||||
for {
|
for _, status := range statuses {
|
||||||
u, err := url.Parse(endpoint)
|
page := 1
|
||||||
if err != nil {
|
limit := 50 // Default page size
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
q := u.Query()
|
|
||||||
q.Set("status", "queued")
|
|
||||||
q.Set("page", fmt.Sprintf("%d", page))
|
|
||||||
q.Set("limit", fmt.Sprintf("%d", limit))
|
|
||||||
u.RawQuery = q.Encode()
|
|
||||||
|
|
||||||
req, err := http.NewRequestWithContext(ctx, "GET", u.String(), nil)
|
for {
|
||||||
if err != nil {
|
u, err := url.Parse(endpoint)
|
||||||
return 0, err
|
if err != nil {
|
||||||
}
|
return 0, err
|
||||||
|
}
|
||||||
|
q := u.Query()
|
||||||
|
q.Set("status", status)
|
||||||
|
q.Set("page", fmt.Sprintf("%d", page))
|
||||||
|
q.Set("limit", fmt.Sprintf("%d", limit))
|
||||||
|
u.RawQuery = q.Encode()
|
||||||
|
|
||||||
req.Header.Set("Authorization", "token "+authToken)
|
req, err := http.NewRequestWithContext(ctx, "GET", u.String(), nil)
|
||||||
req.Header.Set("Accept", "application/json")
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
resp, err := c.httpClient.Do(req)
|
req.Header.Set("Authorization", "token "+authToken)
|
||||||
if err != nil {
|
req.Header.Set("Accept", "application/json")
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
if resp.StatusCode != http.StatusOK {
|
resp, err := c.httpClient.Do(req)
|
||||||
body, _ := io.ReadAll(resp.Body)
|
if err != nil {
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
if resp.StatusCode != http.StatusOK {
|
||||||
|
body, _ := io.ReadAll(resp.Body)
|
||||||
|
resp.Body.Close()
|
||||||
|
return 0, c.handleHTTPError(resp.StatusCode, body, "fetch workflow jobs")
|
||||||
|
}
|
||||||
|
|
||||||
|
var result ActionWorkflowJobsResponse
|
||||||
|
if err := json.NewDecoder(resp.Body).Decode(&result); err != nil {
|
||||||
|
resp.Body.Close()
|
||||||
|
return 0, err
|
||||||
|
}
|
||||||
resp.Body.Close()
|
resp.Body.Close()
|
||||||
return 0, c.handleHTTPError(resp.StatusCode, body, "fetch workflow jobs")
|
|
||||||
|
// Filter and count matching jobs for this page
|
||||||
|
pageCount := c.filterQueuedJobs(result.Jobs, labels)
|
||||||
|
totalCount += pageCount
|
||||||
|
|
||||||
|
// Break if we've fetched all available results
|
||||||
|
if len(result.Jobs) < limit {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
|
||||||
|
page++
|
||||||
}
|
}
|
||||||
|
|
||||||
var result ActionWorkflowJobsResponse
|
|
||||||
if err := json.NewDecoder(resp.Body).Decode(&result); err != nil {
|
|
||||||
resp.Body.Close()
|
|
||||||
return 0, err
|
|
||||||
}
|
|
||||||
resp.Body.Close()
|
|
||||||
|
|
||||||
// Filter and count matching jobs for this page
|
|
||||||
pageCount := c.filterQueuedJobs(result.Jobs, labels)
|
|
||||||
totalCount += pageCount
|
|
||||||
|
|
||||||
// Break if we've fetched all available results
|
|
||||||
if len(result.Jobs) < limit {
|
|
||||||
break
|
|
||||||
}
|
|
||||||
|
|
||||||
page++
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return totalCount, nil
|
return totalCount, nil
|
||||||
|
|||||||
Reference in New Issue
Block a user