This sample playbook demonstrates basic use cases for invoking a REST API service, particularly the z/OSMF REST API services.
It is a good practice to review the playbook contents before executing them. It will help you understand the requirements in terms of space, location, names, authority, and the artifacts that will be created and cleaned up.
This playbook requires:
- uri-sample.yml - Provides an example of how to invoke the z/OSMF REST API services with Ansible.
- Configure the included inventory.yml with the
information from the managed z/OS host.
- To configure the inventory, review inventory documentation
- Configure the included host_vars zos_host.yml
with the information from your z/OS system.
-
Review host_vars documentation and any additional noted variables in the configuration.
-
Configure variables:
ZOSMF_HOST: zosmf_target_host ZOSMF_PORT: zosmf_target_port ZOSMF_DEST_FOLDER: /path/to/folder ZOSMF_USER: user ZOSMF_PASS: pass ZOSMF_SYSTEM: zosmf_system
-
The purpose of the uri-sample
playbook is to showcase the ability to invoke a REST API service as well as give an example of creating, starting, and deleting workflows using the z/OSMF REST API service.
This playbook will use the following operations:
- Querying existing workflows
- Creation of a workflow
- Starting a workflow
- Cancellation of a workflow
- Deletion of a workflow
Note: to learn more about z/OSMF workflow services, visit IBM Docs
The uri-sample
playbook starts by copying over the sample_definition_file.xml (required for z/OSMF REST API service utilization) to the specified target folder, and has two outcomes after execution.
- Running the playbook the first time will result in
- Creation of the sample_workflow
- Starting the sample_workflow
- Running the playbook the second time will result in
- Cancellation of the sample_workflow
- Deletion of the sample_workflow
The ZOSMF_PASS
variable is stored in plaintext as shown above in the group_vars/all.yml file. If desired, the ZOSMF_PASS
can be encrypted in several different ways; we will walk through one of those ways.
For this short tutorial, we will encrypt the following variable.
ZOSMF_PASS: mysecretpassword
In order to encrypt the password, we will run the following ansible-vault
command in our terminal.
ansible-vault encrypt_string mysecretpassword --ask-vault-pass
This command will prompt you to enter a password that will be used to decrypt the sensitive information while running the playbook. After successfully selecting a password to encrypt the sensitive information, the command will produce a result similar to the following output.
!vault |
$ANSIBLE_VAULT;1.1;AES256
64313462656366313466633039373238663035653332366664663839373564613237636662663766
3835383763393630366662366630633965396234303438660a373232633133646535336530353961
38393864396132353637323837656336306633663464633964316637666661363931646565616435
6332316134666538300a393833663835343134393466343265356337633637346631653761653230
6365
Encryption successful
The only thing left to do is replace the plaintext password with this encrypted string.
ZOSMF_PASS: !vault |
$ANSIBLE_VAULT;1.1;AES256
64313462656366313466633039373238663035653332366664663839373564613237636662663766
3835383763393630366662366630633965396234303438660a373232633133646535336530353961
38393864396132353637323837656336306633663464633964316637666661363931646565616435
6332316134666538300a393833663835343134393466343265356337633637346631653761653230
6365
This project has included a site.yml
playbook that serves as the master playbook
that provides additional prerequisite checks then it invokes the uri-sample.yml
playbook.
If you want to run the master playbook site.yml
it will check that your environment
has the correct version of Ansible as well as the collection needed to execute
correctly. To run the master playbook, use command:
ansible-playbook -i inventories site.yml
You can skip the prerequisite check and run the uri-sample.yml
with
command:
ansible-playbook -i inventories uri-sample.yml
If ansible-vault
was used to encrypt any sensitive information, add the
following to your command: --ask-vault-pass
. Note: This will prompt you
for the password used to encrypt the sensitive data. e.g,, run the following command:
ansible-playbook -i inventories --ask-vault-pass uri-sample.yml
ansible-playbook -i inventories --ask-vault-pass site.yml
All changes are maintained chronologically by date found in the changelog.
© Copyright IBM Corporation 2021
Licensed under Apache License, Version 2.0.
Please refer to the support section for more details.