Skip to main content

A butler CLI for assistance in managing Ansible projects

Project description

ansible-butler

Butler CLI for Ansible projects

Functions

Object Action Description
directory init initialize an ansible directory
directory init cleanup an ansible directory
ee init initialize an execution environment directory for ansible-builder
ee dependencies[deps] parse the dependency tree based on execution environment definition (or collection requirements)
role list list roles
role clean clean role directory structure (remove empty yml files & dirs)
role mk-readme auto generate readme based on role meta and basic yml info
playbook update map legacy module names to FCQNs
playbook list-collections[lc] list collections used in a playbook (following include_* directives)

Usage

Usage:
  ansible-butler directory init [<dir>] [--config=PATH]
  ansible-butler directory clean [<dir>] [--skip-roles]
  ansible-butler ee init [<dir>] [--config=PATH]
  ansible-butler ee [dependencies|deps] [--config=PATH] [<name>]
  ansible-butler role list [--roles-path=PATH] [<name> --recursive]
  ansible-butler role clean [--roles-path=PATH] [<name> --recursive]
  ansible-butler role mk-readme [--roles-path=PATH] [<name> --recursive]
  ansible-butler playbook update [--context=CONTEXT] [--config=PATH] [<name>] [--recursive] [--force]
  ansible-butler playbook [list-collections|lc] [--context=CONTEXT] [--config=PATH] [<name>] [--recursive] [--force]

Arguments:
  name    name of target (accepts glob patterns)
  dir     path to directory [default: ./]

Options:
  -h --help           Show this screen
  -r --recursive      Apply glob recursively [default: False]
  -f --force          Make file changes in place
  --config=PATH       Path to config file
  --roles-path=PATH   Path to roles directory [default: ./roles]
  --context=CONTEXT   Path to context directory [default: ./]
  --skip-roles        Flag to skip cleaning roles

Examples

  • Initialize Ansible Directory
    • ansible-butler directory init ./sandbox
    • ansible-butler directory init ./sandbox --config=~/configs/ansible-butler.yml
  • Clean an Ansible Directory
    • ansible-butler directory clean ./sandbox
    • ansible-butler directory clean ./sandbox --skip-roles
  • Initialize Execution Environment Directory
    • ansible-butler ee init ./ee-windows
    • ansible-butler ee init ./ee-windows --config=~/configs/ansible-butler.yml
  • Inspect Execution Environment Dependencies
    • ansible-butler ee dependencies execution-environment.yml
    • ansible-butler ee deps requirements.yml --config=~/configs/ansible-butler.yml
  • Clean Roles
    • ansible-butler role clean my-role-1
    • ansible-butler role clean my-role-*
  • Generate README
    • ansible-butler role mk-readme my-role-1
    • ansible-butler role mk-readme my-role-*
  • Update Playbooks
    • ansible-butler playbook update --context=./playbooks -r
    • ansible-butler playbook update legacy-*.yml
    • ansible-butler playbook update -f
  • List Collections
    • ansible-butler playbook list-collections --context=./playbooks -r
    • ansible-butler playbook lc example-playbook.yml

Configuration

Create an .ansible-butler.yml in one or more of the following locations:

/etc/ansible-butler/    ## least precedence
~/
./                      ## highest precedence

You can also specify a specific path at runtime via the --config option.

# Configuration Schema
execution_environment:
  init:
    version: 2
    ansible_config: ansible.cfg
    ee_base_image: quay.io/ansible/ansible-runner:latest
    ee_builder_image: quay.io/ansible/ansible-builder:latest
    prepend_build_steps:
      - ...
    append_build_steps:
      - ...

directory:
  init:
    folders:
      - name: plugins
        folders:
          ...
        files:
          - README.md
    files:
      - playbook.yml

playbook:
  update:
    modules:
      smart_device:
        redirect: zjleblanc.kasa.smart_device
      custom_module:
        redirect: company.it.custom_module

🔗 Default configuration file
🔗 Example adding test plugins directory
🔗 Example adding module redirects

Troubleshooting

  • ansible-butler: command not found
    • check the $PATH environment variable and ensure that ~/.local/bin is included

License

GNU General Public License

Author Information

Zach LeBlanc

Red Hat

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ansible-butler-1.0.16.tar.gz (71.3 kB view details)

Uploaded Source

Built Distribution

ansible_butler-1.0.16-py3-none-any.whl (70.8 kB view details)

Uploaded Python 3

File details

Details for the file ansible-butler-1.0.16.tar.gz.

File metadata

  • Download URL: ansible-butler-1.0.16.tar.gz
  • Upload date:
  • Size: 71.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.1

File hashes

Hashes for ansible-butler-1.0.16.tar.gz
Algorithm Hash digest
SHA256 a1b6d1dcb29a3dfc33fbc4b3097cb65f3ed8a3e6735542b5c751cf9935ab039c
MD5 782f2f041bb60c75fbb37f2cba8c3068
BLAKE2b-256 31dac189f84d06c40efd67dbd7d8f025d8e1c6e8c4565ded90226df5c1f7b689

See more details on using hashes here.

File details

Details for the file ansible_butler-1.0.16-py3-none-any.whl.

File metadata

File hashes

Hashes for ansible_butler-1.0.16-py3-none-any.whl
Algorithm Hash digest
SHA256 28a843795b4076ac0a5501e303448edc7241ed4b5c15787db3786c8d2d28e594
MD5 2184310b48a8bef924d10a657ecc7351
BLAKE2b-256 2a1735efe575e4bce1c7529f81e1357125ffe03eff8e5510cbe4444799625124

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page