AWS
Index
AWS.DEFAULT_BACKENDAWS.AWSCredentialsAWS.AWSCredentialsAWS.AbstractBackendAWS.DownloadsBackendAWS.HTTPBackendAWS.JSONServiceAWS.QueryServiceAWS.RestJSONServiceAWS.RestXMLServiceAWS.aws_account_numberAWS.aws_get_profile_settingsAWS.aws_get_regionAWS.aws_user_arnAWS.check_credentialsAWS.credentials_from_webtokenAWS.dot_aws_configAWS.dot_aws_credentialsAWS.ec2_instance_credentialsAWS.ec2_instance_metadataAWS.ec2_instance_regionAWS.ecs_instance_credentialsAWS.env_var_credentialsAWS.global_aws_configAWS.global_aws_configAWS.localhost_is_ec2AWS.set_user_agentAWS.@service
Documentation
AWS.@service — Macro@service module_name feature=val...Include a high-level service wrapper based off of the module_name parameter optionally supplying a list of features.
When calling the macro you cannot match the predefined constant for the low-level API. The low-level API constants are named in all lowercase, and spaces replaced with underscores.
Examples:
using AWS.AWSServices: secrets_manager
using AWS: @service
# This matches the constant and will error!
@service secrets_manager
> ERROR: cannot assign a value to variable AWSServices.secrets_manager from module Main
# This does NOT match the filename structure and will error!
@service secretsmanager
> ERROR: could not open file /.julia/dev/AWS.jl/src/services/secretsmanager.jl
# All of the examples below are valid!
@service Secrets_Manager
@service SECRETS_MANAGER
@service sECRETS_MANAGER
# Using a feature
@service Secrets_Manager use_response_type = trueArguments
module_name::Symbol: Name of the module and service to include high-level API wrappers in your namespacefeatures=val...: A list of features to enable/disable for this high-level API include. SeeFeatureSetfor a list of available features.
Return
Expression: Module which embeds the high-level service API wrapper functions in your namespace
AWS.AWSCredentials — TypeAWSCredentialsWhen you interact with AWS, you specify your AWS Security Credentials to verify who you are and whether you have permission to access the resources that you are requesting. AWS uses the security credentials to authenticate and authorize your requests. The fields access_key_id and secret_key hold the access keys used to authenticate API requests (see Creating, Modifying, and Viewing Access Keys). Temporary Security Credentials require the extra session token field. The user_arn and account_number fields are used to cache the result of the aws_user_arn and aws_account_number functions.
AWS.jl searches for credentials in a series of possible locations and stops as soon as it finds credentials. The order of precedence for this search is as follows:
- Passing credentials directly to the
AWSCredentialsconstructor - Environment variables
- Shared credential file (~/.aws/credentials)
- AWS config file (~/.aws/config)
- Assume Role provider via the aws config file
- Instance metadata service on an Amazon EC2 instance that has an IAM role configured
Once the credentials are found, the method by which they were accessed is stored in the renew field and the DateTime at which they will expire is stored in the expiry field. This allows the credentials to be refreshed as needed using check_credentials. If renew is set to nothing, no attempt will be made to refresh the credentials. Any renewal function is expected to return nothing on failure or a populated AWSCredentials object on success. The renew field of the returned AWSCredentials will be discarded and does not need to be set.
To specify the profile to use from ~/.aws/credentials, do, for example, AWSCredentials(profile="profile-name").
AWS.AWSCredentials — MethodAWSCredentials(; profile=nothing) -> Union{AWSCredentials, Nothing}Create an AWSCredentials object, given a provided profile (if not provided "default" will be used).
Checks credential locations in the order: 1. Environment Variables 2. ~/.aws/credentials 3. ~/.aws/config 4. EC2 or ECS metadata
Keywords
profile::AbstractString: Specific profile used to search for AWSCredentials
Throws
error("Can't find AWS Credentials"): AWSCredentials could not be found
AWS.JSONService — Type(service::JSONService)(
operation::String, args::AbstractDict{String, <:Any}=Dict{String, Any}();
aws_config::AbstractAWSConfig=aws_config
)Perform a JSON request to AWS.
Arguments
operation::String: Name of the operation to performargs::AbstractDict{String, <:Any}: Additional arguments to be included in the request
Keywords
aws_config::AbstractAWSConfig: AWSConfig containing credentials and other information for fulfilling the request, default value is the global configurationfeature_set::FeatureSet: Specifies opt-in functionality for this specific API call.
Returns
TupleorDict: Ifreturn_headersis passed in throughargsa Tuple containing the headers and response will be returned, otherwise just aDict
AWS.QueryService — Type(service::QueryService)(
operation::String, args::AbstractDict{String, <:Any}=Dict{String, Any}();
aws_config::AbstractAWSConfig=aws_config
)Perform a Query request to AWS.
Arguments
operation::String:args::AbstractDict{String, <:Any}: Additional arguments to be included in the request
Keywords
aws_config::AbstractAWSConfig: AWSConfig containing credentials and other information for fulfilling the request, default value is the global configurationfeature_set::FeatureSet: Specifies opt-in functionality for this specific API call.
Returns
TupleorDict: Ifreturn_headersis passed in throughargsa Tuple containing the headers and response will be returned, otherwise just aDict
AWS.RestJSONService — Type(service::RestJSONService)(
request_method::String, request_uri::String, args::AbstractDict{String, <:Any}=Dict{String, String}();
aws_config::AbstractAWSConfig=aws_config
)Perform a RestJSON request to AWS.
Arguments
request_method::String: RESTful request type, e.g.:GET,HEAD,PUT, etc.request_uri::String: AWS URI for the endpointargs::AbstractDict{String, <:Any}: Additional arguments to be included in the request
Keywords
aws_config::AbstractAWSConfig: AWSConfig containing credentials and other information for fulfilling the request, default value is the global configurationfeature_set::FeatureSet: Specifies opt-in functionality for this specific API call.
Returns
TupleorDict: Ifreturn_headersis passed in throughargsa Tuple containing the headers and response will be returned, otherwise just aDict
AWS.RestXMLService — Type(service::RestXMLService)(
request_method::String, request_uri::String, args::AbstractDict{String, <:Any}=Dict{String, String}();
aws_config::AbstractAWSConfig=aws_config
)Perform a RestXML request to AWS.
Arguments
request_method::String: RESTful request type, e.g.:GET,HEAD,PUT, etc.request_uri::String: AWS URI for the endpointargs::AbstractDict{String, <:Any}: Additional arguments to be included in the request
Keywords
aws_config::AbstractAWSConfig: AWSConfig containing credentials and other information for fulfilling the request, default value is the global configurationfeature_set::FeatureSet: Specifies opt-in functionality for this specific API call.
Returns
TupleorDict: Ifreturn_headersis passed in throughargsa Tuple containing the headers and response will be returned, otherwise just aDict
AWS.aws_account_number — Methodaws_account_number(aws::AWSConfig) -> StringRetrieve the AWS account number from the AWSConfig, if not present query STS to update the AWS account number.
Arguments
aws::AWSConfig: AWSConfig used to retrieve the AWS account number
AWS.aws_get_profile_settings — Methodaws_get_profile_settings(profile::AbstractString, ini::Inifile) -> DictReturn a Dict containing all of the settings for the specified profile.
Arguments
profile::AbstractString: Profile to retrieve settings fromini::Inifile: Configuration file read the settings from
AWS.aws_get_region — Methodaws_get_region(; profile=nothing, config=nothing, default="us-east-1")Determine the current AWS region that should be used for AWS requests. The order of precedence mirrors what is used by the AWS CLI:
- Environmental variable: as specified by the
AWS_DEFAULT_REGIONenvironmental variable. - AWS configuration file:
regionas specified by theprofilein the configuration file, typically "~/.aws/config". - Default region: use the specified
default, typically "us-east-1".
Keywords
profile: Name of the AWS configuration profile, if any. Defaults tonothingwhich falls back to usingAWS._aws_get_profile()config: AWS configuration loaded as anInifileor a path to a configuration file. Defaults tonothingwhich falls back to usingdot_aws_config_file()default: The region to return if no high-precedence was found. Can be useful to set this tonothingif you want to know that no current AWS region was defined.
AWS.aws_user_arn — Methodaws_user_arn(aws::AWSConfig) -> StringRetrieve the User ARN from the AWSConfig, if not present query STS to update the user_arn.
Arguments
aws::AWSConfig: AWSConfig used to retrieve the user arn
AWS.check_credentials — Methodcheck_credentials(
aws_creds::AWSCredentials, force_refresh::Bool=false
) -> AWSCredentialsChecks current AWSCredentials, refreshing them if they are soon to expire. If force_refresh is true the credentials will be renewed immediately
Arguments
aws_creds::AWSCredentials: AWSCredentials to be checked / refreshed
Keywords
force_refresh::Bool=false:trueto refresh the credentials
Throws
error("Can't find AWS credentials!"): If no credentials can be found
AWS.credentials_from_webtoken — Methodcredentials_from_webtoken()Assume role via web identity. https://docs.aws.amazon.com/cli/latest/userguide/cli-configure-role.html#cli-configure-role-oidc
AWS.dot_aws_config — Functiondot_aws_config(profile=nothing) -> Union{AWSCredential, Nothing}Retrieve AWSCredentials for the default or specified profile from the ~/.aws/config file. If this fails try to retrieve credentials from _aws_get_role(), otherwise return nothing
Arguments
profile: Specific profile used to get AWSCredentials, default isnothing
AWS.dot_aws_credentials — Functiondot_aws_credentials(profile=nothing) -> Union{AWSCredential, Nothing}Retrieve AWSCredentials from the ~/.aws/credentials file
Arguments
profile: Specific profile used to get AWSCredentials, default isnothing
AWS.ec2_instance_credentials — Methodec2_instance_credentials(profile::AbstractString) -> AWSCredentialsParse the EC2 metadata to retrieve AWSCredentials.
AWS.ec2_instance_metadata — Methodec2_instance_metadata(path::AbstractString) -> Union{String, Nothing}Retrieve the AWS EC2 instance metadata as a string using the provided path. If no instance metadata is available (typically due to not running within an EC2 instance) then nothing will be returned. See the AWS documentation for details on what metadata is available: https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ec2-instance-metadata.html
Arguments
path: The URI path to used to specify that metadata to return
AWS.ec2_instance_region — Methodec2_instance_region() -> Union{String, Nothing}Determine the AWS region of the machine executing this code if running inside of an EC2 instance, otherwise nothing is returned.
AWS.ecs_instance_credentials — Methodecs_instance_credentials() -> Union{AWSCredential, Nothing}Retrieve credentials from the local endpoint. Return nothing if not running on an ECS instance.
More information can be found at: https://docs.aws.amazon.com/AmazonECS/latest/developerguide/task-iam-roles.html
Returns
AWSCredentials: AWSCredentials fromECScredentials URI,nothingif the Env Var is not set (not running on an ECS container instance)
Throws
StatusError: If the response status is >= 300ParsingError: Invalid HTTP request target
AWS.env_var_credentials — Methodenv_var_credentials() -> Union{AWSCredential, Nothing}Use AWS environmental variables (e.g. AWSACCESSKEYID, AWSSECRETACCESSKEY, etc.) to create AWSCredentials.
AWS.global_aws_config — Methodglobal_aws_config(config::AbstractAWSConfig)Set the global AWSConfig.
Arguments
config::AWSConfig: The AWSConfig to set in the global state
Returns
AWSConfig: Global AWSConfig
AWS.global_aws_config — Methodglobal_aws_config()Retrieve the global AWS configuration. If one is not set, create one with default configuration options.
Keywords
kwargs...: AWSConfig kwargs to be passed along if the global configuration is not already set
Returns
AWSConfig: The global AWS configuration
AWS.localhost_is_ec2 — Methodlocalhost_is_ec2() -> BoolDetermine if the machine executing this code is running on an EC2 instance.
AWS.set_user_agent — Methodset_user_agent(new_user_agent::String)Set the global user agent when making HTTP requests.
Arguments
new_user_agent::String: User agent to set when making HTTP requests
Return
String: The global user agent