2017-06-20 16:58:55 +03:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"crypto/hmac"
|
|
|
|
"crypto/sha256"
|
|
|
|
"encoding/base64"
|
|
|
|
"errors"
|
|
|
|
)
|
|
|
|
|
2018-10-06 02:29:55 +06:00
|
|
|
var (
|
2018-11-20 19:05:16 +06:00
|
|
|
errInvalidSignature = errors.New("Invalid signature")
|
|
|
|
errInvalidSignatureEncoding = errors.New("Invalid signature encoding")
|
2018-10-06 02:29:55 +06:00
|
|
|
)
|
|
|
|
|
2018-11-15 18:35:06 +06:00
|
|
|
type securityKey []byte
|
|
|
|
|
2018-11-20 19:05:16 +06:00
|
|
|
func validatePath(signature, path string) error {
|
|
|
|
messageMAC, err := base64.RawURLEncoding.DecodeString(signature)
|
2017-06-20 16:58:55 +03:00
|
|
|
if err != nil {
|
2018-11-20 19:05:16 +06:00
|
|
|
return errInvalidSignatureEncoding
|
2017-06-20 16:58:55 +03:00
|
|
|
}
|
|
|
|
|
2018-11-15 18:35:06 +06:00
|
|
|
for i := 0; i < len(conf.Keys); i++ {
|
|
|
|
if hmac.Equal(messageMAC, signatureFor(path, i)) {
|
|
|
|
return nil
|
|
|
|
}
|
2017-06-20 16:58:55 +03:00
|
|
|
}
|
|
|
|
|
2018-11-20 19:05:16 +06:00
|
|
|
return errInvalidSignature
|
2017-06-20 16:58:55 +03:00
|
|
|
}
|
2018-11-02 14:10:20 +03:00
|
|
|
|
2018-11-15 18:35:06 +06:00
|
|
|
func signatureFor(str string, pairInd int) []byte {
|
|
|
|
mac := hmac.New(sha256.New, conf.Keys[pairInd])
|
|
|
|
mac.Write(conf.Salts[pairInd])
|
2018-11-02 14:10:20 +03:00
|
|
|
mac.Write([]byte(str))
|
|
|
|
expectedMAC := mac.Sum(nil)
|
|
|
|
if conf.SignatureSize < 32 {
|
|
|
|
return expectedMAC[:conf.SignatureSize]
|
|
|
|
}
|
|
|
|
return expectedMAC
|
|
|
|
}
|