mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09:00 
			
		
		
		
	Uniform all temporary directories and allow customizing temp path (#32352)
This PR uniform all temporary directory usage so that it will be easier to manage. Relate to #31792 - [x] Added a new setting to allow users to configure the global temporary directory. - [x] Move all temporary files and directories to be placed under os.Temp()/gitea. - [x] `setting.Repository.Local.LocalCopyPath` now will be `setting.TempPath/local-repo` and the customized path is removed. ```diff -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;[repository.local] -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; -;; -;; Path for local repository copy. Defaults to TEMP_PATH + `local-repo`, this is deprecated and cannot be changed -;LOCAL_COPY_PATH = local-repo ``` - [x] `setting.Repository.Upload.TempPath` now will be `settting.TempPath/uploads` and the customized path is removed. ```diff ;[repository.upload] -;; -;; Path for uploads. Defaults to TEMP_PATH + `uploads` -;TEMP_PATH = uploads ``` - [x] `setting.Packages.ChunkedUploadPath` now will be `settting.TempPath/package-upload` and the customized path is removed. ```diff ;[packages] -;; -;; Path for chunked uploads. Defaults it's `package-upload` under `TEMP_PATH` unless it's an absolute path. -;CHUNKED_UPLOAD_PATH = package-upload ``` - [x] `setting.SSH.KeyTestPath` now will be `settting.TempPath/ssh_key_test` and the customized path is removed. ```diff [server] -;; -;; Directory to create temporary files in when testing public keys using ssh-keygen, -;; default is the system temporary directory. -;SSH_KEY_TEST_PATH = ``` TODO: - [ ] setting.PprofDataPath haven't been changed because it may need to be kept until somebody read it but temp path may be clean up any time. --------- Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
This commit is contained in:
		| @@ -7,16 +7,10 @@ import ( | ||||
| 	"bytes" | ||||
| 	"errors" | ||||
| 	"io" | ||||
| 	"math" | ||||
| 	"os" | ||||
| ) | ||||
|  | ||||
| var ( | ||||
| 	// ErrInvalidMemorySize occurs if the memory size is not in a valid range | ||||
| 	ErrInvalidMemorySize = errors.New("Memory size must be greater 0 and lower math.MaxInt32") | ||||
| 	// ErrWriteAfterRead occurs if Write is called after a read operation | ||||
| 	ErrWriteAfterRead = errors.New("Write is unsupported after a read operation") | ||||
| ) | ||||
| var ErrWriteAfterRead = errors.New("write is unsupported after a read operation") // occurs if Write is called after a read operation | ||||
|  | ||||
| type readAtSeeker interface { | ||||
| 	io.ReadSeeker | ||||
| @@ -30,34 +24,17 @@ type FileBackedBuffer struct { | ||||
| 	maxMemorySize int64 | ||||
| 	size          int64 | ||||
| 	buffer        bytes.Buffer | ||||
| 	tempDir       string | ||||
| 	file          *os.File | ||||
| 	reader        readAtSeeker | ||||
| } | ||||
|  | ||||
| // New creates a file backed buffer with a specific maximum memory size | ||||
| func New(maxMemorySize int) (*FileBackedBuffer, error) { | ||||
| 	if maxMemorySize < 0 || maxMemorySize > math.MaxInt32 { | ||||
| 		return nil, ErrInvalidMemorySize | ||||
| 	} | ||||
|  | ||||
| func New(maxMemorySize int, tempDir string) *FileBackedBuffer { | ||||
| 	return &FileBackedBuffer{ | ||||
| 		maxMemorySize: int64(maxMemorySize), | ||||
| 	}, nil | ||||
| } | ||||
|  | ||||
| // CreateFromReader creates a file backed buffer and copies the provided reader data into it. | ||||
| func CreateFromReader(r io.Reader, maxMemorySize int) (*FileBackedBuffer, error) { | ||||
| 	b, err := New(maxMemorySize) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 		tempDir:       tempDir, | ||||
| 	} | ||||
|  | ||||
| 	_, err = io.Copy(b, r) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	return b, nil | ||||
| } | ||||
|  | ||||
| // Write implements io.Writer | ||||
| @@ -73,7 +50,7 @@ func (b *FileBackedBuffer) Write(p []byte) (int, error) { | ||||
| 		n, err = b.file.Write(p) | ||||
| 	} else { | ||||
| 		if b.size+int64(len(p)) > b.maxMemorySize { | ||||
| 			b.file, err = os.CreateTemp("", "gitea-buffer-") | ||||
| 			b.file, err = os.CreateTemp(b.tempDir, "gitea-buffer-") | ||||
| 			if err != nil { | ||||
| 				return 0, err | ||||
| 			} | ||||
| @@ -148,7 +125,7 @@ func (b *FileBackedBuffer) Seek(offset int64, whence int) (int64, error) { | ||||
| func (b *FileBackedBuffer) Close() error { | ||||
| 	if b.file != nil { | ||||
| 		err := b.file.Close() | ||||
| 		os.Remove(b.file.Name()) | ||||
| 		_ = os.Remove(b.file.Name()) | ||||
| 		b.file = nil | ||||
| 		return err | ||||
| 	} | ||||
|   | ||||
| @@ -21,7 +21,8 @@ func TestFileBackedBuffer(t *testing.T) { | ||||
| 	} | ||||
|  | ||||
| 	for _, c := range cases { | ||||
| 		buf, err := CreateFromReader(strings.NewReader(c.Data), c.MaxMemorySize) | ||||
| 		buf := New(c.MaxMemorySize, t.TempDir()) | ||||
| 		_, err := io.Copy(buf, strings.NewReader(c.Data)) | ||||
| 		assert.NoError(t, err) | ||||
|  | ||||
| 		assert.EqualValues(t, len(c.Data), buf.Size()) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user