From 4c08f56914930a5162a83b0f75adf57297c46757 Mon Sep 17 00:00:00 2001 From: przemkalit Date: Wed, 7 Aug 2024 15:44:40 +0200 Subject: [PATCH] Extra variables for workflow job templates and job templates (#854) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat: add variables related to job templates of workflow and related to project of job template * fix: removing brackets * Remove discussions link * fix: remove trailing spaces * fix: missing new line * fix: remove trailing spaces part2 * misc: removing variables, allowing to export job templates and project related to workflow * fix: trailing spaces * fix: trailing spaces part2 * feat: add variable to control if related objects should be exported * fix: missing README entry * misc: change default behaviour * misc: change task name to proper * Update export_related_objects explanation --------- Co-authored-by: Ivan Aragonés Muniesa <26822043+ivarmu@users.noreply.github.com> Co-authored-by: Przemyslaw Kalitowski Co-authored-by: adonisgarciac <71078987+adonisgarciac@users.noreply.github.com> Co-authored-by: David Danielsson --- .../filetree_create_extra_variables.yml | 3 +++ roles/filetree_create/README.md | 1 + roles/filetree_create/defaults/main.yml | 1 + roles/filetree_create/tasks/job_templates.yml | 7 +++++++ .../tasks/workflow_job_templates.yml | 20 +++++++++++++++++++ 5 files changed, 32 insertions(+) create mode 100644 changelogs/fragments/filetree_create_extra_variables.yml diff --git a/changelogs/fragments/filetree_create_extra_variables.yml b/changelogs/fragments/filetree_create_extra_variables.yml new file mode 100644 index 000000000..627570585 --- /dev/null +++ b/changelogs/fragments/filetree_create_extra_variables.yml @@ -0,0 +1,3 @@ +--- +minor_changes: + - filetree_create able to export single worfklow with related job_templates and projects diff --git a/roles/filetree_create/README.md b/roles/filetree_create/README.md index 570762fcf..e69eda72d 100644 --- a/roles/filetree_create/README.md +++ b/roles/filetree_create/README.md @@ -25,6 +25,7 @@ The following variables are required for that role to work properly: | `show_encrypted` | N/A | no | bool | Whether to remove the string '\$encrypted\$' in credentials output (not the actual credential value) | | `omit_id` | N/A | no | bool | Whether to create output files without objects id.| | `organization`| N/A | no | str | Default organization for all objects that have not been set in the source controller.| +| `export_related_objects` | False | no | bool | Whether to export related objects (job templates related to certain workflows and the projects associated with these job templates) when a single JT or a single WFJT are being exported. | ## Dependencies diff --git a/roles/filetree_create/defaults/main.yml b/roles/filetree_create/defaults/main.yml index e669fbdcd..425a73f52 100644 --- a/roles/filetree_create/defaults/main.yml +++ b/roles/filetree_create/defaults/main.yml @@ -22,6 +22,7 @@ output_path: "/tmp/filetree_output" # Maximum number of objects to return from the list. If a list view returns more an max_objects an exception will be raised query_controller_api_max_objects: 10000 +export_related_objects: false controller_configuration_filetree_create_secure_logging: "{{ controller_configuration_secure_logging | default('false') }}" diff --git a/roles/filetree_create/tasks/job_templates.yml b/roles/filetree_create/tasks/job_templates.yml index 70682aa91..6dbb18cb5 100644 --- a/roles/filetree_create/tasks/job_templates.yml +++ b/roles/filetree_create/tasks/job_templates.yml @@ -13,6 +13,13 @@ order_by: 'organization,id' no_log: "{{ controller_configuration_filetree_create_secure_logging }}" +- name: "Export project related to job_template" + when: job_template_id is defined and project_id is not defined and (export_related_objects is defined and export_related_objects) + ansible.builtin.include_tasks: "projects.yml" + vars: + project_id: "job_templates_lookvar[0]['summary_fields']['project']['id'] }}" + no_log: "{{ controller_configuration_filetree_create_secure_logging }}" + - name: "Block for to generate flatten output" when: - flatten_output is defined diff --git a/roles/filetree_create/tasks/workflow_job_templates.yml b/roles/filetree_create/tasks/workflow_job_templates.yml index 503828276..72aa95d9a 100644 --- a/roles/filetree_create/tasks/workflow_job_templates.yml +++ b/roles/filetree_create/tasks/workflow_job_templates.yml @@ -12,6 +12,26 @@ order_by: 'organization,id' no_log: "{{ controller_configuration_filetree_create_secure_logging }}" +- name: "Block for exporting the related job templates" + when: workflow_job_template_id is defined and (export_related_objects is defined and export_related_objects) + block: + - name: "Get current Job Templates related to workflow from the API" + ansible.builtin.set_fact: + workflow_node_job_templates_lookvar: "{{ query(controller_api_plugin, workflow_job_templates_lookvar[0]['related']['workflow_nodes'], + host=controller_hostname, oauth_token=controller_oauthtoken, verify_ssl=controller_validate_certs, + return_all=true, max_objects=query_controller_api_max_objects) + }}" + no_log: "{{ controller_configuration_filetree_create_secure_logging }}" + + - name: "Export job templates related to to workflow" + ansible.builtin.include_tasks: "job_templates.yml" + vars: + job_template_id: "{{ current_workflow_job_node_templates_asset_value['unified_job_template'] }}" + loop: "{{ workflow_node_job_templates_lookvar }}" + loop_control: + loop_var: current_workflow_job_node_templates_asset_value + no_log: "{{ controller_configuration_filetree_create_secure_logging }}" + - name: "Block for to generate flatten output" when: - flatten_output is defined