2019-03-05 20:42:49 +00:00
|
|
|
package provisioner
|
|
|
|
|
|
|
|
import (
|
2019-03-06 22:54:56 +00:00
|
|
|
"crypto/x509"
|
2019-03-05 20:42:49 +00:00
|
|
|
"encoding/json"
|
|
|
|
"strings"
|
|
|
|
|
|
|
|
"github.com/pkg/errors"
|
|
|
|
)
|
|
|
|
|
|
|
|
// Interface is the interface that all provisioner types must implement.
|
|
|
|
type Interface interface {
|
2019-03-06 22:54:56 +00:00
|
|
|
GetID() string
|
|
|
|
GetName() string
|
|
|
|
GetType() Type
|
2019-03-05 22:52:26 +00:00
|
|
|
GetEncryptedKey() (kid string, key string, ok bool)
|
2019-03-05 20:42:49 +00:00
|
|
|
Init(claims *Claims) error
|
|
|
|
Authorize(token string) ([]SignOption, error)
|
2019-03-06 22:54:56 +00:00
|
|
|
AuthorizeRenewal(cert *x509.Certificate) error
|
|
|
|
AuthorizeRevoke(token string) error
|
2019-03-05 20:42:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Type indicates the provisioner Type.
|
|
|
|
type Type int
|
|
|
|
|
|
|
|
const (
|
|
|
|
// TypeJWK is used to indicate the JWK provisioners.
|
|
|
|
TypeJWK Type = 1
|
|
|
|
|
|
|
|
// TypeOIDC is used to indicate the OIDC provisioners.
|
|
|
|
TypeOIDC Type = 2
|
|
|
|
)
|
|
|
|
|
|
|
|
type provisioner struct {
|
|
|
|
Type string `json:"type"`
|
|
|
|
}
|
|
|
|
|
|
|
|
// Provisioner implmements the provisioner.Interface on a base provisioner. It
|
|
|
|
// also implements custom marshalers and unmarshalers so different provisioners
|
|
|
|
// can be represented in a configuration type.
|
|
|
|
type Provisioner struct {
|
|
|
|
base Interface
|
|
|
|
}
|
|
|
|
|
2019-03-06 22:54:56 +00:00
|
|
|
// New creates a new provisioner from the base provisioner.
|
|
|
|
func New(base Interface) *Provisioner {
|
|
|
|
return &Provisioner{
|
|
|
|
base: base,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Base returns the base type of the provisioner.
|
|
|
|
func (p *Provisioner) Base() Interface {
|
|
|
|
return p.base
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetID returns the base provisioner unique ID. This identifier is used as the
|
|
|
|
// key in a provisioner.Collection.
|
|
|
|
func (p *Provisioner) GetID() string {
|
|
|
|
return p.base.GetID()
|
2019-03-05 20:42:49 +00:00
|
|
|
}
|
|
|
|
|
2019-03-05 22:52:26 +00:00
|
|
|
// GetEncryptedKey returns the base provisioner encrypted key if it's defined.
|
|
|
|
func (p *Provisioner) GetEncryptedKey() (string, string, bool) {
|
|
|
|
return p.base.GetEncryptedKey()
|
2019-03-05 22:45:57 +00:00
|
|
|
}
|
|
|
|
|
2019-03-06 22:54:56 +00:00
|
|
|
// GetName returns the name of the provisioner
|
|
|
|
func (p *Provisioner) GetName() string {
|
|
|
|
return p.base.GetName()
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetType return the provisioners type.
|
|
|
|
func (p *Provisioner) GetType() Type {
|
|
|
|
return p.base.GetType()
|
2019-03-05 22:28:32 +00:00
|
|
|
}
|
|
|
|
|
2019-03-05 20:42:49 +00:00
|
|
|
// Init initializes the base provisioner with the given claims.
|
|
|
|
func (p *Provisioner) Init(claims *Claims) error {
|
|
|
|
return p.base.Init(claims)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Authorize validates the given token on the base provisioner returning a list
|
|
|
|
// of options to validate the signing request.
|
|
|
|
func (p *Provisioner) Authorize(token string) ([]SignOption, error) {
|
|
|
|
return p.base.Authorize(token)
|
|
|
|
}
|
|
|
|
|
2019-03-06 22:54:56 +00:00
|
|
|
// AuthorizeRenewal checks if the base provisioner authorizes the renewal.
|
|
|
|
func (p *Provisioner) AuthorizeRenewal(cert *x509.Certificate) error {
|
|
|
|
return p.base.AuthorizeRenewal(cert)
|
|
|
|
}
|
|
|
|
|
|
|
|
// AuthorizeRevoke checks on the base provisioner if the given token has revoke
|
|
|
|
// access.
|
|
|
|
func (p *Provisioner) AuthorizeRevoke(token string) error {
|
|
|
|
return p.base.AuthorizeRevoke(token)
|
|
|
|
}
|
|
|
|
|
2019-03-05 20:42:49 +00:00
|
|
|
// MarshalJSON implements the json.Marshaler interface on the Provisioner type.
|
|
|
|
func (p *Provisioner) MarshalJSON() ([]byte, error) {
|
|
|
|
return json.Marshal(p.base)
|
|
|
|
}
|
|
|
|
|
|
|
|
// UnmarshalJSON implements the json.Unmarshaler interface on the Provisioner
|
|
|
|
// type.
|
|
|
|
func (p *Provisioner) UnmarshalJSON(data []byte) error {
|
|
|
|
var typ provisioner
|
|
|
|
if err := json.Unmarshal(data, &typ); err != nil {
|
|
|
|
return errors.Errorf("error unmarshalling provisioner")
|
|
|
|
}
|
|
|
|
|
|
|
|
switch strings.ToLower(typ.Type) {
|
2019-03-06 22:54:56 +00:00
|
|
|
case "jwk":
|
2019-03-05 20:42:49 +00:00
|
|
|
p.base = &JWT{}
|
|
|
|
case "oidc":
|
|
|
|
p.base = &OIDC{}
|
|
|
|
default:
|
2019-03-06 22:54:56 +00:00
|
|
|
return errors.Errorf("provisioner type %s not supported", typ.Type)
|
2019-03-05 20:42:49 +00:00
|
|
|
}
|
|
|
|
if err := json.Unmarshal(data, &p.base); err != nil {
|
|
|
|
return errors.Errorf("error unmarshalling provisioner")
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|