mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Propagate context and ensure git commands run in request context (#17868)
This PR continues the work in #17125 by progressively ensuring that git commands run within the request context. This now means that the if there is a git repo already open in the context it will be used instead of reopening it. Signed-off-by: Andrew Thornton <art27@cantab.net>
This commit is contained in:
		| @@ -778,10 +778,10 @@ func Routes(sessioner func(http.Handler) http.Handler) *web.Route { | ||||
| 				m.Combo("/forks").Get(repo.ListForks). | ||||
| 					Post(reqToken(), reqRepoReader(unit.TypeCode), bind(api.CreateForkOption{}), repo.CreateFork) | ||||
| 				m.Group("/branches", func() { | ||||
| 					m.Get("", repo.ListBranches) | ||||
| 					m.Get("/*", repo.GetBranch) | ||||
| 					m.Delete("/*", context.ReferencesGitRepo(false), reqRepoWriter(unit.TypeCode), repo.DeleteBranch) | ||||
| 					m.Post("", reqRepoWriter(unit.TypeCode), bind(api.CreateBranchRepoOption{}), repo.CreateBranch) | ||||
| 					m.Get("", context.ReferencesGitRepo(false), repo.ListBranches) | ||||
| 					m.Get("/*", context.ReferencesGitRepo(false), repo.GetBranch) | ||||
| 					m.Delete("/*", reqRepoWriter(unit.TypeCode), context.ReferencesGitRepo(false), repo.DeleteBranch) | ||||
| 					m.Post("", reqRepoWriter(unit.TypeCode), context.ReferencesGitRepo(false), bind(api.CreateBranchRepoOption{}), repo.CreateBranch) | ||||
| 				}, reqRepoReader(unit.TypeCode)) | ||||
| 				m.Group("/branch_protections", func() { | ||||
| 					m.Get("", repo.ListBranchProtections) | ||||
| @@ -957,7 +957,7 @@ func Routes(sessioner func(http.Handler) http.Handler) *web.Route { | ||||
| 						Post(reqToken(), bind(api.CreateStatusOption{}), repo.NewCommitStatus) | ||||
| 				}, reqRepoReader(unit.TypeCode)) | ||||
| 				m.Group("/commits", func() { | ||||
| 					m.Get("", repo.GetAllCommits) | ||||
| 					m.Get("", context.ReferencesGitRepo(false), repo.GetAllCommits) | ||||
| 					m.Group("/{ref}", func() { | ||||
| 						m.Get("/status", repo.GetCombinedCommitStatusByRef) | ||||
| 						m.Get("/statuses", repo.GetCommitStatusesByRef) | ||||
| @@ -965,7 +965,7 @@ func Routes(sessioner func(http.Handler) http.Handler) *web.Route { | ||||
| 				}, reqRepoReader(unit.TypeCode)) | ||||
| 				m.Group("/git", func() { | ||||
| 					m.Group("/commits", func() { | ||||
| 						m.Get("/{sha}", repo.GetSingleCommit) | ||||
| 						m.Get("/{sha}", context.ReferencesGitRepo(false), repo.GetSingleCommit) | ||||
| 						m.Get("/{sha}.{diffType:diff|patch}", repo.DownloadCommitDiffOrPatch) | ||||
| 					}) | ||||
| 					m.Get("/refs", repo.GetGitAllRefs) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user