mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-26 00:48:29 +00:00 
			
		
		
		
	Adds an API POST endpoint under `/repos/{owner}/{repo}/file-contents`
which receives a list of paths and returns a list of the contents of
these files.
This API endpoint will be helpful for applications like headless CMS
(reference: https://github.com/sveltia/sveltia-cms/issues/198) which
need to retrieve a large number of files by reducing the amount of
needed API calls.
Close #33495
---------
Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
		
	
		
			
				
	
	
		
			88 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright 2014 The Gogs Authors. All rights reserved.
 | |
| // Copyright 2019 The Gitea Authors. All rights reserved.
 | |
| // SPDX-License-Identifier: MIT
 | |
| 
 | |
| package git
 | |
| 
 | |
| import (
 | |
| 	"bytes"
 | |
| 	"io"
 | |
| 	"strings"
 | |
| )
 | |
| 
 | |
| // ObjectType git object type
 | |
| type ObjectType string
 | |
| 
 | |
| const (
 | |
| 	// ObjectCommit commit object type
 | |
| 	ObjectCommit ObjectType = "commit"
 | |
| 	// ObjectTree tree object type
 | |
| 	ObjectTree ObjectType = "tree"
 | |
| 	// ObjectBlob blob object type
 | |
| 	ObjectBlob ObjectType = "blob"
 | |
| 	// ObjectTag tag object type
 | |
| 	ObjectTag ObjectType = "tag"
 | |
| 	// ObjectBranch branch object type
 | |
| 	ObjectBranch ObjectType = "branch"
 | |
| )
 | |
| 
 | |
| // Bytes returns the byte array for the Object Type
 | |
| func (o ObjectType) Bytes() []byte {
 | |
| 	return []byte(o)
 | |
| }
 | |
| 
 | |
| type EmptyReader struct{}
 | |
| 
 | |
| func (EmptyReader) Read(p []byte) (int, error) {
 | |
| 	return 0, io.EOF
 | |
| }
 | |
| 
 | |
| func (repo *Repository) GetObjectFormat() (ObjectFormat, error) {
 | |
| 	if repo != nil && repo.objectFormat != nil {
 | |
| 		return repo.objectFormat, nil
 | |
| 	}
 | |
| 
 | |
| 	str, err := repo.hashObject(EmptyReader{}, false)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	hash, err := NewIDFromString(str)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 
 | |
| 	repo.objectFormat = hash.Type()
 | |
| 
 | |
| 	return repo.objectFormat, nil
 | |
| }
 | |
| 
 | |
| // HashObject takes a reader and returns hash for that reader
 | |
| func (repo *Repository) HashObject(reader io.Reader) (ObjectID, error) {
 | |
| 	idStr, err := repo.hashObject(reader, true)
 | |
| 	if err != nil {
 | |
| 		return nil, err
 | |
| 	}
 | |
| 	return NewIDFromString(idStr)
 | |
| }
 | |
| 
 | |
| func (repo *Repository) hashObject(reader io.Reader, save bool) (string, error) {
 | |
| 	var cmd *Command
 | |
| 	if save {
 | |
| 		cmd = NewCommand("hash-object", "-w", "--stdin")
 | |
| 	} else {
 | |
| 		cmd = NewCommand("hash-object", "--stdin")
 | |
| 	}
 | |
| 	stdout := new(bytes.Buffer)
 | |
| 	stderr := new(bytes.Buffer)
 | |
| 	err := cmd.Run(repo.Ctx, &RunOpts{
 | |
| 		Dir:    repo.Path,
 | |
| 		Stdin:  reader,
 | |
| 		Stdout: stdout,
 | |
| 		Stderr: stderr,
 | |
| 	})
 | |
| 	if err != nil {
 | |
| 		return "", err
 | |
| 	}
 | |
| 	return strings.TrimSpace(stdout.String()), nil
 | |
| }
 |