Skip to content

jameszh/ansible-plugins

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 

Repository files navigation

ansible-plugins

Ansible Plugins

Notification Plugins

cloudformation_stack_facts

Retrieve information about a CloudFormation Stack

- name: get cloudformation stack facts details
  cloudformation_stack_facts: stack_name="example_stackname" region="{{ region }}"
  register: cfn_stack

- debug: var=cfn_stack

This module returns a datastructure containing the params, outputs, resources and tags included in a stack as well as other stack attributes such as status, created time and description.

elb_facts

Retrieve information about an Elastic Load Balancer

- name: Retrieve details for the ELB
  elb_facts: elb_name="appname-UAS42ASXZ" region="{{ region }}"
  register: elb_info

- debug: var=elb_info

The structure returned looks like this:

"elb_info": {
    "created_time": "2015-05-07T13:42:46.510Z",
    "cross_az_lb": true,
    "dns_name": "appname-UAS42ASXZ.eu-west-1.elb.amazonaws.com",
    "name": "appname-UAS42ASXZ",
    "scheme": "internet-facing",
    "vpc_id": "vpc-23df567d8",
    "zone_id": "Z3NF1ZF1HGF3"
}

route53_zone_facts

Basic module to return information about a route53 hosted zone.

- name: get route53 info
  route53_zone_facts: zone_name="example.org." region="eu-west-1"
  register: zone_info

- debug: var=zone_info

The structure returned looks like this:

"zone_info": {
  "changed": false,
  "invocation": {
    "module_args": "zone_name=\"example.org.\" region=\"eu-west-1\"",
    "module_name": "route53_zone_facts"
  },
  "name_servers": [
    "ns-fsfsff.awsdns-015.com.",
    "ns-dfsfsfs.awsdns-219.co.uk."
  ],
  "record_count": "2001",
  "zone_comment": "Public example.org. zone.",
  "zone_id": "ZLT8CAAHEM",
  "zone_name": "example.org.",
  "zone_type": "public"
}

changelog

A simple notification plugin for the Prezi Changelog event dashboard:

- local_action: changelog message="Ansible playbook is running - 003"
  category=ansible


- local_action: changelog
                message="An issue was detected in our Ansible playbook!"
                category=ansible
                criticality=critical
                host=changelog.example.org

Lookup Plugins

Most of the AWS Lookup plugins contained here assume that you have a correctly configured .aws/credentials file. This provides the credentials for boto, the underlying AWS library used by Ansible.

AWS Regions

Allows you to look up the available AWS Regions and then filters out any that contain the string 'gov'

- shell: echo region is =={{ item }}==
  with_items: lookup('aws_regions').split(',')

Cloudformation

Allows you to look up Cloudformation stack output values.

The key should be structured like this:

{{ lookup('cloudformation', 'region/stackname/output/outputname') }}

and an actual example:

{{ lookup('cloudformation', 'eu-west-1/unixdaemon-natinstance/output/nat_group_id') }}

Elasticache Replica Group

Allows you to look up the endpoint address and port of a given Elasticache Replica Groups

The key should be structured like this:

{{ lookup('elasticache_replica_group', 'region/repl_group_name/query_value') }}

and some actual examples:

{{ lookup('elasticache_replica_group', 'ap-southeast-1/locarch2-elastiredis/endpoint_address') }}

{{ lookup('elasticache_replica_group', 'ap-southeast-1/locarch2-elastiredis/endpoint_port') }}

AWS Security Group ID

Allows you to look up the ID (something like sg-62f43457) of a remote security group.

"{{ lookup('aws_sg_id', 'eu-west-1/my-stack-name') }}"

I wrote this to avoid adding lots of outputs to certain templates.

AWS DefaultVPC ID

Allows you to look up the default VPC id for a given ec2 region.

- debug: msg="The default vpc is {{ lookup('default_vpc', 'ap-southeast-1') }}"

Currently doesn't handle ec2classics.

About

Ansible Plugins

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%