seal

package
v1.13.0-rc1 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Feb 13, 2023 License: MPL-2.0 Imports: 6 Imported by: 58

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Access added in v1.0.0

type Access struct {
	wrapping.Wrapper
	WrapperType wrapping.WrapperType
}

Access is the embedded implementation of autoSeal that contains logic specific to encrypting and decrypting data, or in this case keys.

func NewTestSeal added in v1.0.0

func NewTestSeal(opts *TestSealOpts) *Access

func NewToggleableTestSeal added in v1.7.5

func NewToggleableTestSeal(opts *TestSealOpts) (*Access, func(error))

func (*Access) Decrypt added in v1.0.0

func (a *Access) Decrypt(ctx context.Context, data *wrapping.BlobInfo, aad []byte) (pt []byte, err error)

Decrypt uses the underlying seal to decrypt the cryptotext and returns it. Note that it is possible depending on the wrapper used that both pt and err are populated.

func (*Access) Encrypt added in v1.0.0

func (a *Access) Encrypt(ctx context.Context, plaintext, aad []byte) (blob *wrapping.BlobInfo, err error)

Encrypt uses the underlying seal to encrypt the plaintext and returns it.

func (*Access) Finalize added in v1.0.0

func (a *Access) Finalize(ctx context.Context) error

func (*Access) Init added in v1.0.0

func (a *Access) Init(ctx context.Context) error

func (*Access) SetType added in v1.4.0

func (a *Access) SetType(t wrapping.WrapperType)

func (*Access) Type added in v1.4.0

func (a *Access) Type(ctx context.Context) (wrapping.WrapperType, error)

type Envelope added in v1.0.0

type Envelope struct {
	// contains filtered or unexported fields
}

func NewEnvelope added in v1.0.0

func NewEnvelope() *Envelope

func (*Envelope) Decrypt added in v1.0.0

func (e *Envelope) Decrypt(data *wrapping.EnvelopeInfo, aad []byte) ([]byte, error)

func (*Envelope) Encrypt added in v1.0.0

func (e *Envelope) Encrypt(plaintext, aad []byte) (*wrapping.EnvelopeInfo, error)

type StoredKeysSupport added in v1.4.0

type StoredKeysSupport int
const (
	// The 0 value of StoredKeysSupport is an invalid option
	StoredKeysInvalid StoredKeysSupport = iota
	StoredKeysNotSupported
	StoredKeysSupportedGeneric
	StoredKeysSupportedShamirRoot
)

func (StoredKeysSupport) String added in v1.4.0

func (s StoredKeysSupport) String() string

type TestSealOpts added in v1.4.0

type TestSealOpts struct {
	Logger     hclog.Logger
	StoredKeys StoredKeysSupport
	Secret     []byte
	Name       wrapping.WrapperType
}

type ToggleableWrapper added in v1.7.5

type ToggleableWrapper struct {
	wrapping.Wrapper
	// contains filtered or unexported fields
}

func (ToggleableWrapper) Decrypt added in v1.7.5

func (t ToggleableWrapper) Decrypt(ctx context.Context, info *wrapping.BlobInfo, opts ...wrapping.Option) ([]byte, error)

func (*ToggleableWrapper) Encrypt added in v1.7.5

func (t *ToggleableWrapper) Encrypt(ctx context.Context, bytes []byte, opts ...wrapping.Option) (*wrapping.BlobInfo, error)

func (*ToggleableWrapper) SetError added in v1.10.0

func (t *ToggleableWrapper) SetError(err error)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL