crypt.go 858 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. package main
  2. import (
  3. "crypto/hmac"
  4. "crypto/sha256"
  5. "encoding/base64"
  6. "errors"
  7. )
  8. var (
  9. errInvalidSignature = errors.New("Invalid signature")
  10. errInvalidSignatureEncoding = errors.New("Invalid signature encoding")
  11. )
  12. type securityKey []byte
  13. func validatePath(signature, path string) error {
  14. messageMAC, err := base64.RawURLEncoding.DecodeString(signature)
  15. if err != nil {
  16. return errInvalidSignatureEncoding
  17. }
  18. for i := 0; i < len(conf.Keys); i++ {
  19. if hmac.Equal(messageMAC, signatureFor(path, i)) {
  20. return nil
  21. }
  22. }
  23. return errInvalidSignature
  24. }
  25. func signatureFor(str string, pairInd int) []byte {
  26. mac := hmac.New(sha256.New, conf.Keys[pairInd])
  27. mac.Write(conf.Salts[pairInd])
  28. mac.Write([]byte(str))
  29. expectedMAC := mac.Sum(nil)
  30. if conf.SignatureSize < 32 {
  31. return expectedMAC[:conf.SignatureSize]
  32. }
  33. return expectedMAC
  34. }