mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 05:25:15 +01: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
 | 
						|
}
 |