cloud

package
v1.113.0 Latest Latest
Warning

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

Go to latest
Published: Nov 8, 2024 License: Apache-2.0 Imports: 2 Imported by: 0

Documentation

Index

Constants

View Source
const (
	// InitialStatus is the zero value of CloudConnectionStatus and means that cloud connection is untested. Once
	// CloudConnection Status has been changed in should not return to this value. This status is assigned on creation
	// to the cloud provider
	InitialStatus ConnectionStatus = "No Connection"

	// InvalidConfiguration means that Cloud Configuration is missing required values to connect to cloud provider.
	// This status is assigned during failures in the provider implementation of getCloudConfig()
	InvalidConfiguration = "Invalid Configuration"

	// FailedConnection means that all required Cloud Configuration values are filled in, but a connection with the
	// Cloud Provider cannot be established. This is indicative of a typo in one of the Cloud Configuration values or an
	// issue in how the connection was set up in the Cloud Provider's Console. The assignment of this status varies
	// between implementations, but should happen if an error is thrown when an interaction with an object from
	// the Cloud Service Provider's sdk occurs.
	FailedConnection = "Failed Connection"

	// ParseError indicates an issue with our functions which parse responses
	ParseError = "Parse Error"

	// MissingData means that the Cloud Integration is properly configured, but the cloud provider is not returning
	// billing/cost and usage data. This status is indicative of the billing/cost and usage data export of the Cloud Provider
	// being incorrectly set up or the export being set up in the last 48 hours and not having started populating data yet.
	// This status is set when a query has been successfully made but the results come back empty. If the cloud provider,
	// already has a SUCCESSFUL_CONNECTION status then this status should not be set, because this indicates that the specific
	// query made may have been empty.
	MissingData = "Data Missing"

	// SuccessfulConnection means that the Cloud Integration is properly configured and returning data. This status is
	// set on any successful query where data is returned
	SuccessfulConnection = "Connection Successful"
)
View Source
const AuthorizerTypeProperty = "authorizerType"

AuthorizerTypeProperty is the property where the id of an Authorizer should be placed in its custom MarshalJSON function

View Source
const Redacted = "REDACTED"

Variables

This section is empty.

Functions

func AuthorizerFromInterface added in v1.108.0

func AuthorizerFromInterface[T Authorizer](f any, authSelectFn AuthorizerSelectorFn[T]) (T, error)

AuthorizerFromInterface this generic function provides Authorizer unmarshalling for all providers

func GetInterfaceValue added in v1.108.0

func GetInterfaceValue[T any](fmap map[string]interface{}, key string) (T, error)

Types

type Authorizer added in v1.108.0

type Authorizer interface {
	Config
	json.Marshaler
}

type AuthorizerSelectorFn added in v1.108.0

type AuthorizerSelectorFn[T Authorizer] func(string) (T, error)

AuthorizerSelectorFn implementations of this function should be a simple switch and acts as a register for the Authorizer types, returned Authorizer should be empty except for its default type property and will have other values marshalled into it

type Config added in v1.108.0

type Config interface {
	Validate() error
	Sanitize() Config
	Equals(Config) bool
}

Config allows for nested configurations which encapsulate their functionality to be validated and compared easily

type ConnectionStatus added in v1.104.0

type ConnectionStatus string

ConnectionStatus communicates the status of a cloud connection in a way that is general enough to apply to each Cloud Provider, but still give actionable information on how to trouble shoot one the four failing statuses.

func (ConnectionStatus) String added in v1.104.0

func (cs ConnectionStatus) String() string

type EmptyChecker added in v1.104.0

type EmptyChecker interface {
	IsEmpty() bool
}

EmptyChecker provides an interface for to check if a result is empty which can be useful for setting a MissingData status

type KeyedConfig added in v1.108.0

type KeyedConfig interface {
	Config
	Key() string
	Provider() string
}

KeyedConfig is a top level Config which uses its public values as a unique identifier allowing duplicates to be identified

type KeyedConfigWatcher added in v1.108.0

type KeyedConfigWatcher interface {
	GetConfigs() []KeyedConfig
}

Directories

Path Synopsis

Jump to

Keyboard shortcuts

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