vault.go 955 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. // +build !novaultkms
  2. package kms
  3. import (
  4. // we import hashivault here to be able to disable Vault support using a build tag
  5. _ "gocloud.dev/secrets/hashivault"
  6. "github.com/drakkan/sftpgo/version"
  7. )
  8. type vaultSecret struct {
  9. baseGCloudSecret
  10. }
  11. func init() {
  12. version.AddFeature("+vaultkms")
  13. }
  14. func newVaultSecret(base baseSecret, url, masterKey string) SecretProvider {
  15. return &vaultSecret{
  16. baseGCloudSecret{
  17. baseSecret: base,
  18. url: url,
  19. masterKey: masterKey,
  20. },
  21. }
  22. }
  23. func (s *vaultSecret) Name() string {
  24. return vaultProviderName
  25. }
  26. func (s *vaultSecret) IsEncrypted() bool {
  27. return s.Status == SecretStatusVaultTransit
  28. }
  29. func (s *vaultSecret) Encrypt() error {
  30. if err := s.baseGCloudSecret.Encrypt(); err != nil {
  31. return err
  32. }
  33. s.Status = SecretStatusVaultTransit
  34. return nil
  35. }
  36. func (s *vaultSecret) Decrypt() error {
  37. if !s.IsEncrypted() {
  38. return errWrongSecretStatus
  39. }
  40. return s.baseGCloudSecret.Decrypt()
  41. }