FineReport で Outlook のデータ を利用する

Jerod Johnson
Jerod Johnson
Director, Technology Evangelism
FineReport で Outlook のデータ をJDBC データソースとして設定する方法。



CData JDBC Driver for Outlook は、JDBC 標準を完全に実装しており、さまざまなBI、レポート、ETL ツール、カスタムアプリケーションに Outlook のデータ への接続を提供します。この記事では、FineReport で Outlook のデータ をJDBC データソースとして設定し、レポートデザイナーで Outlook のデータ をテーブルとして表示する方法を説明します。

Outlook のデータ のJDBC データソースをセットアップする

以下の手順に従って、FineReport のデータベース接続として Outlook のデータ を設定します。

  1. CData JDBC Driver for Outlook のインストールディレクトリにあるlib フォルダから、cdata.jdbc.api.jar ファイルをFineReport のインストールディレクトリにあるlib フォルダにコピーします。cdata.jdbc.api.lic ファイルも同様にコピーしてください。
  2. ServerタブからDefine Data Connectionを選択し、クリックして新しい接続を追加してJDBCをクリックします。

続いて、ウィンドウでデータ接続の定義を設定します。

  1. Database: Others
  2. JDBC Driver: cdata.jdbc.api.APIDriver
  3. URL: セミコロン区切りの接続プロパティを使用した標準のJDBC 接続文字列を入力します。

    OAuth 認証の設定

    Microsoft Graph API は認証に OAuth 2.0 を使用します。OAuth 認証情報(Client ID と Client Secret)を取得するには、Microsoft Azure Portal でアプリケーションを登録する必要があります。

    OAuth 認証情報の取得

    1. Azure Portal にログインします。
    2. Azure Active Directory > App registrations に移動します。
    3. New registration をクリックして新しいアプリケーションを作成します。
    4. アプリケーション名を入力し、適切なアカウントの種類を選択します。
    5. Redirect URI をアプリケーションのコールバック URL に設定します(デスクトップアプリの場合は http://localhost:33333 など)。
    6. Register をクリックしてアプリケーションを作成します。
    7. アプリケーションの概要ページで Application (client) ID をコピーします。これが OAuthClientId になります。
    8. Certificates & secrets に移動して、新しいクライアントシークレットを作成します。
    9. クライアントシークレットの値をコピーします。これが OAuthClientSecret になります。
    10. API permissions に移動して、必要な Microsoft Graph API の権限を追加します:
      • Mail.Read - メールメッセージへのアクセス用
      • Contacts.Read - 連絡先へのアクセス用
      • Calendars.Read - カレンダーイベントへのアクセス用
      • Tasks.Read - To Do タスクへのアクセス用
      • offline_access - リフレッシュトークンの取得用
    11. Grant admin consent をクリックして、これらの権限を付与します。

    OAuth での接続

    以下の接続プロパティを設定して接続を確立してください:

    • AuthScheme:OAuth に設定します。
    • InitiateOAuthGETANDREFRESH に設定します。CData API Profile for Outlook が OAuth プロセスを自動的に進め、アクセストークンを取得します。
    • OAuthClientId:Azure Portal の Application (client) ID に設定します。
    • OAuthClientSecret:Azure Portal のクライアントシークレットの値に設定します。
    • TenantId:Azure AD のテナント識別子(GUID または 'contoso.onmicrosoft.com' のようなドメイン名)に設定します。
    • CallbackURL:アプリ登録で指定したリダイレクト URI に設定します(デスクトップアプリの場合は http://localhost:33333 など)。

    接続文字列の例

    Profile=C:\profiles\Outlook.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;TenantId=your_tenant_id;CallbackUrl=http://localhost:33333;
    

    組み込みの接続文字列デザイナー

    JDBC URL の作成には、Outlook JDBC Driver に組み込まれている接続文字列デザイナーを使用してください。JAR ファイルをダブルクリックするか、コマンドラインからjar ファイルを実行します。

    java -jar cdata.jdbc.api.jar
    

    接続プロパティを入力し、接続文字列をクリップボードにコピーします。

    JDBC URL を設定する際に、Max Rows 接続プロパティも設定しておくことをお勧めします。これにより、返される行数が制限されるため、レポートやビジュアライゼーションを設計する際のパフォーマンス向上に役立ちます。

    JDBC URL の例を以下に示します。

        jdbc:api:Profile=C:\profiles\Outlook.apip;AuthScheme=OAuth;InitiateOAuth=GETANDREFRESH;OAuthClientId=your_client_id;OAuthClientSecret=your_client_secret;TenantId=your_tenant_id;CallbackUrl=http://localhost:33333;
      
  4. Connection pool attributesをクリックし、Test before getting connectionsNoに設定します。

Test connectionをクリックして、接続が正しく設定されていることを確認します。これで、Outlook への接続を設定し、FineReport のデータソースとして使用できるようになります。

レポートデザイナーで Outlook のデータ を選択する

  1. クリックして新しいテンプレートデータセットを追加し、DB queryを選択してデータベースクエリウィンドウを開きます。
  2. ドロップダウンリストから、作成したJDBC 接続を選択します。
  3. 左ペインにOutlook のエンティティがテーブルとして表示されます。
  4. ロードするOutlook のデータ のテーブルとカラムに対してSELECT 文を記述します。
  5. プレビューをクリックすると、データがテーブルとして表示されます。

このように簡単な手順で、FineReport で Outlook をJDBC データソースとして利用できるようになります。

はじめる準備はできましたか?

API Driver で Outlook のライブデータに接続

Outlook に接続