mirror of
				https://github.com/go-gitea/gitea
				synced 2025-10-31 19:38:23 +00: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