Docker support for web
Change-Id: I47ef0a30bc46d74baaf6572d0e3d9cfeb14d58f9
diff --git a/metadata/service/control/cluster.yml b/metadata/service/control/cluster.yml
index d76fb59..858f181 100644
--- a/metadata/service/control/cluster.yml
+++ b/metadata/service/control/cluster.yml
@@ -153,3 +153,6 @@
password: '${_param:keystone_admin_password}'
token: '${_param:keystone_service_token}'
tenant: admin
+ network:
+ engine: neutron
+ host: ${_param:cluster_vip_address}
diff --git a/metadata/service/control/control.yml b/metadata/service/control/control.yml
index 97ebdaa..df3e021 100644
--- a/metadata/service/control/control.yml
+++ b/metadata/service/control/control.yml
@@ -134,3 +134,6 @@
password: '${_param:keystone_admin_password}'
token: '${_param:keystone_service_token}'
tenant: admin
+ network:
+ engine: neutron
+ host: ${_param:cluster_vip_address}
\ No newline at end of file
diff --git a/metadata/service/control/single.yml b/metadata/service/control/single.yml
index 16a8452..3741c3f 100644
--- a/metadata/service/control/single.yml
+++ b/metadata/service/control/single.yml
@@ -129,3 +129,6 @@
password: '${_param:keystone_admin_password}'
token: '${_param:keystone_service_token}'
tenant: admin
+ network:
+ engine: neutron
+ host: ${_param:single_address}
\ No newline at end of file
diff --git a/opencontrail/config.sls b/opencontrail/config.sls
index 97c4003..9b2006f 100644
--- a/opencontrail/config.sls
+++ b/opencontrail/config.sls
@@ -150,6 +150,8 @@
- service: opencontrail_config_services
{%- endif %}
+{%- if not grains.get('virtual_subtype', None) == "Docker" %}
+
/etc/contrail/supervisord_config_files/ifmap.ini:
file.absent:
- require:
@@ -159,6 +161,8 @@
- service: opencontrail_config_services
{%- endif %}
+{%- endif %}
+
/etc/contrail/supervisord_config.conf:
file.managed:
- source: salt://opencontrail/files/{{ config.version }}/config/supervisord_config.conf
diff --git a/opencontrail/files/3.0/config.global.js b/opencontrail/files/3.0/config.global.js
index a6a252b..c511ca1 100644
--- a/opencontrail/files/3.0/config.global.js
+++ b/opencontrail/files/3.0/config.global.js
@@ -85,7 +85,7 @@
*****************************************************************************/
{%- if web.identity.engine == "keystone" %}
config.networkManager = {};
-config.networkManager.ip = '{{ web.master.host }}';
+config.networkManager.ip = '{{ web.network.host }}';
config.networkManager.port = '9696'
config.networkManager.authProtocol = 'http';
config.networkManager.apiVersion = [];
@@ -143,7 +143,7 @@
// Analytics API server and port.
config.analytics = {};
config.analytics.server_ip = '{{ web.analytics.host }}';
-config.analytics.server_port = '9081';
+config.analytics.server_port = '8081';
config.analytics.authProtocol = 'http';
config.analytics.strictSSL = false;
config.analytics.ca = '';
@@ -165,7 +165,7 @@
/* Specifiy true if subscription to discovery server should be enabled, else
* specify false. Other than true/false value here is treated as true
*/
-config.discoveryService.enable = true;
+config.discoveryService.enable = {{ web.get('enable_discovery', 'true')|lower }};
/* Job Server */
config.jobServer = {};
@@ -178,7 +178,7 @@
/* WebUI Redis Server */
config.redis_server_port = '6379';
-config.redis_server_ip = '127.0.0.1';
+config.redis_server_ip = '{{ web.cache.host }}';
config.redis_dump_file = '/var/lib/redis/dump-webui.rdb';
config.redis_password = '';
diff --git a/opencontrail/files/entrypoint.sh.web b/opencontrail/files/entrypoint.sh.web
new file mode 100644
index 0000000..0ac05fe
--- /dev/null
+++ b/opencontrail/files/entrypoint.sh.web
@@ -0,0 +1,25 @@
+{%- from "opencontrail/map.jinja" import web with context -%}
+#!/bin/bash -e
+
+cat /srv/salt/pillar/opencontrail-web.sls | envsubst > /tmp/opencontrail-web.sls
+mv /tmp/opencontrail-web.sls /srv/salt/pillar/opencontrail-web.sls
+
+salt-call --local --retcode-passthrough state.highstate
+
+{% for service in web.services %}
+service {{ service }} stop || true
+{% endfor %}
+
+if [ "$1" == "webserver" ]; then
+ echo "starting webserver"
+ su contrail --shell=/bin/sh -c '/usr/bin/nodejs /var/lib/contrail-webui/contrail-web-core/webServerStart.js'
+elif [ "$1" == "jobserver" ]; then
+ echo "starting jobserver"
+ su contrail --shell=/bin/sh -c '/usr/bin/node jobServerStart.js'
+else
+ echo "No parameter submitted, don't know what to start" 1>&2
+fi
+
+{#-
+vim: syntax=jinja
+-#}
\ No newline at end of file
diff --git a/opencontrail/map.jinja b/opencontrail/map.jinja
index a3be5a5..4c6c52d 100644
--- a/opencontrail/map.jinja
+++ b/opencontrail/map.jinja
@@ -71,7 +71,7 @@
{% set web = salt['grains.filter_by']({
'Debian': {
- 'pkgs': ['contrail-web-controller', 'nodejs-legacy'],
+ 'pkgs': ['contrail-web-controller', 'nodejs-legacy', 'gettext-base'],
'services': ['contrail-webui-webserver','contrail-webui-jobserver']
},
'RedHat': {
diff --git a/opencontrail/web.sls b/opencontrail/web.sls
index aad2251..0a5f2da 100644
--- a/opencontrail/web.sls
+++ b/opencontrail/web.sls
@@ -1,9 +1,6 @@
{%- from "opencontrail/map.jinja" import web with context %}
{%- if web.enabled %}
-include:
-- opencontrail.common
-
opencontrail_web_packages:
pkg.installed:
- names: {{ web.pkgs }}
@@ -21,6 +18,7 @@
- template: jinja
- require:
- pkg: opencontrail_web_packages
+{%- if not grains.get('noservices', False) %}
- watch_in:
- service: opencontrail_web_services
@@ -32,3 +30,16 @@
- file: /etc/contrail/config.global.js
{%- endif %}
+
+{%- if grains.get('virtual_subtype', None) == "Docker" %}
+
+opencontrail_web_entrypoint:
+ file.managed:
+ - name: /entrypoint.sh
+ - template: jinja
+ - source: salt://opencontrail/files/entrypoint.sh.web
+ - mode: 755
+
+{%- endif %}
+
+{%- endif %}
\ No newline at end of file