You've already forked oauth2-proxy
mirror of
https://github.com/oauth2-proxy/oauth2-proxy.git
synced 2025-12-01 22:51:45 +02:00
Move Encrypt/Decrypt Into helper to session_state.go
This helper method is only applicable for Base64 wrapped encryption since it operated on string -> string primarily. It wouldn't be used for pure CFB/GCM ciphers. After a messagePack session refactor, this method would further only be used for legacy session compatibility - making its placement in cipher.go not ideal.
This commit is contained in:
@@ -13,11 +13,9 @@ import (
|
||||
type Cipher interface {
|
||||
Encrypt(value []byte) ([]byte, error)
|
||||
Decrypt(ciphertext []byte) ([]byte, error)
|
||||
EncryptInto(s *string) error
|
||||
DecryptInto(s *string) error
|
||||
}
|
||||
|
||||
type Base64Cipher struct {
|
||||
type base64Cipher struct {
|
||||
Cipher Cipher
|
||||
}
|
||||
|
||||
@@ -28,11 +26,11 @@ func NewBase64Cipher(initCipher func([]byte) (Cipher, error), secret []byte) (Ci
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &Base64Cipher{Cipher: c}, nil
|
||||
return &base64Cipher{Cipher: c}, nil
|
||||
}
|
||||
|
||||
// Encrypt encrypts a value with the embedded Cipher & Base64 encodes it
|
||||
func (c *Base64Cipher) Encrypt(value []byte) ([]byte, error) {
|
||||
func (c *base64Cipher) Encrypt(value []byte) ([]byte, error) {
|
||||
encrypted, err := c.Cipher.Encrypt(value)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -42,7 +40,7 @@ func (c *Base64Cipher) Encrypt(value []byte) ([]byte, error) {
|
||||
}
|
||||
|
||||
// Decrypt Base64 decodes a value & decrypts it with the embedded Cipher
|
||||
func (c *Base64Cipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
func (c *base64Cipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
encrypted, err := base64.StdEncoding.DecodeString(string(ciphertext))
|
||||
if err != nil {
|
||||
return nil, fmt.Errorf("failed to base64 decode value %s", err)
|
||||
@@ -51,17 +49,7 @@ func (c *Base64Cipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
return c.Cipher.Decrypt(encrypted)
|
||||
}
|
||||
|
||||
// EncryptInto encrypts the value and stores it back in the string pointer
|
||||
func (c *Base64Cipher) EncryptInto(s *string) error {
|
||||
return into(c.Encrypt, s)
|
||||
}
|
||||
|
||||
// DecryptInto decrypts the value and stores it back in the string pointer
|
||||
func (c *Base64Cipher) DecryptInto(s *string) error {
|
||||
return into(c.Decrypt, s)
|
||||
}
|
||||
|
||||
type CFBCipher struct {
|
||||
type cfbCipher struct {
|
||||
cipher.Block
|
||||
}
|
||||
|
||||
@@ -71,11 +59,11 @@ func NewCFBCipher(secret []byte) (Cipher, error) {
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &CFBCipher{Block: c}, err
|
||||
return &cfbCipher{Block: c}, err
|
||||
}
|
||||
|
||||
// Encrypt with AES CFB
|
||||
func (c *CFBCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
func (c *cfbCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
ciphertext := make([]byte, aes.BlockSize+len(value))
|
||||
iv := ciphertext[:aes.BlockSize]
|
||||
if _, err := io.ReadFull(rand.Reader, iv); err != nil {
|
||||
@@ -88,7 +76,7 @@ func (c *CFBCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
}
|
||||
|
||||
// Decrypt an AES CFB ciphertext
|
||||
func (c *CFBCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
func (c *cfbCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
if len(ciphertext) < aes.BlockSize {
|
||||
return nil, fmt.Errorf("encrypted value should be at least %d bytes, but is only %d bytes", aes.BlockSize, len(ciphertext))
|
||||
}
|
||||
@@ -101,17 +89,7 @@ func (c *CFBCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
return plaintext, nil
|
||||
}
|
||||
|
||||
// EncryptInto returns an error since the encrypted data is a []byte that isn't string cast-able
|
||||
func (c *CFBCipher) EncryptInto(s *string) error {
|
||||
return fmt.Errorf("CFBCipher is not a string->string compatible cipher")
|
||||
}
|
||||
|
||||
// EncryptInto returns an error since the encrypted data needs to be a []byte
|
||||
func (c *CFBCipher) DecryptInto(s *string) error {
|
||||
return fmt.Errorf("CFBCipher is not a string->string compatible cipher")
|
||||
}
|
||||
|
||||
type GCMCipher struct {
|
||||
type gcmCipher struct {
|
||||
cipher.Block
|
||||
}
|
||||
|
||||
@@ -121,11 +99,11 @@ func NewGCMCipher(secret []byte) (Cipher, error) {
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &GCMCipher{Block: c}, err
|
||||
return &gcmCipher{Block: c}, err
|
||||
}
|
||||
|
||||
// Encrypt with AES GCM on raw bytes
|
||||
func (c *GCMCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
func (c *gcmCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
gcm, err := cipher.NewGCM(c.Block)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -141,7 +119,7 @@ func (c *GCMCipher) Encrypt(value []byte) ([]byte, error) {
|
||||
}
|
||||
|
||||
// Decrypt an AES GCM ciphertext
|
||||
func (c *GCMCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
func (c *gcmCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
gcm, err := cipher.NewGCM(c.Block)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
@@ -156,30 +134,3 @@ func (c *GCMCipher) Decrypt(ciphertext []byte) ([]byte, error) {
|
||||
}
|
||||
return plaintext, nil
|
||||
}
|
||||
|
||||
// EncryptInto returns an error since the encrypted data is a []byte that isn't string cast-able
|
||||
func (c *GCMCipher) EncryptInto(s *string) error {
|
||||
return fmt.Errorf("CFBCipher is not a string->string compatible cipher")
|
||||
}
|
||||
|
||||
// EncryptInto returns an error since the encrypted data needs to be a []byte
|
||||
func (c *GCMCipher) DecryptInto(s *string) error {
|
||||
return fmt.Errorf("CFBCipher is not a string->string compatible cipher")
|
||||
}
|
||||
|
||||
// codecFunc is a function that takes a string and encodes/decodes it
|
||||
type codecFunc func([]byte) ([]byte, error)
|
||||
|
||||
func into(f codecFunc, s *string) error {
|
||||
// Do not encrypt/decrypt nil or empty strings
|
||||
if s == nil || *s == "" {
|
||||
return nil
|
||||
}
|
||||
|
||||
d, err := f([]byte(*s))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
*s = string(d)
|
||||
return nil
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user