Python client for kibana. Provide ORM & vega rendering of visualizations
Project description
pybana
🚧 CAREFUL! WORK IN PROGRESS 🚧
What is this?
This is a kibana client written in python. It provides two kind of utilities
- An ORM layer. The goal is to ease the manipulation of kibana objects such as
index-pattern
,visualization
,dashboard
. This ORM provides:- Modeling using elasticsearch_dsl.
- helpers to extract useful information from kibana objects (ex: the index pattern associated to a visualization).
- reverse relationships between index-pattern & visualizations, visualizations & dashboards.
- A translation layer. The goal is to mimic kibana behaviour in terms of data fetching and visualization rendering. Thus, there are two types of translators:
- elastic. It transforms a kibana
visualization
definition into an elasticsearch query. - vega. It transforms a kibana
visualization
and data fetched into a vega spec.
- elastic. It transforms a kibana
Why?
The ORM was implemented to ease the automatic creation/update of kibana objects. For instance:
- If you've added an access-control layer on top of kibana to handle multi-tenancy, you may want to automate the creation of kibana indexes and the default index-pattern.
- If an
index-pattern
correspond to a table defined somewhere else (like a sql table), you may want to automate the creation ofindex-pattern
. - If a
dashboard
is defined in another database (like a sql db), you may want to delete the kibana object if the sql object is deleted.
The translation layer was implemented to progressively get rid of kibana. Even if kibana is a fantastic tool, it's more meant for internal use than for an integration in another application.
The elastic translator aims to generate almost identical queries to elasticsearch as kibana.
The vega translator tries to provide an equivalent in vega of kibana visualisation. Currently, it supports a limited set of options. Vega was chosen as it provide a complex but almost exhaustive visualization grammar. Vega'sapi allows the rendering of visualizations both on the backend and frontend and has bridges with the main js frameworks (react, vue…).
Roadmap
- ORM
- Automatic creation of index pattern
- Elastic translator:
- Handle more bucket type: ipv4, significatn terms etc
- Handle more metrics: top hit, sibling etc
- Vega translator:
- Handle more visualization types (gauge, metric, map etc)
- Versions
- For now, only elk stack 6.7.1 is handled.
License
Licensed under MIT license.
History
0.4.0
- Handle Category axe rotation
0.3.1
- Handle ZeroDivisionError in datasweet
0.3.0
- Rename
Context
toScope
- Add
BaseDocument.json_attrs
to simplify parsing of some fields (ex: Dashboard.panelsJSON) - Add datasweet support
- Add support for
using
in client
0.2.0
- Add
Search
model - Add
VegaRenderer
and vega-cli
0.1.0
- First version
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file pybana-0.4.0.tar.gz
.
File metadata
- Download URL: pybana-0.4.0.tar.gz
- Upload date:
- Size: 30.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 98c4639286e35e78df2a2c881a7cc2c49d8db0f96ad6e935053cdaec1c7ecd2d |
|
MD5 | d7b9f9ca6ea8a54386a1478619cef816 |
|
BLAKE2b-256 | 99c4b098f2f546b1283b38549f0337d49a2d3ee58c0d8cae884e6eae7c81fda5 |
File details
Details for the file pybana-0.4.0-py3-none-any.whl
.
File metadata
- Download URL: pybana-0.4.0-py3-none-any.whl
- Upload date:
- Size: 3.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.0.0 pkginfo/1.5.0.1 requests/2.21.0 setuptools/41.6.0 requests-toolbelt/0.9.1 tqdm/4.31.1 CPython/3.6.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 77bda193714fbf1e5eeff6e3fc513c84a381a3aa562e73b4198f64263fbe79a4 |
|
MD5 | c8249c794da8e7a76c8d90ef2c98af3a |
|
BLAKE2b-256 | fbd19dcf4a39ee3df318077667e522b45055bdea785a6f08ac8654d5a90fb627 |