chore(awx): and it turned out awx had a client utility all along

This commit is contained in:
Michele Cereda
2024-08-19 19:13:34 +02:00
parent 58c0bd62ae
commit 2e1ed64ffc
2 changed files with 117 additions and 5 deletions

View File

@@ -594,6 +594,53 @@ deployment.apps "awx-operator-controller-manager" deleted
Refer [AWX API Reference] and [How to use AWX REST API to execute jobs]. Refer [AWX API Reference] and [How to use AWX REST API to execute jobs].
AWX offers the `awx` client CLI tool:
```sh
# Install the 'awx' client
pipx install 'awxkit'
pip3 install --user 'awxkit'
# Normally `awx` would require setting the configuration every command like so:
# awx --conf.host https://awx.example.org --conf.username 'admin' --conf.password 'password' config
# awx --conf.host https://awx.example.org --conf.username 'admin' --conf.password 'password' export --schedules
# Export settings to environment variables to avoid having to set them on the command line all the time
export TOWER_HOST='https://awx.example.org' TOWER_USERNAME='admin' TOWER_PASSWORD='password'
# Show the client configuration
awx … config
# List all available endpoints
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/' | jq '.' -
# List jobs
awx jobs list
awx jobs list -f 'yaml'
awx jobs list -f 'human' --filter 'name,created,status'
awx jobs list -f 'jq' --filter '.results[] | .name + " is " + .status'
# Show job templates
awx job_templates list
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/job_templates/' | jq '.' -
# Show notification templates
awx … notification_templates list
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/notification_templates/' | jq '.' -
# Show schedules
awx … schedules list
awx … schedules --schedules 'schedule-1' 'schedule-n'
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/schedules/' | jq '.' -
# Export data
awx … export
awx … export --job_templates 'job-template-1' 'job-template-n' --schedules
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/export/' | jq '.' -
```
Refer [AWX Command Line Interface] for more information.
## Further readings ## Further readings
- [Website] - [Website]
@@ -601,6 +648,7 @@ Refer [AWX API Reference] and [How to use AWX REST API to execute jobs].
- [Minikube] - [Minikube]
- [Kustomize] - [Kustomize]
- [Helm] - [Helm]
- [AWX Command Line Interface]
### Sources ### Sources
@@ -629,6 +677,7 @@ Refer [AWX API Reference] and [How to use AWX REST API to execute jobs].
<!-- Upstream --> <!-- Upstream -->
[awx api reference]: https://ansible.readthedocs.io/projects/awx/en/latest/rest_api/ [awx api reference]: https://ansible.readthedocs.io/projects/awx/en/latest/rest_api/
[awx command line interface]: https://docs.ansible.com/ansible-tower/latest/html/towercli/
[awx's documentation]: https://ansible.readthedocs.io/projects/awx/en/latest/ [awx's documentation]: https://ansible.readthedocs.io/projects/awx/en/latest/
[awx's repository]: https://github.com/ansible/awx/ [awx's repository]: https://github.com/ansible/awx/
[basic install]: https://ansible.readthedocs.io/projects/awx-operator/en/latest/installation/basic-install.html [basic install]: https://ansible.readthedocs.io/projects/awx-operator/en/latest/installation/basic-install.html

View File

@@ -1,8 +1,71 @@
#!/usr/bin/env sh #!/usr/bin/env sh
# List all available endpoints # Install the 'awx' client
curl -fs 'https://awx.company.com/api/v2/' | jq '.' - pipx install 'awxkit'
pip3 install --user 'awxkit'
pip install 'git+https://github.com/ansible/awx.git@24.6.1#egg=awxkit&subdirectory=awxkit'
# list all jobs # Normally `awx` would require setting the configuration every command like so:
curl -fs --user 'admin:password' 'https://awx.company.com/api/v2/job_templates/' | jq '.' - # awx --conf.host https://awx.example.org --conf.username 'admin' --conf.password 'password' config
curl -fs 'https://awx.company.com/api/v2/job_templates/' | jq '.' - # awx --conf.host https://awx.example.org --conf.username 'admin' --conf.password 'password' export --schedules
# Export settings to environment variables to avoid having to set them on the command line all the time
export TOWER_HOST='https://awx.example.org' TOWER_USERNAME='admin' TOWER_PASSWORD='password'
# Show the client configuration
awx config
awx --conf.host https://awx.example.org --conf.username 'admin' --conf.password 'password' config
TOWER_HOST='https://awx.example.org' TOWER_USERNAME='admin' TOWER_PASSWORD='password' awx config
# List all available endpoints
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/' | jq '.' -
# List jobs
awx jobs list
awx jobs list -f 'yaml'
awx jobs list -f 'human' --filter 'name,created,status'
awx jobs list -f 'jq' --filter '.results[] | .name + " is " + .status'
# Show job templates
awx job_templates list
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/job_templates/' | jq '.' -
# Modify job templates
awx job_templates modify '1' --extra_vars "@vars.yml"
awx job_templates modify '5' --extra_vars "@vars.json"
# Show notification templates
awx notification_templates list
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/notification_templates/' | jq '.' -
# Show schedules
awx schedules list
awx … schedules --schedules 'schedule-1' 'schedule-n'
curl -fs --user 'admin:password' 'https://awx.example.org/api/v2/schedules/' | jq '.' -
# Import SSH keys
awx credentials create --credential_type 'Machine' \
--name 'My SSH Key' --user 'alice' \
--inputs '{"username": "alice", "ssh_key_data": "@~/.ssh/id_rsa"}'
# Execute ad-hoc commands
awx ad_hoc_commands create --monitor --wait --job_type 'check' --inventory 'Localhost' 'ping' --module_name 'ping'
# Export resources
awx export
awx … export --job_templates 'job-template-1' 'job-template-n' --schedules
awx … export --users 'admin' '42'
# Import resources
awx import < 'resources.json'
# Create and launch job templates
awx projects create --wait \
--organization '1' --name='Example Project' \
--scm_type 'git' --scm_url 'https://github.com/ansible/ansible-tower-samples' \
-f 'human' \
&& awx job_templates create \
--name='Example Job Template' --project 'Example Project' \
--playbook 'hello_world.yml' --inventory 'Demo Inventory' \
-f 'human' \
&& awx job_templates launch 'Example Job Template' --monitor -f 'human'