You are viewing documentation for version 2 of the AWS SDK for Ruby. Version 3 documentation can be found here.
Class: Aws::AppConfig::Client
- Inherits:
-
Seahorse::Client::Base
- Object
- Seahorse::Client::Base
- Aws::AppConfig::Client
- Defined in:
- (unknown)
Overview
An API client for Amazon AppConfig. To construct a client, you need to configure a :region
and :credentials
.
appconfig = Aws::AppConfig::Client.new(
region: region_name,
credentials: credentials,
# ...
)
See #initialize for a full list of supported configuration options.
Region
You can configure a default region in the following locations:
ENV['AWS_REGION']
Aws.config[:region]
Go here for a list of supported regions.
Credentials
Default credentials are loaded automatically from the following locations:
ENV['AWS_ACCESS_KEY_ID']
andENV['AWS_SECRET_ACCESS_KEY']
Aws.config[:credentials]
- The shared credentials ini file at
~/.aws/credentials
(more information) - From an instance profile when running on EC2
You can also construct a credentials object from one of the following classes:
Alternatively, you configure credentials with :access_key_id
and
:secret_access_key
:
# load credentials from disk
creds = YAML.load(File.read('/path/to/secrets'))
Aws::AppConfig::Client.new(
access_key_id: creds['access_key_id'],
secret_access_key: creds['secret_access_key']
)
Always load your credentials from outside your application. Avoid configuring credentials statically and never commit them to source control.
Instance Attribute Summary
Attributes inherited from Seahorse::Client::Base
Constructor collapse
-
#initialize(options = {}) ⇒ Aws::AppConfig::Client
constructor
Constructs an API client.
API Operations collapse
-
#create_application(options = {}) ⇒ Types::Application
An application in AppConfig is a logical unit of code that provides capabilities for your customers.
-
#create_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Information that enables AppConfig to access the configuration source.
-
#create_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
A deployment strategy defines important criteria for rolling out your configuration to the designated targets.
-
#create_environment(options = {}) ⇒ Types::Environment
For each application, you define one or more environments.
-
#create_hosted_configuration_version(options = {}) ⇒ Types::HostedConfigurationVersion
Create a new configuration in the AppConfig configuration store.
.
-
#delete_application(options = {}) ⇒ Struct
Delete an application.
-
#delete_configuration_profile(options = {}) ⇒ Struct
Delete a configuration profile.
-
#delete_deployment_strategy(options = {}) ⇒ Struct
Delete a deployment strategy.
-
#delete_environment(options = {}) ⇒ Struct
Delete an environment.
-
#delete_hosted_configuration_version(options = {}) ⇒ Struct
Delete a version of a configuration from the AppConfig configuration store.
.
-
#get_application(options = {}) ⇒ Types::Application
Retrieve information about an application.
.
-
#get_configuration(options = {}) ⇒ Types::Configuration
Receive information about a configuration.
AWS AppConfig uses the value of the
ClientConfigurationVersion
parameter to identify the configuration version on your clients. -
#get_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Retrieve information about a configuration profile.
.
-
#get_deployment(options = {}) ⇒ Types::Deployment
Retrieve information about a configuration deployment.
.
-
#get_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
Retrieve information about a deployment strategy.
-
#get_environment(options = {}) ⇒ Types::Environment
Retrieve information about an environment.
-
#get_hosted_configuration_version(options = {}) ⇒ Types::HostedConfigurationVersion
Get information about a specific configuration version.
.
-
#list_applications(options = {}) ⇒ Types::Applications
List all applications in your AWS account.
.
-
#list_configuration_profiles(options = {}) ⇒ Types::ConfigurationProfiles
Lists the configuration profiles for an application.
.
-
#list_deployment_strategies(options = {}) ⇒ Types::DeploymentStrategies
List deployment strategies.
.
-
#list_deployments(options = {}) ⇒ Types::Deployments
Lists the deployments for an environment.
.
-
#list_environments(options = {}) ⇒ Types::Environments
List the environments for an application.
.
-
#list_hosted_configuration_versions(options = {}) ⇒ Types::HostedConfigurationVersions
View a list of configurations stored in the AppConfig configuration store by version.
.
-
#list_tags_for_resource(options = {}) ⇒ Types::ResourceTags
Retrieves the list of key-value tags assigned to the resource.
.
-
#start_deployment(options = {}) ⇒ Types::Deployment
Starts a deployment.
.
-
#stop_deployment(options = {}) ⇒ Types::Deployment
Stops a deployment.
-
#tag_resource(options = {}) ⇒ Struct
Metadata to assign to an AppConfig resource.
-
#untag_resource(options = {}) ⇒ Struct
Deletes a tag key and value from an AppConfig resource.
.
-
#update_application(options = {}) ⇒ Types::Application
Updates an application.
.
-
#update_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Updates a configuration profile.
.
-
#update_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
Updates a deployment strategy.
.
-
#update_environment(options = {}) ⇒ Types::Environment
Updates an environment.
.
-
#validate_configuration(options = {}) ⇒ Struct
Uses the validators in a configuration profile to validate a configuration.
.
Instance Method Summary collapse
-
#wait_until(waiter_name, params = {}) {|waiter| ... } ⇒ Boolean
Waiters polls an API operation until a resource enters a desired state.
-
#waiter_names ⇒ Array<Symbol>
Returns the list of supported waiters.
Methods inherited from Seahorse::Client::Base
add_plugin, api, #build_request, clear_plugins, define, new, #operation, #operation_names, plugins, remove_plugin, set_api, set_plugins
Methods included from Seahorse::Client::HandlerBuilder
#handle, #handle_request, #handle_response
Constructor Details
#initialize(options = {}) ⇒ Aws::AppConfig::Client
Constructs an API client.
Instance Method Details
#create_application(options = {}) ⇒ Types::Application
An application in AppConfig is a logical unit of code that provides capabilities for your customers. For example, an application can be a microservice that runs on Amazon EC2 instances, a mobile application installed by your users, a serverless application using Amazon API Gateway and AWS Lambda, or any system you run on behalf of others.
#create_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Information that enables AppConfig to access the configuration source. Valid configuration sources include Systems Manager (SSM) documents, SSM Parameter Store parameters, and Amazon S3 objects. A configuration profile includes the following information.
-
The Uri location of the configuration data.
-
The AWS Identity and Access Management (IAM) role that provides access to the configuration data.
-
A validator for the configuration data. Available validators include either a JSON Schema or an AWS Lambda function.
For more information, see Create a Configuration and a Configuration Profile in the AWS AppConfig User Guide.
#create_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
A deployment strategy defines important criteria for rolling out your configuration to the designated targets. A deployment strategy includes: the overall duration required, a percentage of targets to receive the deployment during each interval, an algorithm that defines how percentage grows, and bake time.
#create_environment(options = {}) ⇒ Types::Environment
For each application, you define one or more environments. An environment is a logical deployment group of AppConfig targets, such as applications in a Beta
or Production
environment. You can also define environments for application subcomponents such as the Web
, Mobile
and Back-end
components for your application. You can configure Amazon CloudWatch alarms for each environment. The system monitors alarms during a configuration deployment. If an alarm is triggered, the system rolls back the configuration.
#create_hosted_configuration_version(options = {}) ⇒ Types::HostedConfigurationVersion
Create a new configuration in the AppConfig configuration store.
#delete_application(options = {}) ⇒ Struct
Delete an application. Deleting an application does not delete a configuration from a host.
#delete_configuration_profile(options = {}) ⇒ Struct
Delete a configuration profile. Deleting a configuration profile does not delete a configuration from a host.
#delete_deployment_strategy(options = {}) ⇒ Struct
Delete a deployment strategy. Deleting a deployment strategy does not delete a configuration from a host.
#delete_environment(options = {}) ⇒ Struct
Delete an environment. Deleting an environment does not delete a configuration from a host.
#delete_hosted_configuration_version(options = {}) ⇒ Struct
Delete a version of a configuration from the AppConfig configuration store.
#get_application(options = {}) ⇒ Types::Application
Retrieve information about an application.
#get_configuration(options = {}) ⇒ Types::Configuration
Receive information about a configuration.
AWS AppConfig uses the value of the To avoid excess charges, we recommend that you include the ClientConfigurationVersion
parameter to identify the configuration version on your clients. If you don’t send ClientConfigurationVersion
with each call to GetConfiguration
, your clients receive the current configuration. You are charged each time your clients receive a configuration.ClientConfigurationVersion
value with every call to GetConfiguration
. This value must be saved on your client. Subsequent calls to GetConfiguration
must pass this value by using the ClientConfigurationVersion
parameter.
#get_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Retrieve information about a configuration profile.
#get_deployment(options = {}) ⇒ Types::Deployment
Retrieve information about a configuration deployment.
#get_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
Retrieve information about a deployment strategy. A deployment strategy defines important criteria for rolling out your configuration to the designated targets. A deployment strategy includes: the overall duration required, a percentage of targets to receive the deployment during each interval, an algorithm that defines how percentage grows, and bake time.
#get_environment(options = {}) ⇒ Types::Environment
Retrieve information about an environment. An environment is a logical deployment group of AppConfig applications, such as applications in a Production
environment or in an EU_Region
environment. Each configuration deployment targets an environment. You can enable one or more Amazon CloudWatch alarms for an environment. If an alarm is triggered during a deployment, AppConfig roles back the configuration.
#get_hosted_configuration_version(options = {}) ⇒ Types::HostedConfigurationVersion
Get information about a specific configuration version.
#list_applications(options = {}) ⇒ Types::Applications
List all applications in your AWS account.
#list_configuration_profiles(options = {}) ⇒ Types::ConfigurationProfiles
Lists the configuration profiles for an application.
#list_deployment_strategies(options = {}) ⇒ Types::DeploymentStrategies
List deployment strategies.
#list_deployments(options = {}) ⇒ Types::Deployments
Lists the deployments for an environment.
#list_environments(options = {}) ⇒ Types::Environments
List the environments for an application.
#list_hosted_configuration_versions(options = {}) ⇒ Types::HostedConfigurationVersions
View a list of configurations stored in the AppConfig configuration store by version.
#list_tags_for_resource(options = {}) ⇒ Types::ResourceTags
Retrieves the list of key-value tags assigned to the resource.
#start_deployment(options = {}) ⇒ Types::Deployment
Starts a deployment.
#stop_deployment(options = {}) ⇒ Types::Deployment
Stops a deployment. This API action works only on deployments that have a status of DEPLOYING
. This action moves the deployment to a status of ROLLED_BACK
.
#tag_resource(options = {}) ⇒ Struct
Metadata to assign to an AppConfig resource. Tags help organize and categorize your AppConfig resources. Each tag consists of a key and an optional value, both of which you define. You can specify a maximum of 50 tags for a resource.
#untag_resource(options = {}) ⇒ Struct
Deletes a tag key and value from an AppConfig resource.
#update_application(options = {}) ⇒ Types::Application
Updates an application.
#update_configuration_profile(options = {}) ⇒ Types::ConfigurationProfile
Updates a configuration profile.
#update_deployment_strategy(options = {}) ⇒ Types::DeploymentStrategy
Updates a deployment strategy.
#update_environment(options = {}) ⇒ Types::Environment
Updates an environment.
#validate_configuration(options = {}) ⇒ Struct
Uses the validators in a configuration profile to validate a configuration.
#wait_until(waiter_name, params = {}) {|waiter| ... } ⇒ Boolean
Waiters polls an API operation until a resource enters a desired state.
Basic Usage
Waiters will poll until they are succesful, they fail by entering a terminal state, or until a maximum number of attempts are made.
# polls in a loop, sleeping between attempts client.waiter_until(waiter_name, params)
Configuration
You can configure the maximum number of polling attempts, and the delay (in seconds) between each polling attempt. You configure waiters by passing a block to #wait_until:
# poll for ~25 seconds
client.wait_until(...) do |w|
w.max_attempts = 5
w.delay = 5
end
Callbacks
You can be notified before each polling attempt and before each
delay. If you throw :success
or :failure
from these callbacks,
it will terminate the waiter.
started_at = Time.now
client.wait_until(...) do |w|
# disable max attempts
w.max_attempts = nil
# poll for 1 hour, instead of a number of attempts
w.before_wait do |attempts, response|
throw :failure if Time.now - started_at > 3600
end
end
Handling Errors
When a waiter is successful, it returns true
. When a waiter
fails, it raises an error. All errors raised extend from
Waiters::Errors::WaiterFailed.
begin
client.wait_until(...)
rescue Aws::Waiters::Errors::WaiterFailed
# resource did not enter the desired state in time
end
#waiter_names ⇒ Array<Symbol>
Returns the list of supported waiters. The following table lists the supported waiters and the client method they call:
Waiter Name | Client Method | Default Delay: | Default Max Attempts: |
---|