mirror of
				https://github.com/go-gitea/gitea
				synced 2025-11-03 21:08:25 +00:00 
			
		
		
		
	Implements - https://docs.github.com/en/rest/actions/workflow-jobs?apiVersion=2022-11-28#list-jobs-for-a-workflow-run--code-samples - https://docs.github.com/en/rest/actions/workflow-jobs?apiVersion=2022-11-28#get-a-job-for-a-workflow-run--code-samples - https://docs.github.com/en/rest/actions/workflow-runs?apiVersion=2022-11-28#list-workflow-runs-for-a-repository - https://docs.github.com/en/rest/actions/workflow-runs?apiVersion=2022-11-28#get-a-workflow-run - `/actions/runs` for global + user + org (Gitea only) - `/actions/jobs` for global + user + org + repository (Gitea only) - workflow_run webhook + action trigger - limitations - workflow id is assigned to a string, this may result into problems in strongly typed clients Fixes - workflow_job webhook url to no longer contain the `runs/<run>` part to align with api - workflow instance does now use it's name inside the file instead of filename if set Refactoring - Moved a lot of logic from workflows/workflow_job into a shared module used by both webhook and api TODO - [x] Verify Keda Compatibility - [x] Edit Webhook API bug is resolved Closes https://github.com/go-gitea/gitea/issues/23670 Closes https://github.com/go-gitea/gitea/issues/23796 Closes https://github.com/go-gitea/gitea/issues/24898 Replaces https://github.com/go-gitea/gitea/pull/28047 and is much more complete --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
			
				
	
	
		
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			80 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2024 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package context
 | 
						|
 | 
						|
import (
 | 
						|
	"strconv"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	"code.gitea.io/gitea/modules/optional"
 | 
						|
	"code.gitea.io/gitea/modules/util"
 | 
						|
)
 | 
						|
 | 
						|
// FormString returns the first value matching the provided key in the form as a string
 | 
						|
// It works the same as http.Request.FormValue:
 | 
						|
// try urlencoded request body first, then query string, then multipart form body
 | 
						|
func (b *Base) FormString(key string, def ...string) string {
 | 
						|
	s := b.Req.FormValue(key)
 | 
						|
	if s == "" {
 | 
						|
		s = util.OptionalArg(def)
 | 
						|
	}
 | 
						|
	return s
 | 
						|
}
 | 
						|
 | 
						|
// FormStrings returns a values for the key in the form (including query parameters), similar to FormString
 | 
						|
func (b *Base) FormStrings(key string) []string {
 | 
						|
	if b.Req.Form == nil {
 | 
						|
		if err := b.Req.ParseMultipartForm(32 << 20); err != nil {
 | 
						|
			return nil
 | 
						|
		}
 | 
						|
	}
 | 
						|
	if v, ok := b.Req.Form[key]; ok {
 | 
						|
		return v
 | 
						|
	}
 | 
						|
	return nil
 | 
						|
}
 | 
						|
 | 
						|
// FormTrim returns the first value for the provided key in the form as a space trimmed string
 | 
						|
func (b *Base) FormTrim(key string) string {
 | 
						|
	return strings.TrimSpace(b.Req.FormValue(key))
 | 
						|
}
 | 
						|
 | 
						|
// FormInt returns the first value for the provided key in the form as an int
 | 
						|
func (b *Base) FormInt(key string) int {
 | 
						|
	v, _ := strconv.Atoi(b.Req.FormValue(key))
 | 
						|
	return v
 | 
						|
}
 | 
						|
 | 
						|
// FormInt64 returns the first value for the provided key in the form as an int64
 | 
						|
func (b *Base) FormInt64(key string) int64 {
 | 
						|
	v, _ := strconv.ParseInt(b.Req.FormValue(key), 10, 64)
 | 
						|
	return v
 | 
						|
}
 | 
						|
 | 
						|
// FormBool returns true if the value for the provided key in the form is "1", "true" or "on"
 | 
						|
func (b *Base) FormBool(key string) bool {
 | 
						|
	s := b.Req.FormValue(key)
 | 
						|
	v, _ := strconv.ParseBool(s)
 | 
						|
	v = v || strings.EqualFold(s, "on")
 | 
						|
	return v
 | 
						|
}
 | 
						|
 | 
						|
// FormOptionalBool returns an optional.Some(true) or optional.Some(false) if the value
 | 
						|
// for the provided key exists in the form else it returns optional.None[bool]()
 | 
						|
func (b *Base) FormOptionalBool(key string) optional.Option[bool] {
 | 
						|
	value := b.Req.FormValue(key)
 | 
						|
	if len(value) == 0 {
 | 
						|
		return optional.None[bool]()
 | 
						|
	}
 | 
						|
	s := b.Req.FormValue(key)
 | 
						|
	v, _ := strconv.ParseBool(s)
 | 
						|
	v = v || strings.EqualFold(s, "on")
 | 
						|
	return optional.Some(v)
 | 
						|
}
 | 
						|
 | 
						|
func (b *Base) SetFormString(key, value string) {
 | 
						|
	_ = b.Req.FormValue(key) // force parse form
 | 
						|
	b.Req.Form.Set(key, value)
 | 
						|
}
 |