2020-06-03 17:37:51 +00:00
|
|
|
package secret
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
|
|
|
|
"github.com/influxdata/influxdb/v2"
|
|
|
|
"github.com/influxdata/influxdb/v2/kit/metric"
|
2021-09-13 19:12:35 +00:00
|
|
|
"github.com/influxdata/influxdb/v2/kit/platform"
|
2020-06-03 17:37:51 +00:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
)
|
|
|
|
|
|
|
|
// SecreteService is a metrics middleware system for the secret service
|
|
|
|
type SecreteService struct {
|
|
|
|
// RED metrics
|
|
|
|
rec *metric.REDClient
|
|
|
|
|
|
|
|
secretSvc influxdb.SecretService
|
|
|
|
}
|
|
|
|
|
|
|
|
var _ influxdb.SecretService = (*SecreteService)(nil)
|
|
|
|
|
|
|
|
// NewMetricService creates a new secret metrics middleware
|
|
|
|
func NewMetricService(reg prometheus.Registerer, s influxdb.SecretService) *SecreteService {
|
|
|
|
return &SecreteService{
|
|
|
|
rec: metric.New(reg, "secret"),
|
|
|
|
secretSvc: s,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// LoadSecret retrieves the secret value v found at key k for organization orgID.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) LoadSecret(ctx context.Context, orgID platform.ID, key string) (string, error) {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("load_secret")
|
|
|
|
secret, err := ms.secretSvc.LoadSecret(ctx, orgID, key)
|
|
|
|
return secret, rec(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetSecretKeys retrieves all secret keys that are stored for the organization orgID.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) GetSecretKeys(ctx context.Context, orgID platform.ID) ([]string, error) {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("get_secret_keys")
|
|
|
|
secrets, err := ms.secretSvc.GetSecretKeys(ctx, orgID)
|
|
|
|
return secrets, rec(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// PutSecret stores the secret pair (k,v) for the organization orgID.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) PutSecret(ctx context.Context, orgID platform.ID, key string, val string) error {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("put_secret")
|
|
|
|
err := ms.secretSvc.PutSecret(ctx, orgID, key, val)
|
|
|
|
return rec(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// PutSecrets puts all provided secrets and overwrites any previous values.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) PutSecrets(ctx context.Context, orgID platform.ID, m map[string]string) error {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("put_secrets")
|
|
|
|
err := ms.secretSvc.PutSecrets(ctx, orgID, m)
|
|
|
|
return rec(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// PatchSecrets patches all provided secrets and updates any previous values.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) PatchSecrets(ctx context.Context, orgID platform.ID, m map[string]string) error {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("patch_secrets")
|
|
|
|
err := ms.secretSvc.PatchSecrets(ctx, orgID, m)
|
|
|
|
return rec(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
// DeleteSecret removes a single secret from the secret store.
|
2021-03-30 18:10:02 +00:00
|
|
|
func (ms *SecreteService) DeleteSecret(ctx context.Context, orgID platform.ID, keys ...string) error {
|
2020-06-03 17:37:51 +00:00
|
|
|
rec := ms.rec.Record("delete_secret")
|
|
|
|
err := ms.secretSvc.DeleteSecret(ctx, orgID, keys...)
|
|
|
|
return rec(err)
|
|
|
|
}
|