mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 13:34:43 +01:00 
			
		
		
		
	Before: the concept "Content string" is used everywhere. It has some problems: 1. Sometimes it means "base64 encoded content", sometimes it means "raw binary content" 2. It doesn't work with large files, eg: uploading a 1G LFS file would make Gitea process OOM This PR does the refactoring: use "ContentReader" / "ContentBase64" instead of "Content" This PR is not breaking because the key in API JSON is still "content": `` ContentBase64 string `json:"content"` ``
		
			
				
	
	
		
			35 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2019 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package integration
 | 
						|
 | 
						|
import (
 | 
						|
	"strings"
 | 
						|
 | 
						|
	repo_model "code.gitea.io/gitea/models/repo"
 | 
						|
	user_model "code.gitea.io/gitea/models/user"
 | 
						|
	"code.gitea.io/gitea/modules/git"
 | 
						|
	api "code.gitea.io/gitea/modules/structs"
 | 
						|
	files_service "code.gitea.io/gitea/services/repository/files"
 | 
						|
)
 | 
						|
 | 
						|
func createFileInBranch(user *user_model.User, repo *repo_model.Repository, treePath, branchName, content string) (*api.FilesResponse, error) {
 | 
						|
	opts := &files_service.ChangeRepoFilesOptions{
 | 
						|
		Files: []*files_service.ChangeRepoFile{
 | 
						|
			{
 | 
						|
				Operation:     "create",
 | 
						|
				TreePath:      treePath,
 | 
						|
				ContentReader: strings.NewReader(content),
 | 
						|
			},
 | 
						|
		},
 | 
						|
		OldBranch: branchName,
 | 
						|
		Author:    nil,
 | 
						|
		Committer: nil,
 | 
						|
	}
 | 
						|
	return files_service.ChangeRepoFiles(git.DefaultContext, repo, user, opts)
 | 
						|
}
 | 
						|
 | 
						|
func createFile(user *user_model.User, repo *repo_model.Repository, treePath string) (*api.FilesResponse, error) {
 | 
						|
	return createFileInBranch(user, repo, treePath, repo.DefaultBranch, "This is a NEW file")
 | 
						|
}
 |