Documentation ¶
Index ¶
- Constants
- Variables
- func NewDefaultCredentialStoreFactory() *build.Factory
- type CredentialParams
- func NewCredentialParams(values map[string]string) *CredentialParams
- func NewCredentialParamsFromConfig(config *config.ConfigParams) *CredentialParams
- func NewCredentialParamsFromMaps(maps ...map[string]string) *CredentialParams
- func NewCredentialParamsFromString(line string) *CredentialParams
- func NewCredentialParamsFromTuples(tuples ...any) *CredentialParams
- func NewCredentialParamsFromTuplesArray(tuples []any) *CredentialParams
- func NewCredentialParamsFromValue(value any) *CredentialParams
- func NewEmptyCredentialParams() *CredentialParams
- func NewManyCredentialParamsFromConfig(config *config.ConfigParams) []*CredentialParams
- func (c *CredentialParams) AccessId() string
- func (c *CredentialParams) AccessKey() string
- func (c *CredentialParams) Password() string
- func (c *CredentialParams) SetAccessId(value string)
- func (c *CredentialParams) SetAccessKey(value string)
- func (c *CredentialParams) SetPassword(value string)
- func (c *CredentialParams) SetStoreKey(value string)
- func (c *CredentialParams) SetUsername(value string)
- func (c *CredentialParams) StoreKey() string
- func (c *CredentialParams) UseCredentialStore() bool
- func (c *CredentialParams) Username() string
- type CredentialResolver
- func (c *CredentialResolver) Add(credential *CredentialParams)
- func (c *CredentialResolver) Configure(ctx context.Context, config *config.ConfigParams)
- func (c *CredentialResolver) GetAll() []*CredentialParams
- func (c *CredentialResolver) Lookup(ctx context.Context, correlationId string) (*CredentialParams, error)
- func (c *CredentialResolver) SetReferences(ctx context.Context, references refer.IReferences)
- type ICredentialStore
- type MemoryCredentialStore
- func (c *MemoryCredentialStore) Configure(ctx context.Context, config *config.ConfigParams)
- func (c *MemoryCredentialStore) Lookup(ctx context.Context, correlationId string, key string) (result *CredentialParams, err error)
- func (c *MemoryCredentialStore) ReadCredentials(config *config.ConfigParams)
- func (c *MemoryCredentialStore) Store(ctx context.Context, correlationId string, key string, ...) error
Constants ¶
const ( CredentialsParamSectionKey string = "credentials" CredentialParamSectionKey string = "credential" CredentialParamStoreKey string = "store_key" CredentialParamUsername string = "username" CredentialParamUser string = "user" CredentialParamPassword string = "password" CredentialParamPass string = "pass" CredentialParamAccessId string = "access_id" CredentialParamClientId string = "client_id" CredentialParamAccessKey string = "access_key" CredentialParamClientKey string = "client_key" CredentialParamSecretKey string = "secret_key" )
Variables ¶
var MemoryCredentialStoreDescriptor = refer.NewDescriptor(
"pip-services",
"credential-store",
"memory",
"*",
"1.0",
)
MemoryCredentialStoreDescriptor Creates ICredentialStore components by their descriptors.
Functions ¶
func NewDefaultCredentialStoreFactory ¶
NewDefaultCredentialStoreFactory create a new instance of the factory.
Returns: *build.Factory
Types ¶
type CredentialParams ¶
type CredentialParams struct {
*config.ConfigParams
}
CredentialParams contains credentials to authenticate against external services. They are used together with connection parameters, but usually stored in a separate store, protected from unauthorized access.
Configuration parameters store_key: key to retrieve parameters from credential store username: user name user: alternative to username password: user password pass: alternative to password access_id: application access id client_id: alternative to access_id access_key: application secret key client_key: alternative to access_key secret_key: alternative to access_key
In addition to standard parameters CredentialParams may contain any number of custom parameters see config.ConfigParams see ConnectionParams see CredentialResolver see ICredentialStore
Example: credential := NewCredentialParamsFromTuples( "user", "jdoe", "pass", "pass123", "pin", "321" ); username := credential.Username(); // Result: "jdoe" password := credential.Password(); // Result: "pass123"
func NewCredentialParams ¶
func NewCredentialParams(values map[string]string) *CredentialParams
NewCredentialParams creates a new credential parameters and fills it with values.
Parameters: - values map[string]string an object to be converted into key-value pairs to initialize these credentials. Returns: *CredentialParams
func NewCredentialParamsFromConfig ¶
func NewCredentialParamsFromConfig(config *config.ConfigParams) *CredentialParams
NewCredentialParamsFromConfig кetrieves a single CredentialParams from configuration parameters from "credential" section. If "credentials" section is present instead, then is returns only the first credential element.
Parameters: - config *config.ConfigParams, containing a section named "credential(s)". Returns []*CredentialParams the generated CredentialParams object.
func NewCredentialParamsFromMaps ¶
func NewCredentialParamsFromMaps(maps ...map[string]string) *CredentialParams
NewCredentialParamsFromMaps static method for creating a CredentialParams using the maps passed as parameters.
Parameters: - maps ...map[string]string the maps passed to this method to create a StringValueMap with. Returns: *CredentialParams the CredentialParams created.
func NewCredentialParamsFromString ¶
func NewCredentialParamsFromString(line string) *CredentialParams
NewCredentialParamsFromString creates a new CredentialParams object filled with key-value pairs serialized as a string.
Parameters: - line string a string with serialized key-value pairs as "key1=value1;key2=value2;..." Example: "Key1=123;Key2=ABC;Key3=2016-09-16T00:00:00.00Z" Returns: *CredentialParams a new CredentialParams object.
func NewCredentialParamsFromTuples ¶
func NewCredentialParamsFromTuples(tuples ...any) *CredentialParams
NewCredentialParamsFromTuples creates a new CredentialParams object filled with provided key-value pairs called tuples. Tuples parameters contain a sequence of key1, value1, key2, value2, ... pairs.
Parameters: - tuples ...any the tuples to fill a new CredentialParams object. Returns: *CredentialParams a new CredentialParams object.
func NewCredentialParamsFromTuplesArray ¶
func NewCredentialParamsFromTuplesArray(tuples []any) *CredentialParams
NewCredentialParamsFromTuplesArray static method for creating a CredentialParams from an array of tuples.
Parameters: - tuples []any the key-value tuples array to initialize the new StringValueMap with. Returns: CredentialParams the CredentialParams created and filled by the 'tuples' array provided.
func NewCredentialParamsFromValue ¶
func NewCredentialParamsFromValue(value any) *CredentialParams
NewCredentialParamsFromValue method that creates a ConfigParams object based on the values that are stored in the 'value' object's properties.
Parameters: - value any configuration parameters in the form of an object with properties. Returns: *ConfigParams generated ConfigParams.
func NewEmptyCredentialParams ¶
func NewEmptyCredentialParams() *CredentialParams
NewEmptyCredentialParams creates a new credential parameters and fills it with values.
Returns: *CredentialParams
func NewManyCredentialParamsFromConfig ¶
func NewManyCredentialParamsFromConfig(config *config.ConfigParams) []*CredentialParams
NewManyCredentialParamsFromConfig retrieves all CredentialParams from configuration parameters from "credentials" section. If "credential" section is present instead, then it returns a list with only one CredentialParams.
Parameters: - config *config.ConfigParams a configuration parameters to retrieve credentials Returns: []*CredentialParams a list of retrieved CredentialParams
func (*CredentialParams) AccessId ¶
func (c *CredentialParams) AccessId() string
AccessId gets the application access id. The value can be stored in parameters "access_id" pr "client_id"
Returns: string the application access id.
func (*CredentialParams) AccessKey ¶
func (c *CredentialParams) AccessKey() string
AccessKey the application secret key. The value can be stored in parameters "access_key", "client_key" or "secret_key".
ReturnsЖ string the application secret key.
func (*CredentialParams) Password ¶
func (c *CredentialParams) Password() string
Password get the user password. The value can be stored in parameters "password" or "pass".
Returns: string the user password.
func (*CredentialParams) SetAccessId ¶
func (c *CredentialParams) SetAccessId(value string)
SetAccessId sets the application access id.
Parameters: value: string a new application access id.
func (*CredentialParams) SetAccessKey ¶
func (c *CredentialParams) SetAccessKey(value string)
SetAccessKey sets the application secret key.
Parameters: value string a new application secret key.
func (*CredentialParams) SetPassword ¶
func (c *CredentialParams) SetPassword(value string)
SetPassword sets the user password.
Parameters: value string a new user password.
func (*CredentialParams) SetStoreKey ¶
func (c *CredentialParams) SetStoreKey(value string)
SetStoreKey sets the key to retrieve these parameters from CredentialStore.
Parameters: value string a new key to retrieve credentials.
func (*CredentialParams) SetUsername ¶
func (c *CredentialParams) SetUsername(value string)
SetUsername sets the user name.
Parameters: value string a new user name.
func (*CredentialParams) StoreKey ¶
func (c *CredentialParams) StoreKey() string
StoreKey gets the key to retrieve these credentials from CredentialStore. If this key is null, then all parameters are already present.
Returns: string the store key to retrieve credentials.
func (*CredentialParams) UseCredentialStore ¶
func (c *CredentialParams) UseCredentialStore() bool
UseCredentialStore сhecks if these credential parameters shall be retrieved from CredentialStore. The credential parameters are redirected to CredentialStore when store_key parameter is set.
Returns: bool true if credentials shall be retrieved from CredentialStore
func (*CredentialParams) Username ¶
func (c *CredentialParams) Username() string
Username gets the user name. The value can be stored in parameters "username" or "user".
Returns: string the user name.
type CredentialResolver ¶
type CredentialResolver struct {
// contains filtered or unexported fields
}
CredentialResolver helper class to retrieve component credentials. If credentials are configured to be retrieved from ICredentialStore, it automatically locates ICredentialStore in component references and retrieve credentials from there using store_key parameter.
Configuration parameters: credential: store_key: (optional) a key to retrieve the credentials from ICredentialStore ... other credential parameters credentials: alternative to credential [credential params 1]: first credential parameters ... credential parameters for key 1 ... [credential params N]: Nth credential parameters ... credential parameters for key N References: *:credential-store:*:*:1.0 (optional) Credential stores to resolve credentials
see CredentialParams see ICredentialStore
Example: config := NewConfigParamsFromTuples( "credential.user", "jdoe", "credential.pass", "pass123" ); credentialResolver := NewCredentialResolver(); credentialResolver.Configure(context.Background(), config); credentialResolver.SetReferences(context.Background(), references); credentialResolver.Lookup("123", (err, credential) => { // Now use credential... });
func NewCredentialResolver ¶
func NewCredentialResolver(ctx context.Context, config *config.ConfigParams, references refer.IReferences) *CredentialResolver
NewCredentialResolver creates a new instance of credentials resolver.
Parameters: - ctx context.Context - config *config.ConfigParams component configuration parameters - references refer.IReferences component references Returns: *CredentialResolver
func NewEmptyCredentialResolver ¶
func NewEmptyCredentialResolver() *CredentialResolver
NewEmptyCredentialResolver creates a new instance of credentials resolver.
Returns: *CredentialResolver
func (*CredentialResolver) Add ¶
func (c *CredentialResolver) Add(credential *CredentialParams)
Add a new credential to component credentials
Parameters: - credential *CredentialParams new credential parameters to be added
func (*CredentialResolver) Configure ¶
func (c *CredentialResolver) Configure(ctx context.Context, config *config.ConfigParams)
Configure configures component by passing configuration parameters.
Parameters: - config *config.ConfigParams configuration parameters to be set.
func (*CredentialResolver) GetAll ¶
func (c *CredentialResolver) GetAll() []*CredentialParams
GetAll gets all credentials configured in component configuration. Redirect to CredentialStores is not done at this point. If you need fully fleshed credential use lookup method instead.
Returns: []*CredentialParams a list with credential parameters
func (*CredentialResolver) Lookup ¶
func (c *CredentialResolver) Lookup(ctx context.Context, correlationId string) (*CredentialParams, error)
Lookup component credential parameters. If credentials are configured to be retrieved from Credential store it finds a ICredentialStore and lookups credentials there.
Parameters: - ctx context.Context - correlationId string (optional) transaction id to trace execution through call chain. Returns: *CredentialParams? error
func (*CredentialResolver) SetReferences ¶
func (c *CredentialResolver) SetReferences(ctx context.Context, references refer.IReferences)
SetReferences sets references to dependent components.
Parameters: - references refer.IReferences references to locate the component dependencies.
type ICredentialStore ¶
type ICredentialStore interface { // Store stores credential parameters into the store. Store(ctx context.Context, correlationId string, key string, credential *CredentialParams) error // Lookup lookups credential parameters by its key. Lookup(ctx context.Context, correlationId string, key string) (*CredentialParams, error) }
ICredentialStore Interface for credential stores which are used to store and lookup credentials to authenticate against external services.
type MemoryCredentialStore ¶
type MemoryCredentialStore struct {
// contains filtered or unexported fields
}
MemoryCredentialStore Credential store that keeps credentials in memory.
Configuration parameters: [credential key 1]: ... credential parameters for key 1 [credential key 2]: ... credential parameters for key N ...
see ICredentialStore see CredentialParams
Example: config := NewConfigParamsFromTuples( "key1.user", "jdoe", "key1.pass", "pass123", "key2.user", "bsmith", "key2.pass", "mypass" ); credentialStore := NewEmptyMemoryCredentialStore(); credentialStore.ReadCredentials(config); res, err := credentialStore.Lookup("123", "key1");
func NewEmptyMemoryCredentialStore ¶
func NewEmptyMemoryCredentialStore() *MemoryCredentialStore
NewEmptyMemoryCredentialStore creates a new instance of the credential store.
Returns: *MemoryCredentialStore
func NewMemoryCredentialStore ¶
func NewMemoryCredentialStore(ctx context.Context, config *config.ConfigParams) *MemoryCredentialStore
NewMemoryCredentialStore creates a new instance of the credential store.
Parameters: - ctx context.Context - config *config.ConfigParams configuration with credential parameters. Returns: *MemoryCredentialStore
func (*MemoryCredentialStore) Configure ¶
func (c *MemoryCredentialStore) Configure(ctx context.Context, config *config.ConfigParams)
Configure configures component by passing configuration parameters.
Parameters: - config *config.ConfigParams configuration parameters to be set.
func (*MemoryCredentialStore) Lookup ¶
func (c *MemoryCredentialStore) Lookup(ctx context.Context, correlationId string, key string) (result *CredentialParams, err error)
Lookup credential parameters by its key.
Parameters: - ctx context.Context. - correlationId string transaction id to trace execution through call chain. - key string a key to uniquely identify the credential parameters. Returns: result *CredentialParams, err error result of lookup and error message
func (*MemoryCredentialStore) ReadCredentials ¶
func (c *MemoryCredentialStore) ReadCredentials(config *config.ConfigParams)
ReadCredentials reads credentials from configuration parameters. Each section represents an individual CredentialParams
Parameters: - config *config.ConfigParams configuration parameters to be read
func (*MemoryCredentialStore) Store ¶
func (c *MemoryCredentialStore) Store(ctx context.Context, correlationId string, key string, credential *CredentialParams) error
Store credential parameters into the store.
Parameters: - ctx context.Context. - correlationId string transaction id to trace execution through call chain. - key string a key to uniquely identify the credential parameters. - credential *CredentialParams a credential parameters to be stored. Returns: error