mirror of
				https://gitcode.com/gitea/gitea.git
				synced 2025-10-26 13:16:28 +08:00 
			
		
		
		
	 6b33152b7d
			
		
	
	6b33152b7d
	
	
	
		
			
			Replace #16455 Close #21803 Mixing different Gitea contexts together causes some problems: 1. Unable to respond proper content when error occurs, eg: Web should respond HTML while API should respond JSON 2. Unclear dependency, eg: it's unclear when Context is used in APIContext, which fields should be initialized, which methods are necessary. To make things clear, this PR introduces a Base context, it only provides basic Req/Resp/Data features. This PR mainly moves code. There are still many legacy problems and TODOs in code, leave unrelated changes to future PRs.
		
			
				
	
	
		
			33 lines
		
	
	
		
			934 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			934 B
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2023 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package context
 | |
| 
 | |
| import (
 | |
| 	"io"
 | |
| 	"net/http"
 | |
| 	"strings"
 | |
| )
 | |
| 
 | |
| // UploadStream returns the request body or the first form file
 | |
| // Only form files need to get closed.
 | |
| func (ctx *Context) UploadStream() (rd io.ReadCloser, needToClose bool, err error) {
 | |
| 	contentType := strings.ToLower(ctx.Req.Header.Get("Content-Type"))
 | |
| 	if strings.HasPrefix(contentType, "application/x-www-form-urlencoded") || strings.HasPrefix(contentType, "multipart/form-data") {
 | |
| 		if err := ctx.Req.ParseMultipartForm(32 << 20); err != nil {
 | |
| 			return nil, false, err
 | |
| 		}
 | |
| 		if ctx.Req.MultipartForm.File == nil {
 | |
| 			return nil, false, http.ErrMissingFile
 | |
| 		}
 | |
| 		for _, files := range ctx.Req.MultipartForm.File {
 | |
| 			if len(files) > 0 {
 | |
| 				r, err := files[0].Open()
 | |
| 				return r, true, err
 | |
| 			}
 | |
| 		}
 | |
| 		return nil, false, http.ErrMissingFile
 | |
| 	}
 | |
| 	return ctx.Req.Body, false, nil
 | |
| }
 |