auth/vendor/github.com/lestrrat-go/jwx/v2/jwa/content_encryption_gen.go

80 lines
2.6 KiB
Go

// this file was auto-generated by internal/cmd/gentypes/main.go: DO NOT EDIT
package jwa
import (
"fmt"
"sort"
"sync"
)
// ContentEncryptionAlgorithm represents the various encryption algorithms as described in https://tools.ietf.org/html/rfc7518#section-5
type ContentEncryptionAlgorithm string
// Supported values for ContentEncryptionAlgorithm
const (
A128CBC_HS256 ContentEncryptionAlgorithm = "A128CBC-HS256" // AES-CBC + HMAC-SHA256 (128)
A128GCM ContentEncryptionAlgorithm = "A128GCM" // AES-GCM (128)
A192CBC_HS384 ContentEncryptionAlgorithm = "A192CBC-HS384" // AES-CBC + HMAC-SHA384 (192)
A192GCM ContentEncryptionAlgorithm = "A192GCM" // AES-GCM (192)
A256CBC_HS512 ContentEncryptionAlgorithm = "A256CBC-HS512" // AES-CBC + HMAC-SHA512 (256)
A256GCM ContentEncryptionAlgorithm = "A256GCM" // AES-GCM (256)
)
var allContentEncryptionAlgorithms = map[ContentEncryptionAlgorithm]struct{}{
A128CBC_HS256: {},
A128GCM: {},
A192CBC_HS384: {},
A192GCM: {},
A256CBC_HS512: {},
A256GCM: {},
}
var listContentEncryptionAlgorithmOnce sync.Once
var listContentEncryptionAlgorithm []ContentEncryptionAlgorithm
// ContentEncryptionAlgorithms returns a list of all available values for ContentEncryptionAlgorithm
func ContentEncryptionAlgorithms() []ContentEncryptionAlgorithm {
listContentEncryptionAlgorithmOnce.Do(func() {
listContentEncryptionAlgorithm = make([]ContentEncryptionAlgorithm, 0, len(allContentEncryptionAlgorithms))
for v := range allContentEncryptionAlgorithms {
listContentEncryptionAlgorithm = append(listContentEncryptionAlgorithm, v)
}
sort.Slice(listContentEncryptionAlgorithm, func(i, j int) bool {
return string(listContentEncryptionAlgorithm[i]) < string(listContentEncryptionAlgorithm[j])
})
})
return listContentEncryptionAlgorithm
}
// Accept is used when conversion from values given by
// outside sources (such as JSON payloads) is required
func (v *ContentEncryptionAlgorithm) Accept(value interface{}) error {
var tmp ContentEncryptionAlgorithm
if x, ok := value.(ContentEncryptionAlgorithm); ok {
tmp = x
} else {
var s string
switch x := value.(type) {
case fmt.Stringer:
s = x.String()
case string:
s = x
default:
return fmt.Errorf(`invalid type for jwa.ContentEncryptionAlgorithm: %T`, value)
}
tmp = ContentEncryptionAlgorithm(s)
}
if _, ok := allContentEncryptionAlgorithms[tmp]; !ok {
return fmt.Errorf(`invalid jwa.ContentEncryptionAlgorithm value`)
}
*v = tmp
return nil
}
// String returns the string representation of a ContentEncryptionAlgorithm
func (v ContentEncryptionAlgorithm) String() string {
return string(v)
}