list-database.py
# coding: utf-8
import pprint
import json
import requests
host = 'xxx.xxx.xxx.xxx:8080' # Supersetのホスト名またはIPアドレスとポート
user = 'admin' # ユーザ名
password = 'adminpass' # ユーザパスワード
base = "http://{}".format(host)
# ユーザ名とパスワードでアクセストークンの取得
res_login = requests.post(base + "/api/v1/security/login",
json = {
"password": user,
"provider": "db",
"refresh": True,
"username": password
}
)
access_token = res_login.json()['access_token']
print(access_token)
# CSRFトークンの取得
res_csrf = requests.get(base + "/api/v1/security/csrf_token",
headers = {
'Authorization': "Bearer {}".format(access_token)
}
)
csrf_token = res_csrf.json()['result']
print(csrf_token)
# API呼び出し用Request headers
api_headers = {
'Referer': base,
'Authorization': "Bearer {}".format(access_token),
'X-CSRFToken': csrf_token
}
# データベース一覧
res_db = requests.get(base + "/api/v1/database",
headers = api_headers
)
pprint.pprint(res_db.json())
for db in res_db.json()['result']:
print("---")
print("database name: {}".format(db['database_name'])) # データベース名
print("status: {}".format(db['backend'])) # バックエンド
・実行方法
python3 list-database.py
関連情報
・その他のApache Supersetの情報は、以下のまとめページを参照してください。Apache Supersetのまとめ
0 件のコメント:
コメントを投稿