各製品の資料を入手。
詳細はこちら →Jetty コネクションプールからSAP Ariba Source のデータに連携。
CData JDBC Driver は、コネクションプーリングをサポートします:本記事では、Jetty のWeb アプリからSAP Ariba Source のデータに連携する手順を説明します。
最終更新日:2023-06-18
この記事で実現できるSAP Ariba Source 連携のシナリオ
こんにちは!ウェブ担当の加藤です。マーケ関連のデータ分析や整備もやっています。
CData JDBC Driver for SAPAribaSource は、Java Web アプリケーションに簡単に統合して利用することができます。本記事では、Jetty でドライバーをコネクションプールとして設定することで、効率的にSAP Ariba Source のデータをアプリケーションで連携利用する方法を説明します。Jetty でJNDI resource for SAPAribaSource を設定します。
DBC Driver for SAPAribaSource を JNDI Data Source として設定
次の手順で、Jetty とSAP Ariba Source の接続を確立します。
Jetty ベースでJNDI モジュールを有効化します。JNDI を有効化するコマンドラインは以下の通り:
java -jar ../start.jar --add-to-startd=jndi
- JDBC Driver の.jar ファイルと.lic ファイル(インストールディレクトリのlib フォルダ下)をcontext path のlib フォルダに配置します。
-
リソースおよびスコープを宣言します。リソース宣言で必要な接続プロパティを入力します。この例では、SAP Ariba Source のデータソースをWeb アプリケーションのWEB-INF\jetty-env.xml レベルにdeclare しています。
<Configure id='saparibasourcedemo' class="org.eclipse.jetty.webapp.WebAppContext"> <New id="saparibasourcedemo" class="org.eclipse.jetty.plus.jndi.Resource"> <Arg><Ref refid="saparibasourcedemo"/></Arg> <Arg>jdbc/saparibasourcedb</Arg> <Arg> <New class="cdata.jdbc.saparibasource.SAPAribaSourceDriver"> <Set name="url">jdbc:saparibasource:</Set> <Set name="API">SupplierDataAPIWithPagination-V4</Set> <Set name="APIKey">wWVLn7WTAXrIRMAzZ6VnuEj7Ekot5jnU</Set> <Set name="Environment">SANDBOX</Set> <Set name="Realm">testRealm</Set> <Set name="AuthScheme">OAuthClient</Set> </New> </Arg> </New> </Configure>
SAP Ariba Source に接続するには、以下を設定します。
- API:本製品にSAP Ariba データを取得させたいAPI を指定。ビジネスロールに基づき、Supplier、Sourcing Project Management、またはContract API を選択します(可能な値は、SupplierDataAPIWithPaginationV4、SourcingProjectManagementAPIV2、または ContractAPIV1 です)。
- DataCenter:アカウントのデータがホストされているデータセンター。
- Realm:アクセスしたいサイト名。
- Environment:テスト環境、または本番環境のいずれかに指定。(可能な値は、TEST またはPRODUCTION)。
Supplier Data API またはContract API に接続する場合は、さらに以下を設定します。
- User:API 呼び出しを行うユーザーのId。
- PasswordAdapter:認証するUser に関連付けられたパスワード。
Supplier API に接続している場合は、ProjectId をデータを取得したいソーシングプロジェクトのId に設定します。
OAuth 認証
接続プロパティを設定した後、認証のためにOAuth 接続を設定する必要があります。
- AuthScheme をOAuthClient に設定します。
- サービスにアプリケーションを登録し、APIKey、OAuthClientId、およびOAuthClientSecret を取得する必要があります。
OAuth アプリケーションの作成について、詳しくはヘルプドキュメントを参照してください。
OAuth の自動リフレッシュ
以下を設定して、接続してください。
- APIKey:アプリケーション設定のApplication key。
- OAuthClientId:アプリケーション設定のOAuth Client Id。
- OAuthClientSecret:アプリケーション設定のOAuth Secret。
接続すると、本製品は自動でOAuth プロセスを完了します。
- 本製品はSAP Ariba からアクセストークンを取得し、それを使ってデータをリクエストします。
- 本製品はアクセストークンの期限が切れると自動的にリフレッシュします。
- OAuth 値はOAuthSettingsLocation で指定された場所に基づいてメモリに保存されます。
-
Web xml でリソースを設定します:
jdbc/saparibasourcedb javax.sql.DataSource Container -
これで、java:comp/env/jdbc/saparibasourcedb へのルックアップでSAP Ariba Source のデータにアクセスできます:
InitialContext ctx = new InitialContext(); DataSource mysaparibasource = (DataSource)ctx.lookup("java:comp/env/jdbc/saparibasourcedb");
Jetty にさらに統合
ここでは、シンプルなコネクションプーリングシナリオでのドライバーの接続について説明しました。追加での連携ケースについては、Jetty ドキュメントのWorking with Jetty JNDI 参照してください。