Axios と CData Connect AI で HCL Domino に接続した Web アプリを構築

Jerod Johnson
Jerod Johnson
Senior Technology Evangelist
CData Connect AI を使用してライブHCL Domino のデータに接続し、Axios で HCL Domino に接続した Web アプリを構築します。

Axios は開発者が Web ブラウザや Node.js からサーバーに HTTP リクエストを送信できる JavaScript ライブラリです。CData Connect AI と組み合わせることで、Web アプリからライブHCL Domino のデータにアクセスできます。この記事では、HCL Domino に接続し、Axios でライブHCL Domino のデータにアクセスできる Web アプリを構築する方法を説明します。

Axios から HCL Domino に接続

Axios で HCL Domino を操作するには、Connect AI から HCL Domino に接続し、ユーザーにアクセス権を提供し、HCL Domino のデータ 用のワークスペースを作成する必要があります。

Connect AI から HCL Domino に接続

CData Connect AI はシンプルなポイントアンドクリックインターフェースでデータソースに接続できます。

  1. Connect AI にログインして「Sources」をクリック、次に「 Add Connection」をクリック
  2. 接続を追加パネルから「HCL Domino」を選択
  3. HCL Domino に接続するために必要な認証プロパティを入力します。

    Domino への接続

    それでは、Domino のデータに接続していきましょう。接続するには、以下のプロパティを設定してください。

    • URL:Domino データベースをホスティングしているサーバーのホスト名またはIP アドレス。Domino データベースをホスティングしているサーバーのポートを含めます。例:http://sampleserver:1234/
    • DatabaseScope:Domino Web UI でのスコープ名。CData 製品は、指定されたスコープに適合するスキーマのフォームとビューを公開します。Domino Admin UI で、サイドバーのScopes メニューを選択してください。このプロパティを既存のスコープ名に設定します

    Domino での認証

    続いて、認証方法を設定しましょう。Domino では、ログインクレデンシャル(OAuthPassword)またはMicrosoft Entra ID(AzureAD)のいずれかによる認証をサポートしています。

    ログインクレデンシャル

    ログインクレデンシャルで認証するには、以下のプロパティを設定してください:

    • AuthSchemeOAuthPassword
    • User:認証するDomino ユーザーのユーザー名
    • Password:認証するDomino ユーザーに関連付けられたパスワード

    ドライバーがログインクレデンシャルを使用して、自動的にOAuth トークン交換を実行します。

    Microsoft Entra ID(Azure AD)

    この認証方法は、Azure Active Directory をIdP として使用してJWT トークンを取得します。Azure Active Directory にカスタムのアプリケーションを作成し、それをIdP として設定する必要があります。詳しい手順については、ヘルプドキュメントの指示に従ってください。その後、以下のプロパティを設定します。

    • AuthSchemeAzureAD
    • InitiateOAuth:これをGETANDREFRESH に設定します。InitiateOAuth を使用すると、OAuth 交換の繰り返しやOAuthAccessToken の手動設定を避けることができます
    • OAuthClientId:カスタムAzure AD アプリケーションの作成時に取得したクライアントID
    • OAuthClientSecret:カスタムAzure AD アプリケーションの作成時に取得したクライアントシークレット
    • CallbackURL:カスタムAzure AD アプリケーションの登録時に指定されたリダイレクトURI。例えば、https://localhost:33333
    • AzureTenant:データにアクセスするために使用されるMicrosoft Online テナント。companyname.microsoft.com 形式の値またはテナントID のいずれかを指定してください

    テナントID は、Azure ポータルのAzure Active Directory > プロパティページに表示されているディレクトリID と同じです。

  4. 「Save & Test」をクリック
  5. HCL Domino 接続の追加ページで「Permissions」タブに移動し、ユーザーベースのアクセス許可を設定します。

Personal Access Token の作成

