Require approval to run actions for fork pull request (#22803)
Currently, Gitea will run actions automatically which are triggered by fork pull request. It's a security risk, people can create a PR and modify the workflow yamls to execute a malicious script. So we should require approval for first-time contributors, which is the default strategy of a public repo on GitHub, see [Approving workflow runs from public forks](https://docs.github.com/en/actions/managing-workflow-runs/approving-workflow-runs-from-public-forks). Current strategy: - don't need approval if it's not a fork PR; - always need approval if the user is restricted; - don't need approval if the user can write; - don't need approval if the user has been approved before; - otherwise, need approval. https://user-images.githubusercontent.com/9418365/217207121-badf50a8-826c-4425-bef1-d82d1979bc81.mov GitHub has an option for that, you can see that at `/<owner>/<repo>/settings/actions`, and we can support that later. <img width="835" alt="image" src="https://user-images.githubusercontent.com/9418365/217199990-2967e68b-e693-4e59-8186-ab33a1314a16.png"> --------- Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com>
This commit is contained in:
		| @@ -68,6 +68,8 @@ type FindRunOptions struct { | ||||
| 	OwnerID          int64 | ||||
| 	IsClosed         util.OptionalBool | ||||
| 	WorkflowFileName string | ||||
| 	TriggerUserID    int64 | ||||
| 	Approved         bool // not util.OptionalBool, it works only when it's true | ||||
| } | ||||
|  | ||||
| func (opts FindRunOptions) toConds() builder.Cond { | ||||
| @@ -89,6 +91,12 @@ func (opts FindRunOptions) toConds() builder.Cond { | ||||
| 	if opts.WorkflowFileName != "" { | ||||
| 		cond = cond.And(builder.Eq{"workflow_id": opts.WorkflowFileName}) | ||||
| 	} | ||||
| 	if opts.TriggerUserID > 0 { | ||||
| 		cond = cond.And(builder.Eq{"trigger_user_id": opts.TriggerUserID}) | ||||
| 	} | ||||
| 	if opts.Approved { | ||||
| 		cond = cond.And(builder.Gt{"approved_by": 0}) | ||||
| 	} | ||||
| 	return cond | ||||
| } | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Jason Song
					Jason Song