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
56 lines
1.4 KiB
YAML
56 lines
1.4 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.
|
|
|
|
libvirt_pool:
|
|
path: /var/lib/libvirt/airship
|
|
name: airship
|
|
|
|
libvirt_volumes:
|
|
- name: volume-1
|
|
image: https://cloud.centos.org/centos/7/images/CentOS-7-x86_64-GenericCloud.qcow2
|
|
size: 10G
|
|
pool: "{{ libvirt_pool.name }}"
|
|
action: create
|
|
- name: volume-2
|
|
size: 10G
|
|
pool: "{{ libvirt_pool.name }}"
|
|
action: create
|
|
|
|
libvirt_domain:
|
|
state: running
|
|
name: 'vm1'
|
|
memory_mb: 2048
|
|
vcpus: 1
|
|
volumes:
|
|
- name: 'volume-1'
|
|
device: 'disk'
|
|
format: 'qcow2'
|
|
pool: 'airship'
|
|
interfaces:
|
|
- network: 'provision-network'
|
|
|
|
libvirt_network:
|
|
name: provision-network
|
|
spec:
|
|
forward:
|
|
mode: nat
|
|
nat:
|
|
port:
|
|
- start: 1024
|
|
end: 65535
|
|
bridge:
|
|
name: "prov-net-br"
|
|
stp: 'on'
|
|
delay: '0'
|
|
ip:
|
|
address: "172.22.0.1"
|
|
netmask: "255.255.255.0" |