REST API、OData API、または Virtual SQL Server を介して Connect AI に接続する場合、Personal Access Token(PAT)を使用して Connect AI への接続を認証します。アクセスの粒度を維持するために、サービスごとに個別の PAT を作成することをお勧めします。

  1. Connect AI アプリの右上にある歯車アイコン()をクリックして設定ページを開きます。
  2. 設定ページで「Access Tokens」セクションに移動し、「 Create PAT」をクリックします。
  3. PAT に名前を付けて「Create」をクリックします。
  4. Personal Access Token は作成時にのみ表示されるため、必ずコピーして安全な場所に保存してください。

Axios 用に HCL Domino エンドポイントを設定

HCL Domino に接続したら、目的のテーブル用のワークスペースを作成します。

  1. 「Workspaces」ページに移動し、「 Add」をクリックして新しいワークスペースを作成します(または既存のワークスペースを選択)。
  2. Add」をクリックしてワークスペースに新しいアセットを追加します。
  3. HCL Domino 接続(例: Domino1)を選択して「Next」をクリックします。
  4. 操作するテーブルを選択して「Confirm」をクリックします。
  5. ワークスペースの OData サービス URL をメモしておきます(例: https://cloud.cdata.com/api/odata/{workspace_name})。

接続、PAT、ワークスペースが設定できたので、Axios からHCL Domino のデータに接続する準備が整いました。

Axios ワークフローで HCL Domino のデータに接続

OData プロトコルを使用して Axios から CData Connect AI への接続を確立するには、以下のステップに従います。

  1. Web アプリ用のプロジェクトディレクトリを作成します(例: ~/connect_cloud/
  2. ターミナルを開き、プロジェクトディレクトリに移動して以下のコマンドで node プロジェクトを初期化します:
    npm init -y
  3. 以下のコマンドでプロジェクトに Axios 依存関係をインストールします:
    npm install axios
  4. プロジェクトディレクトリに以下のコードを含む server.js ファイルを作成します。CData Connect AI のユーザー名(例: user@mydomain.com)と PAT(前提条件で作成した PAT)を指定します。また、SELECT * FROM Domino1.SCHEMA.ByName のようなデータクエリも指定する必要があります。

    server.js コード

          const axios = require('axios')
    
          const user = 'user@mydomain.com'
          const pat = '***********************************';
    
          //API エンドポイント
          const url = 'https://cloud.cdata.com/api/odata/{workspace_name}';
    
          //POST リクエストで送信するデータ
          const data = {
          "query":"SELECT * FROM {workspace_name}.SCHEMA.ByName"
          };
    
          axios.post(url, data, {
          auth: {
          username: user,
          password: pat
          }
          })
          .then(response => {
          const rows = response.data.results[0].rows;
          const schema = response.data.results[0].schema;
    
          //カラム名の配列を作成
          const columnNames = schema.map(col => col.columnName);
    
          //各行をループして、カラム名と値をログ出力
          rows.forEach(row => {
          const rowObject = {};
          row.forEach((value, index) => {
          const columnName = columnNames[index];
          rowObject[columnName] = value;
          });
          console.log(rowObject);
          })
          })
          .catch(error => {
          console.error('Error:', error);
          });
        
  5. ターミナルで以下のコマンドを実行してサーバーを起動します:
    node server.js
    クエリ結果が表示されます:
        { ID: 1, VALUE: -2 }
        { ID: 2, VALUE: 1 }
        { ID: 11, VALUE: null }
        { ID: 3, VALUE: 2 }
        { ID: 4, VALUE: 5 }
        ...

クラウドアプリケーションから HCL Domino のデータへの簡易アクセス

これで、Axios からライブHCL Domino のデータへの直接接続が確立されました。Axios のようなクラウドアプリケーションから 100 以上の SaaS、ビッグデータ、NoSQL ソースへの簡易アクセスについての詳細は、Connect AI ページを参照してください。

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

CData Connect AI の詳細、または無料トライアルにお申し込みください:

無料トライアル お問い合わせ