1
0
vault-redux/vault/barrier_access.go

28 lines
967 B
Go
Raw Normal View History

// Copyright (c) HashiCorp, Inc.
// SPDX-License-Identifier: BUSL-1.1
2017-10-23 23:42:56 +03:00
package vault
import "context"
2017-10-23 23:42:56 +03:00
// BarrierEncryptorAccess is a wrapper around BarrierEncryptor that allows Core
// to expose its barrier encrypt/decrypt operations through BarrierEncryptorAccess()
// while restricting the ability to modify Core.barrier itself.
type BarrierEncryptorAccess struct {
barrierEncryptor BarrierEncryptor
}
var _ BarrierEncryptor = (*BarrierEncryptorAccess)(nil)
func NewBarrierEncryptorAccess(barrierEncryptor BarrierEncryptor) *BarrierEncryptorAccess {
return &BarrierEncryptorAccess{barrierEncryptor: barrierEncryptor}
}
func (b *BarrierEncryptorAccess) Encrypt(ctx context.Context, key string, plaintext []byte) ([]byte, error) {
2018-01-19 13:31:55 +03:00
return b.barrierEncryptor.Encrypt(ctx, key, plaintext)
2017-10-23 23:42:56 +03:00
}
func (b *BarrierEncryptorAccess) Decrypt(ctx context.Context, key string, ciphertext []byte) ([]byte, error) {
2018-01-19 13:31:55 +03:00
return b.barrierEncryptor.Decrypt(ctx, key, ciphertext)
2017-10-23 23:42:56 +03:00
}