Redash API Client
Project description
Redash-API-Client
Redash API Client written in Python.
Dependencies
- Python3.6+
Installation
pip install redash-api-client
Getting Started
from redashAPI import RedashAPIClient
# Create API client instance
"""
:args:
API_KEY
REDASH_HOST (optional): `http://localhost:5000` by default
"""
Redash = RedashAPIClient(API_KEY, REDASH_HOST)
Redash's RESTful API
URI | Supported Methods |
---|---|
users | GET, POST |
users/1 | GET, POST |
data_sources | GET, POST |
data_sources/1 | GET, POST, DELETE |
queries | GET, POST |
queries/1 | GET, POST, DELETE |
query_results | POST |
query_results/1 | GET |
visualizations | POST |
visualizations/1 | POST, DELETE |
dashboards | GET, POST |
dashboards/slug | GET, POST, DELETE |
widgets | POST |
widgets/1 | POST, DELETE |
### EXAMPLE ###
# List all Data Sources
res = Redash.get('data_sources')
res.json()
"""
[
{
'name': 'data_source1',
'pause_reason': None,
'syntax': 'sql',
'paused': 0,
'view_only': False,
'type': 'pg',
'id': 1
},
...
]
"""
# Retrieve specific Data Source
res = Redash.get('data_sources/1')
res.json()
"""
{
"scheduled_queue_name": "scheduled_queries",
"name": "test1",
"pause_reason": "None",
"queue_name": "queries",
"syntax": "sql",
"paused": 0,
"options": {
"password": "--------",
"dbname": "bi",
"user": ""
},
"groups": {
"1":False
},
"type": "pg",
"id": 1
}
"""
# Create New Data Source
Redash.post('data_sources', {
"name": "New Data Source",
"type": "pg",
"options": {
"dbname": DB_NAME,
"host": DB_HOST,
"user": DB_USER,
"passwd": DB_PASSWORD,
"port": DB_PORT
}
})
"""
{
"scheduled_queue_name": "scheduled_queries",
"name": "New Data Source",
"pause_reason": "None",
"queue_name": "queries",
"syntax": "sql",
"paused": 0,
"options": {
"dbname": DB_NAME,
"host": DB_HOST,
"user": DB_USER,
"passwd": DB_PASSWORD,
"port": DB_PORT
},
"groups": {
"2": False
},
"type": "pg",
"id": 2
}
"""
# Delete specific Data Source
Redash.delete('data_sources/2')
Create Data Source
-
_type
- Type of Data Source. (Supported types)
-
name
- Name for Data Source.
-
options
- Configuration.
### EXAMPLE ###
Redash.create_data_source("pg", "First Data Source", {
"dbname": DB_NAME,
"host": DB_HOST,
"user": DB_USER,
"passwd": DB_PASSWORD,
"port": DB_PORT
})
Create Query
-
ds_id
- Data Source ID.
-
name
- Name for query.
-
qry
- Query string.
-
desc (optional)
- Description.
-
with_results (optional)
- Generate query results automatically,
True
by default.
- Generate query results automatically,
-
options (optional)
- Custom options.
### EXAMPLE ###
Redash.create_query(1, "First Query", "SELECT * FROM table_name;")
Refresh Query
-
qry_id
- Query ID.
### EXAMPLE ###
Redash.refresh_query(1)
Generate Query Result
-
ds_id
- Data Source ID.
-
qry
- Query String.
-
qry_id (optional)
- Query ID.
-
max_age (optional)
- If query results less than max_age seconds old are available, return them, otherwise execute the query; if omitted or -1, returns any cached result, or executes if not available. Set to zero to always execute.
-
parameters (optional)
- A set of parameter values to apply to the query.
-
return_results (optional)
- Return results if query is executed successfully,
True
by default.
- Return results if query is executed successfully,
### EXAMPLE ###
Redash.generate_query_results(1)
Query and Wait Result
-
ds_id
- Data Source ID.
-
qry
- Query String.
-
timeout (optional)
- Defines the time in seconds to wait before cutting the request.
### EXAMPLE ###
Redash.query_and_wait_result(1, 'select * from my_table;', 60)
Create Visualization
-
qry_id
- Query ID.
-
_type
- Type of Visualization. (
table
,line
,column
,area
,pie
,scatter
,bubble
,box
,pivot
)
- Type of Visualization. (
-
name
- Name for Visualization.
-
columns (optional)
- Columns for Table. (Required if _type is
table
)
- Columns for Table. (Required if _type is
-
x_axis (optional)
- Column for X Axis. (Required if _type is not
table
norpivot
)
- Column for X Axis. (Required if _type is not
-
y_axis (optional)
- Columns for Y Axis (Required if _type is not
table
norpivot
)
- Columns for Y Axis (Required if _type is not
-
group_by (optional)
- Group by specific column.
-
custom_options (optional)
- Custom options for Visualization.
-
desc (optional)
- Description.
### EXAMPLE 1 ###
Redash.create_visualization(1, "table", "First Visualization", columns=[
{"name": "column1", "type": "string"},
{"name": "column2", "type": "datetime"}
])
### EXAMPLE 2 ###
Redash.create_visualization(1, "line", "Second Visualization", x_axis="column1", y_axis=[
{"type": "line", "name": "column2", "label": "c2"}
])
Create Dashboard
-
name
- Name for Dashboard.
### EXAMPLE ###
Redash.create_dashboard("First Dashboard")
Add Widget into Dashboard
-
db_id
- Dashboard ID.
-
text (optional)
- Text Widget.
-
vs_id (optional)
- Visualization ID.
-
full_width (optional)
- Full width or not,
False
by default.
- Full width or not,
-
position (optional)
- Custom position for Widget.
### EXAMPLE 1 ###
Redash.add_widget(1, text="Test")
### EXAMPLE 2 ###
Redash.add_widget(1, visualization_id=1, full_width=True)
Publish Dashboard
-
db_id
- Dashboard ID.
### EXAMPLE ###
url = Redash.publish_dashboard(1)
License
This project is licensed under the MIT License - see the LICENSE file for details.
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 redash-api-client-0.2.9.tar.gz
.
File metadata
- Download URL: redash-api-client-0.2.9.tar.gz
- Upload date:
- Size: 6.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4d0d6f83f3cc959a953246557ee1e494df207afaccabc06001274817980b6ead |
|
MD5 | 1e5b578847f62ad769fe12ea62eab1e1 |
|
BLAKE2b-256 | bbaa6c653f79e1d3ee36d6c02f6002da382ddfc1e6839b88c70b7fae141348d3 |
File details
Details for the file redash_api_client-0.2.9-py3-none-any.whl
.
File metadata
- Download URL: redash_api_client-0.2.9-py3-none-any.whl
- Upload date:
- Size: 7.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.4.0 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.9
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | aaa934fbe0840086bff674fe9a7680a4d1b3be3715c1c12c7690a54ec319e457 |
|
MD5 | 61564db232e144a5af99682bbeda8e89 |
|
BLAKE2b-256 | c01d66b8e6d737d09862579c42682aacb919af3305374ce4433a1de445912b8c |