@ -11,7 +11,7 @@
|
||||
|
||||
- name: Append/Create Item
|
||||
ansible.builtin.include_tasks:
|
||||
file: append-create-item.yaml
|
||||
file: search-add.yaml
|
||||
loop: "{{ glpi_config_as_code_json }}"
|
||||
|
||||
|
||||
|
@ -1,39 +1,10 @@
|
||||
---
|
||||
|
||||
- name: Create item_body
|
||||
ansible.builtin.set_fact:
|
||||
item_body: "{{ item.body }}"
|
||||
no_log: true
|
||||
|
||||
|
||||
- name: Search item_id
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/search/item_id.yaml
|
||||
when: not item.body.id is defined
|
||||
|
||||
|
||||
- name: Search entities_id
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/search/entities_id.yaml
|
||||
when: item.entities_id is defined
|
||||
|
||||
|
||||
- name: Search tickettemplates_id_demand
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/search/tickettemplates_id_demand.yaml
|
||||
when: item.tickettemplates_id_demand is defined
|
||||
|
||||
|
||||
- name: Search itilcategories_id
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/search/itilcategories_id.yaml
|
||||
when: item.itilcategories_id is defined
|
||||
|
||||
|
||||
- name: Search users_id
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/search/users_id.yaml
|
||||
when: item.users_id is defined
|
||||
when: >
|
||||
not item.body.id is defined
|
||||
|
||||
|
||||
- name: Show Body
|
||||
@ -59,7 +30,7 @@
|
||||
|
||||
- name: Update Item
|
||||
ansible.builtin.uri:
|
||||
url: "http://{{ glpi.host }}/apirest.php/{{ item.api_path }}/{{ item_body.id }}"
|
||||
url: "http://{{ glpi.host }}/apirest.php/{{ item.api_path }}{% if item.api_path != 'Config' %}/{{ item_body.id }}{% endif %}"
|
||||
method: "PATCH"
|
||||
return_content: true
|
||||
body: "{\"input\": {{ item_body | from_yaml | to_json }} }"
|
||||
|
91
tasks/api/config.yaml
Normal file
91
tasks/api/config.yaml
Normal file
@ -0,0 +1,91 @@
|
||||
---
|
||||
|
||||
- name: Show {{ list_item.body.name }}
|
||||
ansible.builtin.debug:
|
||||
msg: "{{ list_item }}"
|
||||
|
||||
- name: Fetch ID for {{ list_item.body.name }}
|
||||
ansible.builtin.uri:
|
||||
url: "http://{{ glpi.host }}/apirest.php/{{ item.api_path }}?searchText[name]={{ list_item.body.name | urlencode }}"
|
||||
method: "GET"
|
||||
return_content: true
|
||||
body: ''
|
||||
# status_code: "{{ item.status_code | from_yaml | list }}"
|
||||
status_code: [200, 201]
|
||||
headers:
|
||||
App-Token: "{{ glpi.app_token }}"
|
||||
Session-Token: "{{ glpi.session.valid_id }}"
|
||||
body_format: json
|
||||
no_log: true
|
||||
register: glpi_search
|
||||
|
||||
|
||||
- name: Build API Body for {{ list_item.body.name }}
|
||||
ansible.builtin.set_fact:
|
||||
config_item:
|
||||
api_path: "{{ list_item.api_path }}"
|
||||
body:
|
||||
context: "{{ list_item.body.context }}"
|
||||
name: "{{ list_item.body.name }}"
|
||||
value: "{{ list_item.body.value }}"
|
||||
when: glpi_search.json | length | int == 0
|
||||
no_log: true
|
||||
|
||||
|
||||
- name: Build API Body (with ID) for {{ list_item.body.name }}
|
||||
ansible.builtin.set_fact:
|
||||
config_item:
|
||||
api_path: "{{ list_item.api_path }}"
|
||||
body:
|
||||
id: "{% for found_id in glpi_search.json %}{%if list_item.body.name == found_id.name %}{{ found_id.id }}{% endif %}{% endfor %}"
|
||||
context: "{{ list_item.body.context }}"
|
||||
name: "{{ list_item.body.name }}"
|
||||
value: "{{ list_item.body.value }}"
|
||||
when: glpi_search.json | length | int > 0
|
||||
no_log: true
|
||||
|
||||
|
||||
- name: "Item [{{ config_item.body.id + ']: ' + config_item.body.name }}"
|
||||
ansible.builtin.debug:
|
||||
msg: "{{ config_item }}"
|
||||
when: config_item is defined
|
||||
|
||||
|
||||
# ToDo: figure out why cant create item?????
|
||||
|
||||
# - name: Create Config Item
|
||||
# ansible.builtin.uri:
|
||||
# url: "http://{{ glpi.host }}/apirest.php/{{ config_item.api_path }}"
|
||||
# method: "POST"
|
||||
# return_content: true
|
||||
# body: "{\"input\": {{ config_item.body | from_yaml | to_json }} }"
|
||||
# status_code: [200, 201]
|
||||
# headers:
|
||||
# App-Token: "{{ glpi.app_token }}"
|
||||
# Session-Token: "{{ glpi.session.valid_id }}"
|
||||
# body_format: json
|
||||
# # no_log: true
|
||||
# when: not config_item.body.id is defined
|
||||
|
||||
|
||||
- name: Update Config Item
|
||||
ansible.builtin.uri:
|
||||
url: "http://{{ glpi.host }}/apirest.php/{{ item.api_path }}/{{ config_item.body.id }}"
|
||||
method: "PATCH"
|
||||
return_content: true
|
||||
body: "{\"input\": {{ config_item.body | from_yaml | to_json }} }"
|
||||
status_code: [200, 201]
|
||||
headers:
|
||||
App-Token: "{{ glpi.app_token }}"
|
||||
Session-Token: "{{ glpi.session.valid_id }}"
|
||||
body_format: json
|
||||
no_log: true
|
||||
when: config_item.body.id is defined
|
||||
|
||||
|
||||
- name: Clear temp vars
|
||||
ansible.builtin.set_fact:
|
||||
config_item: {}
|
||||
glpi_search: {}
|
||||
list_item: {}
|
||||
no_log: true
|
47
tasks/api/search-add.yaml
Normal file
47
tasks/api/search-add.yaml
Normal file
@ -0,0 +1,47 @@
|
||||
---
|
||||
|
||||
- name: Create item_body
|
||||
ansible.builtin.set_fact:
|
||||
item_body: "{{ item.body }}"
|
||||
no_log: true
|
||||
|
||||
|
||||
- name: Append/Create Item
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/append-create-item.yaml
|
||||
when: not item.api_path == 'Config'
|
||||
|
||||
|
||||
- name: Config Items to skip
|
||||
ansible.builtin.set_fact:
|
||||
skip_config:
|
||||
- cas_version
|
||||
- dbversion
|
||||
- _dbslave_status
|
||||
- schema_version
|
||||
- version
|
||||
when: item.api_path == 'Config'
|
||||
|
||||
|
||||
- name: Config
|
||||
ansible.builtin.include_tasks:
|
||||
file: api/config.yaml
|
||||
when: >
|
||||
item.api_path == 'Config'
|
||||
and
|
||||
not sub_item.name in skip_config
|
||||
loop: "{{ item_body }}"
|
||||
loop_control:
|
||||
loop_var: sub_item
|
||||
vars:
|
||||
list_item:
|
||||
api_path: "{{ item.api_path }}"
|
||||
body:
|
||||
context: "{{ sub_item.context }}"
|
||||
name: "{{ sub_item.name }}"
|
||||
value: "{{ sub_item.value | default('') }}"
|
||||
|
||||
|
||||
- name: Clear temp vars
|
||||
ansible.builtin.set_fact:
|
||||
item_body: {}
|
@ -37,4 +37,4 @@
|
||||
apply:
|
||||
tags:
|
||||
- always
|
||||
when: glpi_config_as_code_json length | int > 0
|
||||
when: glpi_config_as_code_json | length | int > 0
|
||||
|
Reference in New Issue
Block a user