crypt.go 573 B

12345678910111213141516171819202122232425262728293031
  1. package main
  2. import (
  3. "crypto/hmac"
  4. "crypto/sha256"
  5. "encoding/base64"
  6. "errors"
  7. )
  8. var (
  9. errInvalidToken = errors.New("Invalid token")
  10. errInvalidURLEncoding = errors.New("Invalid token encoding")
  11. )
  12. func validatePath(token, path string) error {
  13. messageMAC, err := base64.RawURLEncoding.DecodeString(token)
  14. if err != nil {
  15. return errInvalidURLEncoding
  16. }
  17. mac := hmac.New(sha256.New, conf.Key)
  18. mac.Write(conf.Salt)
  19. mac.Write([]byte(path))
  20. expectedMAC := mac.Sum(nil)
  21. if !hmac.Equal(messageMAC, expectedMAC) {
  22. return errInvalidToken
  23. }
  24. return nil
  25. }