Sqlスクラッチパッドコンポーネントとパブリック REST API を使用して、5 分で独自の SQL エディター (BYOE) を構築する

Published on 29 May 2021 in Version 4.10 / Development / Query - 4 minutes read - Last modified on 17 June 2021 - Read in en

Hueの新しいSQLスクラッチパッドWebコンポーネントとREST APIを、プロジェクトに活用する。

HueのSQL Editorプロジェクトは、10年以上にわたって進化し続けており、あらゆるデータベースやデータウェアハウスへのクエリを実行できます。 プロジェクト全体を完全に分離されたコンポーネントに分割したことが、急速に進化し、長い間生き続けることができた理由の一つです。

既に人気のあるSQL Parser コンポーネントに、 SQL スクラッチパッド コンポーネントが加わりました。

The SQL Scratchpad is a lightweight repackaging of the mature Hue SQL EditorSQL スクラッチパッドは、成熟したHueのSQLエディタの軽量の再パッケージング

主な追加の利点は、エディタの共有と統合が容易になったことです。したがって、エンドユーザにとって、より良い単一のエディタを作ることに集中するのではなく、車輪を再発明して様々な重複するSQLエディタを再作成することを避けるための、強力なケースとなります。

ここでは、コンポーネントの追加がいかに簡単であるかを示すライブデモを紹介します。

Adding the component in 3 lines and watching the interaction with the public API of demo.gethue.com3行でコンポーネントを追加し、demo.gethue.com の公開API との連携を確認する

仕組み

The SQL Editor is a module published to a registry called NPM. The component can then be integrated in any Web page. It then communicates via a REST API with the Hue server which interacts with the Databases we want to query.SQLエディタは、NPMというレジストリに公開されたモジュールです。 コンポーネントは、任意のWebページに統合することができます。 その後SQLエディタは、クエリを行いたいデータベースとやり取りするHueサーバーと、REST APIを介して通信します。

クエリエディタのコンポーネント

このコンポーネントをWebページに統合するのは簡単です。 以下のHTMLコードをindex.htmlファイルにコピーして貼り付け、FireFoxで開いてください。

<!DOCTYPE html>
<html>

<head>
  <title>SQL Scratchpad</title>
  <script type="text/javascript" src="https://unpkg.com/gethue/lib/components/SqlScratchpadWebComponent.js"></script>
</head>

<body>
  <div style="position: absolute; height: 100%; width: 100%">
    <sql-scratchpad api-url="https://demo.gethue.com" username="demo" password="demo" dialect="hive" />
  </div>
</body>

</html>

そして「それだけです」!

ローカルの HTML ページを Firefox で直接開く
ローカルの HTML ページを Firefox で直接開く

オートコンプリートはローカルパーサによって動作し、表示されます。 これは明らかに、自分自身ではSQL構文の手助けしかできません。 テーブルやカラムのリストのような動的コンテンツを取得して SQL クエリを実行するには、コンポーネントがクエリ API を指す必要があります。

次のステップとコンポーネントをより深く統合については、 NPM Hueレジストリ を参照してください。

クエリエディタAPI

エディタコンポーネントを真に生かすためには、ユーザーを認証してクエリを実行するサービスと対話する必要があります。

これを可能にするのが、新しい パブリック REST API であり、これまでよりもずっと簡単に使用できます。 これは通常のログインページとまったく同じ認証を利用しており、その後JWTトークンを提供するだけですみます。

たとえば、以下のようにアクセストークンを要求するだけです。

curl -X POST https://demo.gethue.com/api/token/auth -d 'username=demo&password=demo'

その後、以下の各コールでトークンの値を指定します。

curl -X POST https://demo.gethue.com/api/editor/execute/hive --data 'statement=SHOW TABLES' -H "Authorization: Bearer <token value>"

SQL クエリを実行するためのエンドポイントは大幅に簡素化され、SQL 方言とクエリステートメント、または以前に実行のために送信されたクエリの ID などの必要な情報のみが要求されるようになりました。

curl -X POST https://demo.gethue.com/api/editor/check_status --data 'operationId=63ce87ba-ca0f-4653-8aeb-e9f5c1781b78'

この最初のリリースでは、SQLコンテンツの編集と実行が可能です。 完全なエディタの一般的な機能が徐々に統合されていますが、例えば以下のような機能があります。

  • クエリの書式設定と共有
  • 結果のダウンロード
  • ポップアップでスクラッチパッドを開く(例:PySparkでの埋め込みSQLの編集)

認証情報を必要としないようにするために、SSO とローカルの JWT トークンを検証するオプションも近日公開予定です。

SQLスクラッチパッドンポーネント とそのAPIは急速に進化しています。 今こそお試しいただいて、 フィードバック を送っていただいたり、貢献していただくための絶好の機会です!

どうぞよろしくお願いします!

Romain from the Hue Team


comments powered by Disqus

More recent stories

10 June 2021
Hue4.10(新しいSQLエディタコンポーネント、REST API、小さなファイルのインポート、Slackアプリなど)がリリースされました!
Read More
29 May 2021
Sqlスクラッチパッドコンポーネントとパブリック REST API を使用して、5 分で独自の SQL エディター (BYOE) を構築する
Read More
26 May 2021
改善されたHueのImporter -- ファイルの選択、方言の選択、テーブルの作成
Read More