bb7bd1c58e
The current implementation of airship-libvirt-gate is using sushy-emulator binary to emulate redfish. Sushy-emulator works only for http and also can’t authenticate users out-of-box if ran by itself. In order to check https and authentication the reverse-proxy was introduced. This approach had several drawbacks: 1) http still doesn’t check auth 2) to use apache for https only is too heavy solution for https This change converts reverse proxy to apache running sushy-emulator as wsgi backend, that gives an ability to check authentication for both http and https. We’re also getting rid of ad-hoc sushy-emulator service and using out-of-box apache service implementation. The code also introduces gathering of apache resulting configs and logs for quicker debug if needed. Right now authentication is disabled, since manifests are written in a way so they don’t use them. If it’s necessary to enable it, just set username here[1] PS There is ability to use apache for http-server [2], but it’s better to do as a separate PR [1] roles/airship-libvirt-gate/defaults/main.yaml [2] roles/http-fileserver Change-Id: I43b5bca41519c88b01535c156b2db0e9edaa81bb
60 lines
2.0 KiB
YAML
60 lines
2.0 KiB
YAML
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
# you may not use this file except in compliance with the License.
|
|
# You may obtain a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
# See the License for the specific language governing permissions and
|
|
# limitations under the License.
|
|
|
|
- name: Include test variables.
|
|
include_vars:
|
|
file: vars.yaml
|
|
|
|
- name: deploy-gate
|
|
include_role:
|
|
name: airship-libvirt-gate
|
|
vars:
|
|
gate_flavor: small
|
|
gate_action: build-infra
|
|
|
|
- name: query redfish to make sure it has running domains using HTTPS
|
|
uri:
|
|
url: "https://{{ airship_gate_redfish_auth.servername }}:{{ airship_gate_redfish_auth.https_port }}/redfish/v1/Systems?format=json"
|
|
url_username: "{{ airship_gate_redfish_auth.user[0].username }}"
|
|
url_password: "{{ airship_gate_redfish_auth.user[0].password}}"
|
|
validate_certs: false
|
|
method: GET
|
|
return_content: yes
|
|
register: redfish_response
|
|
|
|
- name: debug redfish machines
|
|
debug:
|
|
var: redfish_response
|
|
|
|
- name: save ids to list
|
|
uri:
|
|
url: "https://{{ airship_gate_redfish_auth.servername }}:{{ airship_gate_redfish_auth.https_port }}{{ item.value }}?format=json"
|
|
url_username: "{{ airship_gate_redfish_auth.user[0].username }}"
|
|
url_password: "{{ airship_gate_redfish_auth.user[0].password }}"
|
|
validate_certs: false
|
|
method: GET
|
|
return_content: yes
|
|
with_dict: "{{ redfish_response.json.Members }}"
|
|
register: systems_details
|
|
|
|
- name: deploy ephemeral host
|
|
set_fact:
|
|
ephemeral_domain_id: "{{ systems_details | json_query(query_string) | join('') }}"
|
|
vars:
|
|
query_string: "results[?json.Name=='{{ airship_gate_names.ephemeral_vm }}'].json.Id"
|
|
|
|
- name: verify that id is not empty
|
|
assert:
|
|
that:
|
|
- ephemeral_domain_id is defined
|
|
- (ephemeral_domain_id | length) > 1
|