aws.go 914 B

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