clients

package
v0.7.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Jan 20, 2022 License: MIT Imports: 17 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

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) 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"`
	MasterName string   `envconfig:"REDIS_MASTER_NAME"`
	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) 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

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 {
	CreateDirectory(relativePath string) error
	RemoveDirectory(relativePath string) error
	CheckIfExists(relativePath string) bool
}

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(configuration VaultClientConfiguration, logger logging.Logger) (*VaultClient, error)

NewVaultClient returns an initialized struct with the required dependencies injected

func (*VaultClient) CheckIfEngineExists

func (vc *VaultClient) CheckIfEngineExists() 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) DeleteCredentials

func (vc *VaultClient) DeleteCredentials(datasourceName string) error

DeleteCredentials receives the name of the DataSource 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) GetCredentials

func (vc *VaultClient) GetCredentials(datasourceName string) (*config.Credentials, error)

GetCredentials receives the name of the DataSource and attemps to retrieve the map of credentials present on the Vault server.

func (*VaultClient) StoreCredentials

func (vc *VaultClient) StoreCredentials(datasourceName string, credentials map[string]string) error

StoreCredentials receives the name of the DataSource 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

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL