connect

package
v1.1.2 Latest Latest
Warning

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

Go to latest
Published: Mar 2, 2023 License: MIT Imports: 9 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type AwsConnectionParams

type AwsConnectionParams struct {
	*cconf.ConfigParams
}

Contains connection parameters to authenticate against Amazon Web Services (AWS) and connect to specific AWS resource.

The struct is able to compose and parse AWS resource ARNs.

Configuration parameters

  • 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 AwsConnectionResolver

Example

connection := NewAwsConnectionParamsFromTuples(
    "region", "us-east-1",
    "access_id", "XXXXXXXXXXXXXXX",
    "secret_key", "XXXXXXXXXXXXXXX",
    "service", "s3",
    "bucket", "mybucket"
)

region := connection.Region()                     // Result: "us-east-1"
accessId := connection.AccessId()                 // Result: "XXXXXXXXXXXXXXX"
secretKey := connection.AccessKey()               // Result: "XXXXXXXXXXXXXXX"
pin := connection.GetAsNullableString("bucket")      // Result: "mybucket"

func NewAwsConnectionParams

func NewAwsConnectionParams(values map[string]string) *AwsConnectionParams

NewAwsConnectionParams creates an new instance of the connection parameters.

  • values (optional) an object to be converted into key-value pairs to initialize this connection.

func NewAwsConnectionParamsFromConfig

func NewAwsConnectionParamsFromConfig(config *cconf.ConfigParams) *AwsConnectionParams

Retrieves AwsConnectionParams from configuration parameters. The values are retrieves from "connection" and "credential" sections.

  • config configuration parameters

Returns the generated AwsConnectionParams object. See NewAwsConnectionParamsMergeConfigs

func NewAwsConnectionParamsFromString

func NewAwsConnectionParamsFromString(line string) *AwsConnectionParams

NewAwsConnectionParamsFromString creates a new AwsConnectionParams object filled with key-value pairs serialized as a string.

  • line 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 a new AwsConnectionParams object.

func NewAwsConnectionParamsMergeConfigs

func NewAwsConnectionParamsMergeConfigs(configs []*cconf.ConfigParams) *AwsConnectionParams

NewAwsConnectionParamsMergeConfigs retrieves AwsConnectionParams from multiple configuration parameters. The values are retrieves from "connection" and "credential" sections.

  • configs a list with configuration parameters

Returns the generated AwsConnectionParams object. See NewAwsConnectionParamsFromConfig

func NewEmptyAwsConnectionParams

func NewEmptyAwsConnectionParams() *AwsConnectionParams

NewEmptyAwsConnectionParams creates an new instance of the connection parameters.

func (*AwsConnectionParams) GetAccessId

func (c *AwsConnectionParams) GetAccessId() string

GetAccessId gets the AWS access id. Returns the AWS access id.

func (*AwsConnectionParams) GetAccessKey

func (c *AwsConnectionParams) GetAccessKey() string

GetAccessKey gets the AWS client key. Returns the AWS client key.

func (*AwsConnectionParams) GetAccount

func (c *AwsConnectionParams) GetAccount() string

GetAccount Gets the AWS account id. Returns the AWS account id.

func (*AwsConnectionParams) GetArn

func (c *AwsConnectionParams) GetArn() string

GetArn gets the AWS resource ARN. If the ARN is not defined it automatically generates it from other properties. Returns the AWS resource ARN.

func (*AwsConnectionParams) GetPartition

func (c *AwsConnectionParams) GetPartition() string

GetPartition Gets the AWS partition name. Returns the AWS partition name.

func (*AwsConnectionParams) GetRegion

func (c *AwsConnectionParams) GetRegion() string

GetRegion gets the AWS region. Returns the AWS region.

func (*AwsConnectionParams) GetResource

func (c *AwsConnectionParams) GetResource() string

GetResource gets the AWS resource id.

Returns the AWS resource id.

func (*AwsConnectionParams) GetResourceType

func (c *AwsConnectionParams) GetResourceType() string

GetResourceType gets the AWS resource type. Returns the AWS resource type.

func (*AwsConnectionParams) GetService

func (c *AwsConnectionParams) GetService() string

GetService gets the AWS service name. Returns the AWS service name.

func (*AwsConnectionParams) SetAccessId

func (c *AwsConnectionParams) SetAccessId(value string)

