2024-09-08 12:06:14 +02:00
|
|
|
package hmac
|
|
|
|
|
|
|
|
import (
|
2024-09-11 16:20:30 +02:00
|
|
|
"crypto/sha256"
|
2024-09-08 12:06:14 +02:00
|
|
|
"fmt"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
|
|
|
)
|
|
|
|
|
|
|
|
type TimedHMACValidator struct {
|
|
|
|
*TimedHMAC
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewTimedHMACValidator(secret string, duration time.Duration) *TimedHMACValidator {
|
|
|
|
ta := NewTimedHMAC(secret, duration)
|
|
|
|
return &TimedHMACValidator{
|
|
|
|
ta,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-09-11 16:20:30 +02:00
|
|
|
func (a *TimedHMACValidator) Validate(credentials any) error {
|
2024-09-08 12:06:14 +02:00
|
|
|
b, ok := credentials.([]byte)
|
|
|
|
if !ok {
|
|
|
|
return fmt.Errorf("invalid credentials type")
|
|
|
|
}
|
|
|
|
c, err := unmarshalToken(b)
|
|
|
|
if err != nil {
|
|
|
|
log.Debugf("failed to unmarshal token: %s", err)
|
|
|
|
return err
|
|
|
|
}
|
2024-09-11 16:20:30 +02:00
|
|
|
return a.TimedHMAC.Validate(sha256.New, c)
|
2024-09-08 12:06:14 +02:00
|
|
|
}
|