mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 17:08:25 +00:00 
			
		
		
		
	Rewrite of the LFS server (#15523)
* Restructured code. Moved static checks out of loop. * Restructured batch api. Add support for individual errors. * Let router decide if LFS is enabled. * Renamed methods. * Return correct status from verify handler. * Unified media type check in router. * Changed error code according to spec. * Moved checks into router. * Removed invalid v1 api methods. * Unified methods. * Display better error messages. * Added size parameter. Create meta object on upload. * Use object error on invalid size. * Skip upload if object exists. * Moved methods. * Suppress fields in response. * Changed error on accept. * Added tests. * Use ErrorResponse object. * Test against message property. * Add support for the old invalid lfs client. * Fixed the check because MinIO wraps the error. * Use individual repositories. Co-authored-by: 6543 <6543@obermui.de> Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		| @@ -19,21 +19,6 @@ import ( | ||||
| 	jsoniter "github.com/json-iterator/go" | ||||
| ) | ||||
|  | ||||
| //checkIsValidRequest check if it a valid request in case of bad request it write the response to ctx. | ||||
| func checkIsValidRequest(ctx *context.Context) bool { | ||||
| 	if !setting.LFS.StartServer { | ||||
| 		log.Debug("Attempt to access LFS server but LFS server is disabled") | ||||
| 		writeStatus(ctx, http.StatusNotFound) | ||||
| 		return false | ||||
| 	} | ||||
| 	if !MetaMatcher(ctx.Req) { | ||||
| 		log.Info("Attempt access LOCKs without accepting the correct media type: %s", lfs_module.MediaType) | ||||
| 		writeStatus(ctx, http.StatusBadRequest) | ||||
| 		return false | ||||
| 	} | ||||
| 	return true | ||||
| } | ||||
|  | ||||
| func handleLockListOut(ctx *context.Context, repo *models.Repository, lock *models.LFSLock, err error) { | ||||
| 	if err != nil { | ||||
| 		if models.IsErrLFSLockNotExist(err) { | ||||
| @@ -60,12 +45,7 @@ func handleLockListOut(ctx *context.Context, repo *models.Repository, lock *mode | ||||
|  | ||||
| // GetListLockHandler list locks | ||||
| func GetListLockHandler(ctx *context.Context) { | ||||
| 	if !checkIsValidRequest(ctx) { | ||||
| 		// Status is written in checkIsValidRequest | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	rv, _ := unpack(ctx) | ||||
| 	rv := getRequestContext(ctx) | ||||
|  | ||||
| 	repository, err := models.GetRepositoryByOwnerAndName(rv.User, rv.Repo) | ||||
| 	if err != nil { | ||||
| @@ -150,11 +130,6 @@ func GetListLockHandler(ctx *context.Context) { | ||||
|  | ||||
| // PostLockHandler create lock | ||||
| func PostLockHandler(ctx *context.Context) { | ||||
| 	if !checkIsValidRequest(ctx) { | ||||
| 		// Status is written in checkIsValidRequest | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	userName := ctx.Params("username") | ||||
| 	repoName := strings.TrimSuffix(ctx.Params("reponame"), ".git") | ||||
| 	authorization := ctx.Req.Header.Get("Authorization") | ||||
| @@ -223,11 +198,6 @@ func PostLockHandler(ctx *context.Context) { | ||||
|  | ||||
| // VerifyLockHandler list locks for verification | ||||
| func VerifyLockHandler(ctx *context.Context) { | ||||
| 	if !checkIsValidRequest(ctx) { | ||||
| 		// Status is written in checkIsValidRequest | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	userName := ctx.Params("username") | ||||
| 	repoName := strings.TrimSuffix(ctx.Params("reponame"), ".git") | ||||
| 	authorization := ctx.Req.Header.Get("Authorization") | ||||
| @@ -294,11 +264,6 @@ func VerifyLockHandler(ctx *context.Context) { | ||||
|  | ||||
| // UnLockHandler delete locks | ||||
| func UnLockHandler(ctx *context.Context) { | ||||
| 	if !checkIsValidRequest(ctx) { | ||||
| 		// Status is written in checkIsValidRequest | ||||
| 		return | ||||
| 	} | ||||
|  | ||||
| 	userName := ctx.Params("username") | ||||
| 	repoName := strings.TrimSuffix(ctx.Params("reponame"), ".git") | ||||
| 	authorization := ctx.Req.Header.Get("Authorization") | ||||
|   | ||||
		Reference in New Issue
	
	Block a user