An Ansible module that enables Continuous Delivery with Red Hat 3scale API Management Platform (3scale AMP)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

80 lines
3.1 KiB

---
- name: Retrieve existing Services from the 3scale Admin Portal
uri:
url: "https://{{ inventory_hostname }}/admin/api/services.json?access_token={{ threescale_cicd_access_token|urlencode }}"
validate_certs: no
register: threescale_cicd_tmpresponse
when: threescale_cicd_existing_services is not defined
no_log: '{{ threescale_cicd_nolog }}'
- name: Set the list of existing service as a fact
set_fact:
threescale_cicd_existing_services: >-
{{ threescale_cicd_tmpresponse.json|json_query('services[*].service.system_name') }}
threescale_cicd_existing_services_details: >-
{{ threescale_cicd_tmpresponse.json|json_query('services[].{"system_name": service.system_name, "id": service.id}') }}
cacheable: true
when: threescale_cicd_existing_services is not defined
- debug:
msg: "Found {{ threescale_cicd_existing_services|length }} services"
verbosity: 1
- debug:
var: threescale_cicd_existing_services_details
verbosity: 1
- name: Retrieve existing ActiveDocs from the 3scale Admin Portal
uri:
url: "https://{{ inventory_hostname }}/admin/api/active_docs.json?access_token={{ threescale_cicd_access_token|urlencode }}"
validate_certs: no
register: threescale_cicd_tmp_allactivedocs
no_log: '{{ threescale_cicd_nolog }}'
- name: Set the list of existing active docs as a fact
set_fact:
threescale_cicd_existing_activedocs: >-
{{ threescale_cicd_tmp_allactivedocs.json|json_query('api_docs[*].api_doc.system_name') }}
threescale_cicd_existing_activedocs_details: >-
{{ threescale_cicd_tmp_allactivedocs.json|json_query('api_docs[].{"system_name": api_doc.system_name, "id": api_doc.id}') }}
- debug:
msg: "Found {{ threescale_cicd_existing_activedocs|length }} active docs"
verbosity: 1
- debug:
var: threescale_cicd_existing_activedocs_details
verbosity: 1
- name: Poke around for the APIcast Policies Registry API
uri:
url: "https://{{ inventory_hostname }}/admin/api/policies.json?access_token={{ threescale_cicd_access_token|urlencode }}"
validate_certs: no
status_code: 200,404
register: threescale_cicd_tmp_policy_response
changed_when: false
no_log: '{{ threescale_cicd_nolog }}'
when: threescale_cicd_capabilities is not defined
- name: Poke around for the OIDC Configuration Show API
uri:
url: "https://{{ inventory_hostname }}/admin/api/services/0/proxy/oidc_configuration.json?access_token={{ threescale_cicd_access_token|urlencode }}"
validate_certs: no
status_code: 404
register: threescale_cicd_tmp_oidc_config_response
changed_when: false
no_log: '{{ threescale_cicd_nolog }}'
when: threescale_cicd_capabilities is not defined
- name: Set the list of 3scale capabilities as a fact
set_fact:
threescale_cicd_capabilities:
policy_registry_api: '{{ threescale_cicd_tmp_policy_response.status == 200 }}'
oidc_configuration_api: '{{ threescale_cicd_tmp_oidc_config_response.content_type.startswith(''application/json'') }}'
cacheable: true
when: threescale_cicd_capabilities is not defined
- debug:
var: threescale_cicd_capabilities
verbosity: 1