mirror of
https://github.com/tgdrive/teldrive.git
synced 2025-01-10 01:02:01 +08:00
62 lines
986 B
Go
62 lines
986 B
Go
package auth
|
|
|
|
import (
|
|
"encoding/json"
|
|
"os"
|
|
|
|
"github.com/divyam234/teldrive/pkg/types"
|
|
"github.com/go-jose/go-jose/v3"
|
|
)
|
|
|
|
func Encode(payload *types.JWTClaims) (string, error) {
|
|
|
|
rcpt := jose.Recipient{
|
|
Algorithm: jose.PBES2_HS256_A128KW,
|
|
Key: os.Getenv("JWT_SECRET"),
|
|
}
|
|
|
|
enc, err := jose.NewEncrypter(jose.A128CBC_HS256, rcpt, nil)
|
|
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
jwt, _ := json.Marshal(payload)
|
|
|
|
jweObject, err := enc.Encrypt(jwt)
|
|
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
jweToken, err := jweObject.CompactSerialize()
|
|
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
return jweToken, nil
|
|
}
|
|
|
|
func Decode(token string) (*types.JWTClaims, error) {
|
|
jwe, err := jose.ParseEncrypted(token)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
decryptedData, err := jwe.Decrypt(os.Getenv("JWT_SECRET"))
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
jwtToken := &types.JWTClaims{}
|
|
|
|
err = json.Unmarshal(decryptedData, jwtToken)
|
|
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return jwtToken, nil
|
|
|
|
}
|