mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Add Alpine package registry (#23714)
This PR adds an Alpine package registry. You can follow [this tutorial](https://wiki.alpinelinux.org/wiki/Creating_an_Alpine_package) to build a *.apk package for testing. This functionality is similar to the Debian registry (#22854) and therefore shares some methods. I marked this PR as blocked because it should be merged after #22854.  --------- Co-authored-by: techknowlogick <techknowlogick@gitea.io> Co-authored-by: silverwind <me@silverwind.io> Co-authored-by: Giteabot <teabot@gitea.io>
This commit is contained in:
		@@ -23,7 +23,6 @@ import (
 | 
			
		||||
	"code.gitea.io/gitea/modules/util"
 | 
			
		||||
 | 
			
		||||
	"github.com/golang-jwt/jwt/v4"
 | 
			
		||||
	"github.com/minio/sha256-simd"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
// ErrInvalidAlgorithmType represents an invalid algorithm error.
 | 
			
		||||
@@ -82,7 +81,7 @@ type rsaSingingKey struct {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func newRSASingingKey(signingMethod jwt.SigningMethod, key *rsa.PrivateKey) (rsaSingingKey, error) {
 | 
			
		||||
	kid, err := createPublicKeyFingerprint(key.Public().(*rsa.PublicKey))
 | 
			
		||||
	kid, err := util.CreatePublicKeyFingerprint(key.Public().(*rsa.PublicKey))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return rsaSingingKey{}, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -133,7 +132,7 @@ type eddsaSigningKey struct {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func newEdDSASingingKey(signingMethod jwt.SigningMethod, key ed25519.PrivateKey) (eddsaSigningKey, error) {
 | 
			
		||||
	kid, err := createPublicKeyFingerprint(key.Public().(ed25519.PublicKey))
 | 
			
		||||
	kid, err := util.CreatePublicKeyFingerprint(key.Public().(ed25519.PublicKey))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return eddsaSigningKey{}, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -184,7 +183,7 @@ type ecdsaSingingKey struct {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
func newECDSASingingKey(signingMethod jwt.SigningMethod, key *ecdsa.PrivateKey) (ecdsaSingingKey, error) {
 | 
			
		||||
	kid, err := createPublicKeyFingerprint(key.Public().(*ecdsa.PublicKey))
 | 
			
		||||
	kid, err := util.CreatePublicKeyFingerprint(key.Public().(*ecdsa.PublicKey))
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return ecdsaSingingKey{}, err
 | 
			
		||||
	}
 | 
			
		||||
@@ -229,19 +228,6 @@ func (key ecdsaSingingKey) PreProcessToken(token *jwt.Token) {
 | 
			
		||||
	token.Header["kid"] = key.id
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// createPublicKeyFingerprint creates a fingerprint of the given key.
 | 
			
		||||
// The fingerprint is the sha256 sum of the PKIX structure of the key.
 | 
			
		||||
func createPublicKeyFingerprint(key interface{}) ([]byte, error) {
 | 
			
		||||
	bytes, err := x509.MarshalPKIXPublicKey(key)
 | 
			
		||||
	if err != nil {
 | 
			
		||||
		return nil, err
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	checksum := sha256.Sum256(bytes)
 | 
			
		||||
 | 
			
		||||
	return checksum[:], nil
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// CreateJWTSigningKey creates a signing key from an algorithm / key pair.
 | 
			
		||||
func CreateJWTSigningKey(algorithm string, key interface{}) (JWTSigningKey, error) {
 | 
			
		||||
	var signingMethod jwt.SigningMethod
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user