Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/cytopia/ansible-role-aws_account_match

Ansible safe-guard role to ensure you are currently using the correct AWS account(s)
https://github.com/cytopia/ansible-role-aws_account_match

ansible ansible-galaxy ansible-roles aws aws-account-management aws-cli

Last synced: 6 days ago
JSON representation

Ansible safe-guard role to ensure you are currently using the correct AWS account(s)

Awesome Lists containing this project

README

        

# Ansible AWS account match

The `aws_account_match` role let's you define one or more AWS accounts and ensures your playbook
is only provisioned against those accounts.

Include this role at the very top of any AWS relatated playbooks and it will act as a safeguard
by immediately aborting the whole play in case you are logged in with the wrong AWS account.

Boto profiles and environment variables are both supported.

[![Build Status](https://travis-ci.org/cytopia/ansible-role-aws_account_match.svg?branch=master)](https://travis-ci.org/cytopia/ansible-role-aws_account_match)
[![Ansible Galaxy](https://img.shields.io/ansible/role/d/40181.svg)](https://galaxy.ansible.com/cytopia/aws_account_match/)
[![Release](https://img.shields.io/github/release/cytopia/ansible-role-aws_account_match.svg)](https://github.com/cytopia/ansible-role-aws_account_match/releases)

---

## Installation

Ensure [aws-cli](https://docs.aws.amazon.com/cli/latest/userguide/installing.html) is installed locally:

```bash
$ pip install awscli
```

Either use [Ansible Galaxy](https://galaxy.ansible.com/cytopia/aws_account_match) to install the role:

```bash
$ ansible-galaxy install cytopia.aws_account_match
```

Or git clone it into your roles directory

```bash
$ git clone https://github.com/cytopia/ansible-role-aws_account_match /path/to/ansible/roles
```

## Variables

**Note:** (XOR)

* Either `aws_account_match_allowed_account` or `aws_account_match_allowed_accounts` must be specified.
* Only one of `aws_account_match_allowed_account` or `aws_account_match_allowed_accounts` can be specified.

| Name | Type | Description |
|--------------------------------------|---------------------------|---------------------------|
| `aws_account_match_allowed_account` | `int` or `string` | Single allowed account |
| `aws_account_match_allowed_accounts` | `list` | Multiple allowed accounts |
| `aws_account_match_profile` | `string` | Optional boto profile of current login |

## Requirements

* [aws-cli](https://docs.aws.amazon.com/cli/latest/userguide/installing.html) (`pip install awscli`)
* [Ansible 2.4](https://github.com/ansible/ansible)

## Usage

##### playbook.yml

```yml
---
- hosts: all
roles:
- aws_account_match # <- make sure it is the first
- aws-do-this
- aws-do-that
- aws-more-work
tags:
- aws
```
##### group_vars/all.yml

```yml
---
# Allow two AWS accounts
aws_account_match_allowed_accounts:
- 123456789
- 987654321

# Ensure to have boto profile optionally parsed via cmd args
aws_account_match_profile: "{{ profile | default('') }}"
```

##### Run

The `testing` boto profile has a login for account `555444333222`, which is not part of the allowed
accounts. In case this is run, it will immediately abort the whole play:

```bash
$ ansible-playbook playbook.yml -e profile=testing
```

```
TASK [aws_account_match : ensure current account matched any of all allowed accounts] **************************
fatal: [infrastructure]: FAILED! => {
"assertion": "_aws_account_match_number.stdout | string in aws_account_match_allowed_accounts | map('string') | list",
"changed": false,
"evaluated_to": false,
"msg": "Currently logged in account (555444333222) not in allowed accounts (123456789, 987654321)."
}
```

##### Run without aws_account_match

You can also skip the whole role in case you need to test without account validation
via its pre-defined tags:

```bash
$ ansible-playbook playbook.yml -e profile=testing --skip-tags=aws_account_match
```