mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-04 04:14:01 +01:00 
			
		
		
		
	Fixes a resource leak introduced by #27069. - add defer - move sign code out of `repository.go`
		
			
				
	
	
		
			40 lines
		
	
	
		
			956 B
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			956 B
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright 2024 The Gitea Authors. All rights reserved.
 | 
						|
// SPDX-License-Identifier: MIT
 | 
						|
 | 
						|
package rpm
 | 
						|
 | 
						|
import (
 | 
						|
	"bytes"
 | 
						|
	"io"
 | 
						|
	"strings"
 | 
						|
 | 
						|
	packages_module "code.gitea.io/gitea/modules/packages"
 | 
						|
 | 
						|
	"github.com/ProtonMail/go-crypto/openpgp"
 | 
						|
	"github.com/sassoftware/go-rpmutils"
 | 
						|
)
 | 
						|
 | 
						|
func SignPackage(buf *packages_module.HashedBuffer, privateKey string) (*packages_module.HashedBuffer, error) {
 | 
						|
	keyring, err := openpgp.ReadArmoredKeyRing(strings.NewReader(privateKey))
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	h, err := rpmutils.SignRpmStream(buf, keyring[0].PrivateKey, nil)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	signBlob, err := h.DumpSignatureHeader(false)
 | 
						|
	if err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	if _, err := buf.Seek(int64(h.OriginalSignatureHeaderSize()), io.SeekStart); err != nil {
 | 
						|
		return nil, err
 | 
						|
	}
 | 
						|
 | 
						|
	// create new buf with signature prefix
 | 
						|
	return packages_module.CreateHashedBufferFromReader(io.MultiReader(bytes.NewReader(signBlob), buf))
 | 
						|
}
 |