SetAccessId sets the AWS access id.

  • value the AWS access id.

func (*AwsConnectionParams) SetAccessKey

func (c *AwsConnectionParams) SetAccessKey(value string)

SetAccessKey sets the AWS client key.

  • value a new AWS client key.

func (*AwsConnectionParams) SetAccount

func (c *AwsConnectionParams) SetAccount(value string)

SetAccount Sets the AWS account id. - value the AWS account id.

func (*AwsConnectionParams) SetArn

func (c *AwsConnectionParams) SetArn(value string)

SetArn sets the AWS resource ARN. When it sets the value, it automatically parses the ARN and sets individual parameters.

  • value a new AWS resource ARN.

func (*AwsConnectionParams) SetPartition

func (c *AwsConnectionParams) SetPartition(value string)

SetPartition Sets the AWS partition name.

  • value a new AWS partition name.

func (*AwsConnectionParams) SetRegion

func (c *AwsConnectionParams) SetRegion(value string)

SetRegion Sets the AWS region.

  • value a new AWS region.

func (*AwsConnectionParams) SetResource

func (c *AwsConnectionParams) SetResource(value string)

SetResource sets the AWS resource id.

  • value a new AWS resource id.

func (*AwsConnectionParams) SetResourceType

func (c *AwsConnectionParams) SetResourceType(value string)

SetResourceType sets the AWS resource type.

  • value a new AWS resource type.

func (*AwsConnectionParams) SetService

func (c *AwsConnectionParams) SetService(value string)

SetService sets the AWS service name.

  • value a new AWS service name.

func (*AwsConnectionParams) Validate

func (c *AwsConnectionParams) Validate(correlationId string) *cerr.ApplicationError

Validates this connection parameters

  • correlationId (optional) transaction id to trace execution through call chain.

Returns a ConfigException or null if validation passed successfully.

type AwsConnectionResolver

type AwsConnectionResolver struct {
	// contains filtered or unexported fields
}

Helper class to retrieve AWS connection and credential parameters, validate them and compose a AwsConnectionParams value.

Configuration parameters

  • connections:
  • discovery_key: (optional) a key to retrieve the connection from IDiscovery
  • region: (optional) AWS region
  • partition: (optional) AWS partition
  • service: (optional) AWS service
  • resource_type: (optional) AWS resource type
  • resource: (optional) AWS resource id
  • arn: (optional) AWS resource ARN
  • credentials:
  • store_key: (optional) a key to retrieve the credentials from ICredentialStore
  • access_id: AWS access/client id
  • access_key: AWS access/client id

References

  • \*:discovery:\*:\*:1.0 (optional) IDiscovery services to resolve connections

  • \*:credential-store:\*:\*:1.0 (optional) Credential stores to resolve credentials

    See ConnectionParams (in the Pip.Services components package) See IDiscovery (in the Pip.Services components package)

    Example:

    config := NewConfigParamsFromTuples( "connection.region", "us-east1", "connection.service", "s3", "connection.bucket", "mybucket", "credential.access_id", "XXXXXXXXXX", "credential.access_key", "XXXXXXXXXX" );

    connectionResolver := NewAwsConnectionResolver() connectionResolver.Configure(context.Background(), config) connectionResolver.SetReferences(context.Background(), references)

    err, connection :=connectionResolver.Resolve("123") // Now use connection...

func NewAwsConnectionResolver

func NewAwsConnectionResolver() *AwsConnectionResolver

func (*AwsConnectionResolver) Configure

func (c *AwsConnectionResolver) Configure(ctx context.Context, config *cconf.ConfigParams)

Configures component by passing configuration parameters.

  • config configuration parameters to be set.

func (*AwsConnectionResolver) Resolve

func (c *AwsConnectionResolver) Resolve(correlationId string) (connection *AwsConnectionParams, err error)

Resolves connection and credental parameters and generates a single AWSConnectionParams value.

  • correlationId (optional) transaction id to trace execution through call chain.

Returns: AwsConnectionParams connection aprmeters and error. See IDiscovery (in the Pip.Services components package)

func (*AwsConnectionResolver) SetReferences

func (c *AwsConnectionResolver) SetReferences(ctx context.Context, references cref.IReferences)

Sets references to dependent components.

  • references references to locate the component dependencies.

Jump to

Keyboard shortcuts

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