Blame vendor/github.com/dgrijalva/jwt-go/hmac.go

Packit 63bb0d
package jwt
Packit 63bb0d
Packit 63bb0d
import (
Packit 63bb0d
	"crypto"
Packit 63bb0d
	"crypto/hmac"
Packit 63bb0d
	"errors"
Packit 63bb0d
)
Packit 63bb0d
Packit 63bb0d
// Implements the HMAC-SHA family of signing methods signing methods
Packit 63bb0d
// Expects key type of []byte for both signing and validation
Packit 63bb0d
type SigningMethodHMAC struct {
Packit 63bb0d
	Name string
Packit 63bb0d
	Hash crypto.Hash
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// Specific instances for HS256 and company
Packit 63bb0d
var (
Packit 63bb0d
	SigningMethodHS256  *SigningMethodHMAC
Packit 63bb0d
	SigningMethodHS384  *SigningMethodHMAC
Packit 63bb0d
	SigningMethodHS512  *SigningMethodHMAC
Packit 63bb0d
	ErrSignatureInvalid = errors.New("signature is invalid")
Packit 63bb0d
)
Packit 63bb0d
Packit 63bb0d
func init() {
Packit 63bb0d
	// HS256
Packit 63bb0d
	SigningMethodHS256 = &SigningMethodHMAC{"HS256", crypto.SHA256}
Packit 63bb0d
	RegisterSigningMethod(SigningMethodHS256.Alg(), func() SigningMethod {
Packit 63bb0d
		return SigningMethodHS256
Packit 63bb0d
	})
Packit 63bb0d
Packit 63bb0d
	// HS384
Packit 63bb0d
	SigningMethodHS384 = &SigningMethodHMAC{"HS384", crypto.SHA384}
Packit 63bb0d
	RegisterSigningMethod(SigningMethodHS384.Alg(), func() SigningMethod {
Packit 63bb0d
		return SigningMethodHS384
Packit 63bb0d
	})
Packit 63bb0d
Packit 63bb0d
	// HS512
Packit 63bb0d
	SigningMethodHS512 = &SigningMethodHMAC{"HS512", crypto.SHA512}
Packit 63bb0d
	RegisterSigningMethod(SigningMethodHS512.Alg(), func() SigningMethod {
Packit 63bb0d
		return SigningMethodHS512
Packit 63bb0d
	})
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
func (m *SigningMethodHMAC) Alg() string {
Packit 63bb0d
	return m.Name
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// Verify the signature of HSXXX tokens.  Returns nil if the signature is valid.
Packit 63bb0d
func (m *SigningMethodHMAC) Verify(signingString, signature string, key interface{}) error {
Packit 63bb0d
	// Verify the key is the right type
Packit 63bb0d
	keyBytes, ok := key.([]byte)
Packit 63bb0d
	if !ok {
Packit 63bb0d
		return ErrInvalidKeyType
Packit 63bb0d
	}
Packit 63bb0d
Packit 63bb0d
	// Decode signature, for comparison
Packit 63bb0d
	sig, err := DecodeSegment(signature)
Packit 63bb0d
	if err != nil {
Packit 63bb0d
		return err
Packit 63bb0d
	}
Packit 63bb0d
Packit 63bb0d
	// Can we use the specified hashing method?
Packit 63bb0d
	if !m.Hash.Available() {
Packit 63bb0d
		return ErrHashUnavailable
Packit 63bb0d
	}
Packit 63bb0d
Packit 63bb0d
	// This signing method is symmetric, so we validate the signature
Packit 63bb0d
	// by reproducing the signature from the signing string and key, then
Packit 63bb0d
	// comparing that against the provided signature.
Packit 63bb0d
	hasher := hmac.New(m.Hash.New, keyBytes)
Packit 63bb0d
	hasher.Write([]byte(signingString))
Packit 63bb0d
	if !hmac.Equal(sig, hasher.Sum(nil)) {
Packit 63bb0d
		return ErrSignatureInvalid
Packit 63bb0d
	}
Packit 63bb0d
Packit 63bb0d
	// No validation errors.  Signature is good.
Packit 63bb0d
	return nil
Packit 63bb0d
}
Packit 63bb0d
Packit 63bb0d
// Implements the Sign method from SigningMethod for this signing method.
Packit 63bb0d
// Key must be []byte
Packit 63bb0d
func (m *SigningMethodHMAC) Sign(signingString string, key interface{}) (string, error) {
Packit 63bb0d
	if keyBytes, ok := key.([]byte); ok {
Packit 63bb0d
		if !m.Hash.Available() {
Packit 63bb0d
			return "", ErrHashUnavailable
Packit 63bb0d
		}
Packit 63bb0d
Packit 63bb0d
		hasher := hmac.New(m.Hash.New, keyBytes)
Packit 63bb0d
		hasher.Write([]byte(signingString))
Packit 63bb0d
Packit 63bb0d
		return EncodeSegment(hasher.Sum(nil)), nil
Packit 63bb0d
	}
Packit 63bb0d
Packit 63bb0d
	return "", ErrInvalidKeyType
Packit 63bb0d
}