 Johannes Grassler
		
	
	bb5178406c
	
	
	Add support for monasca-ui metrics API proxy
			Johannes Grassler
		
	
	bb5178406c
	
	
	Add support for monasca-ui metrics API proxy
		
			
			This commit adds support for the Monasca API proxy provided by the monasca-ui Horizon plugin. This Horizon plugin combined with direct access in the Monasca data source allows using a user's Horizon session for authenticating and authorizing access to the Monasca API. Change-Id: I98bd8ff7bcc55dcd911e87037b64840035542155 Story: 2001305 Task: 5856
Team and repository tags
Monasca Datasource - A datasource for use with the OpenStack Monasca api.
For more information on Monasca see the Monasca documentation
Authentication Options
Horizon Session
The Monasca Horizon plugin offers Horizon integration for Monasca. Among other things this plugin proxies the Monasca metrics API, using the Horizon session for authentication (as opposed to a Keystone token). This proxied API can be used to let this plugin access the Monasca API with the privileges of the user logged in to Horizon.
Note that this is entirely separate from Grafana's user management.
Setting this up requires the following steps:
- 
Install and configure the monasca-uiHorizon plugin. Specifically you will need to setGRAFANA_URLto/grafanaand pointGRAFANA_LINKSto your dashboards which can either be JSON dashboards you point to or in-database dashboards. In the former case set the links'rawattribute toTrueand theirpathattribute to the dashboard's path or full URL. In the latter case, set the links'rawattribute toFalse(or omit it entirely) and set theirpathattributes to the database dashboards' names.
- 
Enable mod_proxyandmod_proxy_httpin Apache:a2enmod proxy proxy_http
- 
Configure the VHost hosting your Horizon instance with a proxy path that points at your Grafana instance (the example assumes you are running Horizon on Apache - adapt as required for other web servers): ProxyPass "/grafana" "http://my.grafana.server:3000" ProxyPassReverse "/grafana" "http://my.grafana.server:3000"
- 
Configure Grafana's [server/root_url]setting to point at your dashboard node's/grafanapath:[server] root_url = %(protocol)s://%(domain)s/grafana
- 
Configure the plugin as follows: - Http settings:
- Url: http://my.dashboard.server/monitoring/proxy(substitute your dashboard's actual host name formy.dashboard.serverhere)
- Access: direct
 
- Url: 
- Authentication
- Auth: Horizon
 
 
- Http settings:
Steps (2) and (3) are neccessary to ensure both Grafana and Horizon are on the
same Host/Port from the browser's perspective. Otherwise the browser's XSS
protection mechanisms will omit the Horizon session cookie from any requests
triggered by the monasca-grafana-datasource plugin.
Keystone Authentication
When combined with Grafana Keystone authentication this datasource supports using login credentials to authenticate queries.
Keystone Token
Without the Grafana Keystone auth, this datasource can be used by inserting a keystone token into the datasource.  To get a keystone token download the python-openstackclient, source credentials and run openstack token issue.