Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Fixed orphaned link.
Div
stylefloat:left

AWS Credentials Variables task

You can use the AWS Credentials Variables task to provide managed temporary AWS security credentials for other tools by injecting them into AWS unaware tasks like the Bamboo Script task. This improves versatility for using tools that are not directly integrated with Identity Federation for AWS, but accept AWS credentials via the command line or , environment variables or the Bamboo task configuration interface.

Include Page
_TasksForAWSNote
_TasksForAWSNote

 


Panel
borderColor#bbb
bgColor#eeeeee

On this page:

Table of Contents
exclude(Popular.*|Recent.*)

Panel
borderColor#bbb
bgColor#eeeeee

Related Pages:

Configuration

Tip
titleAddress limitations with the AWS CLI

The most frequent use case for the AWS Credentials Variables task is to address scenarios not (yet) covered by dedicated tasks, see How to work around limitations with the AWS Command Line Interface (AWS CLI) for details.

To configure an AWS Credentials Variables task:

  1. Navigate to the Tasks configuration tab for the job (this will be the default job if creating a new plan).
  2. Click the name of an existing AWS Credentials Variables task, or click Add Task and then AWS Credentials Variables to create a new task.


Complete the following settings:

Task Description (Optional) Identify the purpose of the task.
Disable this task

Check, or clear, to selectively run this task.

SourceSelect the AWS Credentials Source (see below). Can be either Identity Federation for AWS or an IAM Role for EC2.
Connector

(Conditional) Select the shared Identity Federation for AWS Connector. Alternatively, select [Use connector variable ...] to supply the connector dynamically via Bamboo variables (needs to be a connector id such as f24e81bc-7aff-42db-86a2-7cf82e24d871) - refer to How to parametrize the AWS connector via a Bamboo variable for details.

Role ARN(Conditional | Optional) Specify the ARN of another role that the agent's IAM role for EC2 should assume.

AWS Credentials Sources

You currently have two option to provide AWS Security Credentials:

Identity Federation for AWS

Tip
titleFederated Amazon Web Services access

This is the recommended approach to share and manage AWS credentials:

  • It provides benefits like easy credentials sharing and reuse, fine grained access control for AWS resources, strong encryption and more.

Image RemovedRefer to the Administrator's Guide for details on how to configure the connectors.

  • (info) this option requires at least one AWS Connector to be configured with System Scope to allow usage from Bamboo builds, where no user session is available
  • a connector yields a set of temporary credentials on task execution (optionally limiting the IAM permissions)
  • you can configure multiple connectors to provide credentials with different IAM permissions tailored for specific use cases

IAM Role for EC2 (Agent)

You can use IAM Roles for Amazon EC2 to optionally skip credentials configuration all together: if an agent happens to run on an EC2 instance started with an instance profile (IAM role), the tasks can be configured to facilitate those credentials. Of course, the underlying IAM role needs to have a sufficient policy attached to grant the the required permissions for the task at hand.

Image RemovedThis feature requires the Amazon EC2 instance running the agent to be started with an EC2 instance profile. There are three different scenarios:

  • local agents - requires the hosting Bamboo server itself to run on EC2
  • remote/elastic agents - requires the remote agent to run on EC2
  • elastic agents - requires the elastic agent to run on EC2(warning) Elastic Bamboo only supports configuring elastic images with an instance profile as of Bamboo 5.6.
    Tip
    titleIAM Policy

    The AWS Credentials Variables task requires IAM permissions to retrieve temporary security credentials via the AWS Security Token Service (STS) - an all-encompassing policy look as follows:

    Code Block
    languagejs
    collapsetrue
    {
        "Version": "2012-10-17",
        "Statement": [
            {
                "Effect": "Allow",
                "Action": [
                    "sts:AssumeRole",
                    "sts:GetFederationToken",
                    "sts:GetSessionToken"
                ],
                "Resource": [
                    "*"
                ]
            }
        ]
    }

    (info) Refer to Granting Permissions to Create Temporary Security Credentials for details on how to create more granular/secure policies, for example:

    • you can remove permissions for unused principal types.
    • you can further restrict permissions via more specific resource declarations

    You have the following options to provide AWS Security Credentials:

    Include Page
    _IdentityFederationForAWSConnector
    _IdentityFederationForAWSConnector

    Include Page
    _IAMRolesForEC2
    _IAMRolesForEC2

    Usage

    Bamboo variables


    This task generates the following Bamboo variables for reuse in subsequent tasks without native integration with Identity Federation for AWS:

    Code Block
    languagebash
    titleBamboo variables
    ${bamboo.custom.aws.accessKeyId}
    ${bamboo.custom.aws.secretAccessKey.password}
    ${bamboo.custom.aws.sessionToken.password}
    
    • (info) The '*.password' suffix ensures that these sensitive variables are masked with asterisks ('*******') in the Bamboo build log.

    An alternative representation as a JSON object for automated processing with tools like jq is available too:

    Code Block
    languagebash
    titleBamboo variables (alternative representations)
    ${bamboo.custom.aws.credentials.json.password}

    Environment variables

    Aforementioned variables will also be available as environment variables for use in Bamboo Script tasks. The syntax differs between shells, as illustrated in these examples for assigning them to the standardized variables used by tools like the AWS Command Line Interface (AWS CLI):

    Code Block
    languagebash
    titleBash (Unix shell)
    export AWS_ACCESS_KEY_ID=$bamboo_custom_aws_accessKeyId
    export AWS_SECRET_ACCESS_KEY=$bamboo_custom_aws
    .
    _secretAccessKey_password
    export AWS_SESSION_TOKEN=$bamboo_custom_aws_sessionToken_password
    Code Block
    languagepowershell
    titlePowerShell
    $AWS_ACCESS_KEY_ID = $bamboo_custom_aws_accessKeyId
    $AWS_SECRET_ACCESS_KEY = $bamboo_custom_aws_secretAccessKey_password
    $AWS_SESSION_TOKEN = $bamboo_custom_aws_sessionToken_password
    Code Block
    languagediff
    title Windows Command Prompt (cmd)
    set AWS_ACCESS_KEY_ID=%bamboo_custom_aws_accessKeyId%
    set AWS_SECRET_ACCESS_KEY=%bamboo_custom_aws_secretAccessKey_password%
    set AWS_SESSION_TOKEN=%bamboo_custom_aws_sessionToken_password%
     


    How-to Articles

    Filter by label (Content by label)
    max8
    showSpacefalse
    sorttitle
    excerptTypesimple
    cqllabel in ("aws-cli","aws-iam","variables")

    Frequently Asked Questions (FAQ)

    Questionslist macro
    filter

    recent

    popular
    asktrue
    limit8
    topicaws-credentials