Pentaho Report Designer でDrift のデータを連携利用
CData JDBC Driver for Drift のデータ を使えば、ダッシュボードやレポートからリアルタイムデータにアクセスできます。この記事では、Drift のデータにJDBC データソースとして接続し、Pentaho でDrift のデータをもとにしたレポートを公開する方法を説明します。
接続してレポートを作成
- インストールディレクトリのlib サブフォルダ内にあるドライバーのJAR ファイルを、Pentaho ディレクトリ内の\Report-Designer\lib\jdbc\ フォルダにコピーします。
- \Report-Designer\ フォルダ内のreport-designer.bat ファイルを実行してReport-Designer UI を開きます。
Data -> Add Data Source -> Advanced -> JDBC(Custom)をクリックし、新しいDrift 接続を作成して、ドライバーで新しいデータソースを作成します。 表示されるダイアログで、以下のように接続プロパティを設定します。
Custom Connection URL property:JDBC URL を入力します。JDBC URL はjdbc:api: で始まり、その後にセミコロン区切りで接続プロパティを指定します。
まず、Profile 接続プロパティをディスク上のDrift プロファイルの場所に設定します(例:C:\profiles\Drift.apip)。次に、ProfileSettings 接続プロパティをDrift の接続文字列に設定します(以下を参照)。
Drift API プロファイル設定
Drift はOAuth ベースの認証を使用します。
まず、https://dev.drift.com でアプリケーションを登録する必要があります。アプリにはclient ID とclient secret が割り当てられます。OAuthClientId およびOAuthClientSecret プロパティを介して、これらを接続文字列に設定します。OAuth アプリケーションの設定の詳細については、https://devdocs.drift.com/docs/ を参照してください。
ProfileSettings 接続プロパティに以下のオプションを設定すると、接続できるようになります。
- AuthScheme:OAuth に設定します。
- OAuthClientId:アプリ設定で指定されたClient Id に設定します。
- OAuthClientSecret:アプリ設定で指定されたClient Secret に設定します。
- CallbackURL:アプリ設定で指定したRedirect URI に設定します。
- InitiateOAuth:GETANDREFRESH に設定します。InitiateOAuth を使用して、OAuthAccessToken を取得するプロセスを管理できます。
組み込みの接続文字列デザイナー
JDBC URL の構成については、Drift JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインからJAR ファイルを実行します。
java -jar cdata.jdbc.api.jar
接続プロパティを入力し、接続文字列をクリップボードにコピーします。
JDBC URL を設定する際、Max Rows 接続プロパティの設定も検討してください。これにより返される行数が制限されます。特にレポートやビジュアライゼーションを設計する際のパフォーマンス向上に役立ちます。
一般的なJDBC URL は次のとおりです:
jdbc:api:Profile=C:\profiles\Drift.apip;Authscheme=OAuth;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;CallbackUrl=your_callback_url;
- Custom Driver Class Name:cdata.jdbc.api.APIDriver を入力します。
- User Name:認証に使用するユーザー名。
- Password:認証に使用するパスワード。
レポートにDrift のデータを追加
Drift のデータをもとにレポートを作成する準備が整いました。
-
レポートにDrift のソースを追加します。Data -> Add Data Source -> JDBC をクリックしてデータソースを選択します。
クエリを設定します。この記事では以下のクエリを使用します:
SELECT Id, DisplayName FROM Contacts WHERE LastName = 'Stark'
- レポートにチャートをドラッグし、ダブルクリックしてチャートを編集します。レポートを実行してチャートを表示します。このクエリの結果を使用して、Contacts テーブルのシンプルなチャートを作成できます。
- 最後に、レポートを実行してチャートを確認します。