Documentation ¶
Index ¶
- type Authenticator
- type K8sAuthenticator
- type LocalAuthenticator
- type PrometheusClient
- type PrometheusConfiguration
- type RedisClient
- type RedisConfiguration
- type StorageClient
- func (sc *StorageClient) BasePath() string
- func (sc *StorageClient) CheckIfExists(relativePath string) bool
- func (sc *StorageClient) CreateDirectory(relativePath string) error
- func (sc *StorageClient) RemoveDirectory(relativePath string) error
- func (sc *StorageClient) Rename(fromRelativePath, toAbsolutePath string) error
- type StorageClientConfiguration
- type StorageClientInterface
- type VaultClient
- func (vc *VaultClient) CheckIfEngineExists(path string) bool
- func (vc *VaultClient) Delete(path string) error
- func (vc *VaultClient) DeleteCredentials(path string) error
- func (vc *VaultClient) Get(path string) (map[string]interface{}, error)
- func (vc *VaultClient) GetCredentials(path string) (*config.Credentials, error)
- func (vc *VaultClient) List(path string) (interface{}, error)
- func (vc *VaultClient) Patch(path string, data map[string]interface{}) error
- func (vc *VaultClient) Put(path string, data map[string]interface{}) error
- func (vc *VaultClient) StoreCredentials(path string, credentials map[string]string) error
- type VaultClientConfiguration
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Authenticator ¶ added in v0.9.0
type Authenticator interface {
Authenticate(vc *VaultClient) error
}
Authenticator is an interface to identify which way to authenticate
func NewK8sAuthenticator ¶ added in v0.9.0
func NewK8sAuthenticator() Authenticator
NewK8sAuthenticator defines a new K8sAuthenticator struct.
func NewLocalAuthenticator ¶ added in v0.9.0
func NewLocalAuthenticator(token string) Authenticator
NewLocalAuthenticator defines a new LocalAuthenticator
type K8sAuthenticator ¶ added in v0.9.0
type K8sAuthenticator struct{}
K8sAuthenticator defines a struct for authenticating with Kubernetes.
func (*K8sAuthenticator) Authenticate ¶ added in v0.9.0
func (a *K8sAuthenticator) Authenticate(vc *VaultClient) error
Authenticate is used to authenticate using Kubernetes.
type LocalAuthenticator ¶ added in v0.9.0
type LocalAuthenticator struct {
// contains filtered or unexported fields
}
LocalAuthenticator is used to configure the development mode
func (*LocalAuthenticator) Authenticate ¶ added in v0.9.0
func (a *LocalAuthenticator) Authenticate(vc *VaultClient) error
Authenticate is used to authenticate local (development mode).
type PrometheusClient ¶
type PrometheusClient struct {
// contains filtered or unexported fields
}
PrometheusClient represents the Prometheus client.
func NewPrometheusClient ¶
func NewPrometheusClient( config PrometheusConfiguration, logger logging.Logger) PrometheusClient
NewPrometheusClient creates a PrometheusClient instance.
func (PrometheusClient) Query ¶ added in v0.9.1
func (c PrometheusClient) Query(ctx context.Context, query string, moment time.Time) (model.Value, error)
Query returns an instant vector, given the following parameters:
- query: Prometheus query
- moment: moment in time
It returns the result vector and the execution error encountered.
func (PrometheusClient) QueryRange ¶
func (c PrometheusClient) QueryRange(ctx context.Context, query string, startAt, endAt time.Time, step time.Duration) (model.Value, error)
QueryRange returns range vectors as result type matrix, given the following parameters:
- query: Prometheus query
- startAt: start time
- endAt: end time
- step: interval duration
It returns the result matrix and the execution error encountered.
type PrometheusConfiguration ¶
type PrometheusConfiguration struct {
Address string `envconfig:"PROMETHEUS_ADDRESS" required:"true"`
}
PrometheusConfiguration represents the client configuration to connect to Prometheus.
func (*PrometheusConfiguration) LoadFromEnvVars ¶
func (c *PrometheusConfiguration) LoadFromEnvVars() error
LoadFromEnvVars for PrometheusConfiguration.
type RedisClient ¶ added in v0.5.0
type RedisClient interface { Get(ctx context.Context, key string) *redis.StringCmd Set(ctx context.Context, key string, value interface{}, expiration time.Duration) *redis.StatusCmd Publish(ctx context.Context, channel string, message interface{}) *redis.IntCmd Subscribe(ctx context.Context, channels ...string) *redis.PubSub Ping(ctx context.Context) *redis.StatusCmd }
func NewRedisClient ¶ added in v0.5.0
func NewRedisClient(config RedisConfiguration, logger logging.Logger) RedisClient
NewRedisClient creates a new RedisClient (redis.Client) instance.
type RedisConfiguration ¶ added in v0.5.0
type RedisConfiguration struct { // Address represents host:port list separated by , Address []string `envconfig:"REDIS_ADDRESS" required:"true"` InsecureSkipVerify bool `envconfig:"REDIS_INSECURE_SKIP_VERIFY" default:"false"` CACert string `envconfig:"REDIS_CA_CERT"` Cert string `envconfig:"REDIS_CERT"` CertKey string `envconfig:"REDIS_CERT_KEY"` }
RedisConfiguration represents the client configuration to connect to Prometheus.
func (*RedisConfiguration) LoadFromEnvVars ¶ added in v0.5.0
func (c *RedisConfiguration) LoadFromEnvVars() error
LoadFromEnvVars for RedisConfiguration.
type StorageClient ¶
type StorageClient struct {
// contains filtered or unexported fields
}
StorageClient is a structure that holds all the dependencies for the following client
func NewStorageClient ¶
func NewStorageClient(logger logging.Logger, configuration StorageClientConfiguration) StorageClient
NewStorageClient returns an initialized struct with the required dependencies injected
func (*StorageClient) BasePath ¶ added in v0.9.2
func (sc *StorageClient) BasePath() string
BasePath returns a configured base path
func (*StorageClient) CheckIfExists ¶
func (sc *StorageClient) CheckIfExists(relativePath string) bool
CheckIfExists attempts to check if the directory exists
func (*StorageClient) CreateDirectory ¶
func (sc *StorageClient) CreateDirectory(relativePath string) error
CreateDirectory attempts to create a directory to hold requirements.txt
func (*StorageClient) RemoveDirectory ¶
func (sc *StorageClient) RemoveDirectory(relativePath string) error
RemoveDirectory attempts to remove the directory that holds requirements.txt
func (*StorageClient) Rename ¶ added in v0.9.2
func (sc *StorageClient) Rename(fromRelativePath, toAbsolutePath string) error
Rename attempts to rename a path
type StorageClientConfiguration ¶
type StorageClientConfiguration struct {
BasePath string `envconfig:"STORAGE_PATH" required:"true"`
}
StorageClientConfiguration is a struct that holds all the environment variables required to the Storage Client
func (*StorageClientConfiguration) LoadFromEnvVars ¶
func (c *StorageClientConfiguration) LoadFromEnvVars() error
LoadFromEnvVars parses the required configuration variables. Throws an error if the validations aren't met
type StorageClientInterface ¶
type StorageClientInterface interface { BasePath() string CreateDirectory(relativePath string) error RemoveDirectory(relativePath string) error CheckIfExists(relativePath string) bool Rename(fromRelativePath, toAbsolutePath string) error }
StorageClientInterface defines storage client interface
type VaultClient ¶
type VaultClient struct {
// contains filtered or unexported fields
}
VaultClient defines the Vault client struct, holding all the required dependencies
func NewVaultClient ¶
func NewVaultClient(logger logging.Logger, configuration VaultClientConfiguration, role string, authenticator Authenticator) (*VaultClient, error)
NewVaultClient returns an initialized struct with the required dependencies injected
func (*VaultClient) CheckIfEngineExists ¶
func (vc *VaultClient) CheckIfEngineExists(path string) bool
CheckIfEngineExists attempts to call the /tune API endpoint on the Secrets Engine. Should it fail, it might be an indication that the Secrets Engine is not created, which it's useful to know whether or not to call CreateEngine
func (*VaultClient) Delete ¶ added in v0.9.0
func (vc *VaultClient) Delete(path string) error
Delete ...
func (*VaultClient) DeleteCredentials ¶
func (vc *VaultClient) DeleteCredentials(path string) error
DeleteCredentials receives the path and attempts to delete the existing credentials on Vault. Is performs a soft delete, per docs > https://www.vaultproject.io/docs/commands/kv/delete
func (*VaultClient) Get ¶ added in v0.9.0
func (vc *VaultClient) Get(path string) (map[string]interface{}, error)
Get ...
func (*VaultClient) GetCredentials ¶
func (vc *VaultClient) GetCredentials(path string) (*config.Credentials, error)
GetCredentials receives the path and attemps to retrieve the map of credentials present on the Vault server.
func (*VaultClient) List ¶ added in v0.9.0
func (vc *VaultClient) List(path string) (interface{}, error)
List ...
func (*VaultClient) Patch ¶ added in v0.9.0
func (vc *VaultClient) Patch(path string, data map[string]interface{}) error
Patch ...
func (*VaultClient) Put ¶ added in v0.9.0
func (vc *VaultClient) Put(path string, data map[string]interface{}) error
Put ...
func (*VaultClient) StoreCredentials ¶
func (vc *VaultClient) StoreCredentials(path string, credentials map[string]string) error
StoreCredentials receives the path and the respective map of credentials and attempts to store them on the Vault server.
type VaultClientConfiguration ¶
type VaultClientConfiguration struct {
VaultURL string `envconfig:"VAULT_SERVER_URL" required:"true"`
}
VaultClientConfiguration is a struct that holds all the environment variables required to the Vault client
func (*VaultClientConfiguration) LoadFromEnvVars ¶
func (vlc *VaultClientConfiguration) LoadFromEnvVars() error
LoadFromEnvVars parses the required configuration variables. Throws an error if the validations aren't met