
Currently we only support dashboards for Grafana, this is about to change. For example, we also need to add the ability to create datasources and even users. Here we are breaking out the logic into more specific functions. Additionaly, this helps when we eventually break out this code into python-grafana. Change-Id: I10a618adbf9052c8dccda38fefb7abf3a148d3b6 Signed-off-by: Paul Belanger <pabelanger@redhat.com>
50 lines
1.4 KiB
Python
50 lines
1.4 KiB
Python
# Copyright 2015 Red Hat, Inc.
|
|
#
|
|
# 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.
|
|
|
|
try:
|
|
from urllib.parse import urljoin
|
|
except ImportError:
|
|
from urlparse import urljoin
|
|
|
|
import requests
|
|
|
|
from grafana_dashboards.grafana.dashboard import Dashboard
|
|
|
|
|
|
class Grafana(object):
|
|
|
|
def __init__(self, url, key=None):
|
|
"""Create object for grafana instance
|
|
|
|
:param url: URL for Grafana server
|
|
:type url: str
|
|
:param key: API token used for authenticate
|
|
:type key: str
|
|
|
|
"""
|
|
|
|
base_url = urljoin(url, 'api/dashboards/db/')
|
|
session = requests.Session()
|
|
session.headers.update({
|
|
'Content-Type': 'application/json',
|
|
})
|
|
# NOTE(pabelanger): Grafana 2.1.0 added basic auth support so now the
|
|
# api key is optional.
|
|
if key:
|
|
session.headers.update({
|
|
'Authorization': 'Bearer %s' % key,
|
|
})
|
|
|
|
self.dashboard = Dashboard(base_url, session)
|