blob: 2dd1b6423a7ad91a99c0b11016e933b5cffaae5e [file] [log] [blame]
{%- from "opencontrail/map.jinja" import common,web with context %}
/*
* Copyright (c) 2014 Juniper Networks, Inc. All rights reserved.
*/
var config = {};
config.orchestration = {};
{%- if web.identity.engine == "keystone" %}
config.orchestration.Manager = 'openstack'
{%- if web.identity.version == "3" %}
config.multi_tenancy = {};
config.multi_tenancy.enabled = true;
{%- endif %}
{%- else %}
config.orchestration.Manager = 'none'
config.multi_tenancy = {};
config.multi_tenancy.enabled = false;
{%- endif %}
/****************************************************************************
* This boolean flag indicates to communicate with Orchestration
* modules(networkManager, imageManager, computeManager, identityManager,
* storageManager), should the webServer communicate using the
* ip/port/authProtocol/apiVersion as specified in this file, or as returned
* from auth catalog list.
* Note: config.identityManager.apiVersion is not controlled by this boolean
* flag.
*
* true - These values should be taken from this config
* file.
* false - These values should be taken from auth catalog list
*
*****************************************************************************/
config.serviceEndPointFromConfig = true;
/****************************************************************************
* This boolean flag specifies wheather region list should be taken from config
* file or from keystone endpoint
* true - If set as true, then keystone endpoint is taken from
* config.regions
* false - If set as false, then keystone endpoint is taken from
* config.identityManager
*
****************************************************************************/
config.regionsFromConfig = false;
/****************************************************************************
* Below are the configs for Api Server and analytics Service type & name as
* provisioned in keystone
*
* apiServiceType - Service Type for apiServer, default value is apiServer
* opServiceType - Service Type for analytics, default value is opServer
*
* Note: If there are multiple api server or analytices nodes in a specific
* region, then provision service type/name as ApiServer0, ApiServer1,
* ApiServer2 etc, similarly for analytics node: OpServer0, OpServer1,
* OpServer2 etc.
*
****************************************************************************/
config.endpoints = {};
config.endpoints.apiServiceType = 'ApiServer';
config.endpoints.opServiceType = 'OpServer';
/****************************************************************************
* Mapping to region name with keystone endpoint
*
* For example:
* config.regions.RegionOne = 'http://nodeIp:5000/v2.0';
* config.regions.RegionTwo = 'http://nodeIp:5000/v3';
*
****************************************************************************/
config.regions = {};
{%- if web.identity.engine != "none" %}
config.regions['{{ web.identity.get("region", "RegionOne") }}'] = 'http://{{ web.identity.host }}:5000/v{{ web.identity.version }}';
{%- endif %}
/****************************************************************************
* This boolean flag indicates if serviceEndPointFromConfig is set as false,
* then to take IP/Port/Protocol/Version information from auth catalog,
* should publicURL OR internalURL will be used.
*
* true - publicURL in endpoint will be used to retrieve IP/Port/Protocol/
* Version information
* false - internalURL in endpoint will be used to retrieve
* IP/Port/Protocol/Version information
*
* NOTE: if config.serviceEndPointFromConfig is set as true, then this flag
* does not have any effect.
*
*****************************************************************************/
config.serviceEndPointTakePublicURL = false;
/****************************************************************************
* Below are the config options for all Orchestration Modules below:
* - networkManager
* - imageManager
* - computeManager
* - identityManager
* - storageManager
* - cnfg
* - analytics
*
* Options:
* ip:
* IP to connect to for this Server.
* port:
* Port to connect to for this server
* authProtocol:
* Specify authProtocol either 'http' or 'https'
* apiVersion:
* REST API Version for this server to connect to.
* Specify a list of Versions in array notation.
* Below are the supported list of apiVersion for the modules as of now:
* imageManager - ['v1', 'v2']
* computeManager - ['v1.1', 'v2']
* identityManager - ['v2.0']
* storageManager - ['v1']
*
* Not applicable for cnfg/analytics as of now
* strictSSL:
* If true, requires certificates to be valid
* ca:
* An authority certificate to check the remote host against,
* if you do not want to specify then use ''
*****************************************************************************/
{%- if web.identity.engine == "keystone" %}
config.networkManager = {};
config.networkManager.ip = '{{ web.network.host }}';
config.networkManager.port = '9696'
config.networkManager.authProtocol = 'http';
config.networkManager.apiVersion = [];
config.networkManager.strictSSL = false;
config.networkManager.ca = '';
config.imageManager = {};
config.imageManager.ip = '{{ web.identity.host }}';
config.imageManager.port = '9292';
config.imageManager.authProtocol = 'http';
config.imageManager.apiVersion = ['v1', 'v2'];
config.imageManager.strictSSL = false;
config.imageManager.ca = '';
config.computeManager = {};
config.computeManager.ip = '{{ web.identity.host }}';
config.computeManager.port = '8774';
config.computeManager.authProtocol = 'http';
config.computeManager.apiVersion = ['v1.1', 'v2'];
config.computeManager.strictSSL = false;
config.computeManager.ca = '';
config.identityManager = {};
config.identityManager.ip = '{{ web.identity.host }}';
config.identityManager.port = '5000';
config.identityManager.authProtocol = 'http';
/******************************************************************************
* Note: config.identityManager.apiVersion is not controlled by boolean flag
* config.serviceEndPointFromConfig. If specified apiVersion here, then these
* API versions will be used while using REST API to identityManager.
* If want to use with default apiVersion(v2.0), then can specify it as
* empty array.
******************************************************************************/
config.identityManager.apiVersion = ['v{{ web.identity.version }}'];
config.identityManager.strictSSL = false;
config.identityManager.ca = '';
config.storageManager = {};
config.storageManager.ip = '{{ web.identity.host }}';
config.storageManager.port = '8776';
config.storageManager.authProtocol = 'http';
config.storageManager.apiVersion = ['v1'];
config.storageManager.strictSSL = false;
config.storageManager.ca = '';
{%- endif %}
// VNConfig API server and port.
config.cnfg = {};
config.cnfg.server_ip = '{{ web.master.host }}';
config.cnfg.server_port = '8082';
config.cnfg.authProtocol = 'http';
config.cnfg.strictSSL = false;
config.cnfg.ca = '';
config.cnfg.statusURL = "/global-system-configs";
// Analytics API server and port.
config.analytics = {};
config.analytics.server_ip = '{{ web.analytics.host }}';
config.analytics.server_port = '8081';
config.analytics.authProtocol = 'http';
config.analytics.strictSSL = false;
config.analytics.ca = '';
config.analytics.statusURL = "/analytics/uves/bgp-peers";
//DNS API Server and port.
/* Please note: being introspect port, SSL options for dns should come from
config.introspect.ssl configuration
*/
config.dns = {};
config.dns.server_ip = ['{{ web.master.host }}']; //check this
config.dns.server_port = '8092';
config.dns.statusURL = "/Snh_PageReq?x=AllEntries%20VdnsServersReq";
// vcenter related parameters
config.vcenter = {};
config.vcenter.server_ip = '127.0.0.1'; //vCenter IP
config.vcenter.server_port = '443'; //Port
config.vcenter.authProtocol = 'https'; //http or https
config.vcenter.datacenter = 'vcenter'; //datacenter name
config.vcenter.dvsswitch = 'vswitch'; //dvsswitch name
config.vcenter.strictSSL = false; //Validate the certificate or ignore
config.vcenter.ca = ''; //specify the certificate key file
{%- if common.vendor == "juniper" %}
config.vcenter.wsdl = '/usr/src/contrail/contrail-web-core/webroot/js/vim.wsdl';
{%- else %}
config.vcenter.wsdl = '/var/lib/contrail-webui/contrail-web-core/webroot/js/vim.wsdl';
{%- endif %}
/*****************************************************************************
* The below configurations descibe the SSL options for connecting to different
* introspect port.
*
* enabled:
* Boolean flag to enable or disable ssl while connecting to different
* introspect port
* key:
* Private key to use for SSL
* cert:
* Public x509 certificate to use
* ca:
* A string, Buffer or array of strings or Buffers of trusted certificates
* in PEM format. These are used to authorize connections.
* strictSSL:
* If true, the server certificate is verified against the list of
* supplied CAs
*****************************************************************************/
config.introspect = {};
config.introspect.ssl = {};
config.introspect.ssl.enabled = false;
config.introspect.ssl.key = '';
config.introspect.ssl.cert = '';
config.introspect.ssl.ca = '';
config.introspect.ssl.strictSSL = false;
/* Job Server */
config.jobServer = {};
config.jobServer.server_ip = '127.0.0.1';
config.jobServer.server_port = '3000';
/* Upload/Download Directory */
config.files = {};
config.files.download_path = '/tmp';
/* WebUI Redis Server */
config.redis_server_port = '6379';
config.redis_server_ip = '{{ web.cache.host }}';
{%- if common.vendor == "juniper" %}
config.redis_dump_file = '/var/lib/redis/dump.rdb';
{%- else %}
config.redis_dump_file = '/var/lib/redis/dump-webui.rdb';
{%- endif %}
config.redis_password = '{{ web.cache.get("password", "") }}';
/* Cassandra Server */
config.cassandra = {};
config.cassandra.server_ips = [{%- for member in web.members %}'{{ member.host }}'{% if not loop.last %},{% endif %}{%- endfor %}];
config.cassandra.server_port = '{{ web.database.port }}';
config.cassandra.enable_edit = false;
/* KUE Job Scheduler */
config.kue = {};
config.kue.ui_port = '3002'
/* IP List to listen on */
config.webui_addresses = ['0.0.0.0'];
/* Is insecure access to WebUI?
* If set as false, then all http request will be redirected
* to https, if set true, then no https request will be processed, but only http
* request
*/
config.insecure_access = false;
// HTTP port for NodeJS Server.
config.http_port = '{{ web.get("http",{}).get("port","8080") }}';
// HTTPS port for NodeJS Server.
config.https_port = '{{ web.get("https",{}).get("port","8143") }}';
// Activate/Deactivate Login.
config.require_auth = false;
/* Number of node worker processes for cluster. */
config.node_worker_count = 1;
/* Number of Parallel Active Jobs with same type */
config.maxActiveJobs = 10;
/* Redis DB index for Web-UI */
config.redisDBIndex = 3;
config.featurePkg = {};
config.featurePkg.webController = {};
{%- if common.vendor == "juniper" %}
/* Logo File: Use complete path of logo file location */
config.logo_file = '/usr/src/contrail/contrail-web-core/webroot/img/juniper-networks-logo.png';
/* Favicon File: Use complete path of favicon file location */
config.favicon_file = '/usr/src/contrail/contrail-web-core/webroot/img/juniper-networks-favicon.ico';
/* Add new feature Package Config details below */
config.featurePkg.webController.path = '/usr/src/contrail/contrail-web-controller';
config.featurePkg.webController.enable = true;
{%- else %}
/* Logo File: Use complete path of logo file location */
config.logo_file = '/var/lib/contrail-webui/contrail-web-core/webroot/img/opencontrail-logo.png';
/* Favicon File: Use complete path of favicon file location */
config.favicon_file = '/var/lib/contrail-webui/contrail-web-core/webroot/img/juniper-networks-favicon.ico';
/* Add new feature Package Config details below */
config.featurePkg.webController.path = '/var/lib/contrail-webui/contrail-web-controller';
config.featurePkg.webController.enable = true;
{%- endif %}
/* Enable/disable Stat Query Links in Sidebar*/
config.qe = {};
config.qe.enable_stat_queries = false;
/* Configure level of logs, supported log levels are:
debug, info, notice, warning, error, crit, alert, emerg
*/
config.logs = {};
config.logs.level = 'debug';
/******************************************************************************
* Boolean flag getDomainProjectsFromApiServer indicates wheather the project
* list should come from API Server or Identity Manager.
* If Set
* - true, then project list will come from API Server
* - false, then project list will come from Identity Manager
* Default: false
*
******************************************************************************/
config.getDomainProjectsFromApiServer = {{ web.get('projects_from_api', 'false')|lower }};
/*****************************************************************************
* Boolean flag L2_enable indicates the default forwarding-mode of a network.
* Allowed values : true / false
* Set this flag to true if all the networks are to be L2 networks,
* set to false otherwise.
*****************************************************************************/
config.network = {};
config.network.L2_enable = false;
/******************************************************************************
* Boolean flag getDomainsFromApiServer indicates wheather the domain
* list should come from API Server or Identity Manager.
* If Set
* - true, then domain list will come from API Server
* - false, then domain list will come from Identity Manager
* Default: true
* NOTE: if config.identityManager.apiVersion is set as v2.0, then this flag
* does not have any effect, in that case the domain list is retrieved
* from API Server.
*
*****************************************************************************/
config.getDomainsFromApiServer = false;
config.jsonSchemaPath = "/var/lib/contrail-webui/contrail-web-core/src/serverroot/configJsonSchemas";
// Export this as a module.
module.exports = config;
config.features = {};
config.features.disabled = [];