外部システムに存在するデータにOData 4.0 APIを介してアクセスするには仮想エンティティを利用すれば良いのですが。。。
データベース用に独自の OData API を構築し、Dynamics 365にプラグインすればデータにアクセスできますが、これには開発、保守、テストに結構労力がかかります。
面倒なので、自動でOData 4.0のエンドポイントを作成してくれ、仮想エンティティとして設定できるProgress Hybrid Data Pipelineの使い方について記述します。
インスト方法は以下をご覧ください。
#OData 4 エンドポイントの作成
1、ブラウザよりhttp://サーバIP/ でログインページが表示されます。
2、インストール時に設定した情報でログインすると、ダッシュボードが表示されます。
サイドバーの「Data Sources」タブをクリックすると、サポートされているすべてのデータストアが表示されます。
3、SQL Serverまたは自分のデータベースをクリックすると、以下のような接続設定ページが表示されるので、データベースへの接続情報を入力し、Test Connectボタンをクリックして接続を確認します。
オンプレミスのDBに接続している場合は、上記で設定したオンプレのコネクタ IDをドロップダウンで確認します。
4、ODataタブに移動し、クリックしてスキーマの構成ボタンをクリックします。
アクセスしたいテーブルを選択します。
5、Save and Close をクリックして設定を保存します。
ODataタブには、以下のようなエンドポイントURLが作られています。
SSLを有効にしていない場合は、httpにフォールバックしてください。
トラフィックをリダイレクトしているので、
https://サーバ名/api/odata4/SQLServer (SSLが有効な場合)
または
からアクセスできるはずです。
#Dynamics CRM仮想エンティティの設定
1、Dynamics CRMのSettings -> Administration より、Virtual Entity Data Sourcesをクリックします。
2、新規作成をクリックし、新しいOData4データソースを作成します。下図のようなイメージです。
認証については、Hybrid Data Pipeline Serverは基本認証を使用するので、基本認証文字列を計算してくださいね!
3、保存&閉じます。
#エンティティの作成
仮想エンティティ経由でエンティティを見てみます。
<?xml version="1.0" encoding="UTF-8"?>
<edmx:Edmx xmlns:edmx="http://docs.oasis-open.org/odata/ns/edmx" Version="4.0">
<edmx:DataServices>
<Schema xmlns="http://docs.oasis-open.org/odata/ns/edm" Namespace="SQLServer">
<EntityType Name="Customer">
<Key>
<PropertyRef Name="CustomerId"/>
</Key>
<Property Name="CustomerId" Nullable="false" Type="Edm.Guid"/>
<Property Name="FirstName" Nullable="false" Type="Edm.String" MaxLength="40"/>
<Property Name="LastName" Nullable="false" Type="Edm.String" MaxLength="20"/>
<Property Name="Company" Type="Edm.String" MaxLength="80"/>
<Property Name="Address" Type="Edm.String" MaxLength="70"/>
<Property Name="City" Type="Edm.String" MaxLength="40"/>
<Property Name="State" Type="Edm.String" MaxLength="40"/>
<Property Name="Country" Type="Edm.String" MaxLength="40"/>
<Property Name="PostalCode" Type="Edm.String" MaxLength="10"/>
<Property Name="Phone" Type="Edm.String" MaxLength="24"/>
<Property Name="Fax" Type="Edm.String" MaxLength="24"/>
<Property Name="Email" Nullable="false" Type="Edm.String" MaxLength="60"/>
</EntityType>
<EntityContainer Name="dbo">
<EntitySet Name="Customers" EntityType="SQLServer.Customer"/>
</EntityContainer>
</Schema>
</edmx:DataServices>
</edmx:Edmx>
2、Customerという名前のエンティティを持っており、データ型はEdm.Guid。主キーはCustomerIdです。エンティティのデータ型は Edm.GuidでなければDynamics CRMからデータにアクセスすることができません。
3、Entityでフィールド設定時の注意事項がいくつかあります。
・列名は大文字と小文字が区別されるため、OData 4.0のメタデータと同じように、フィールドの外部名に同じ名前を設定する必要があります。
・カラムがNullable=falseの場合、フィールド要件をBusiness Requiredに設定する必要があります。
・列に Nullable=true が設定されている場合は、フィールド要件を [option] に設定する必要があります。
・OData 4.0 メタデータで列に MaxLength プロパティがある場合は、フィールド構成で最大長を同じ値に設定します。
4、ここで、Settings -> Customizations -> Customize the Systemと進み、新規エンティティの作成を行います。以下のように設定します。
・Display Name: Customer
・Plural Name: Customers
・External Name
(OData 4.0設定のEntitySet Name="Customer "と同じである必要があります。
・External Collection Name: Customers
(OData 4.0構成のEntitySet Name="Customer "と同じでなければなりません)
Virtual Entityをチェックすると、Data Sourceという新しいフィールドが表示され、ドロップダウンに上記で設定したVirtual Entityのデータソースが表示されます。
保存します。
5、エンティティを保存したら、次はFieldsを作成します。サイドバーの「Fields」タブをクリックすると、既に2つのデフォルトカラムが見えます。
6、主キー:new_customerid をクリックすると、以下のようなフィールド構成が表示されるはずです。
外部名を設定します。CustomerId は、OData 4.0 メタデータのプライマリ・キーのカラム名と同一である必要があります。カラム名は大文字と小文字を区別するので注意です。
7、column new_nameをクリックして、以下のように設定します。
・External Name:FirstName (OData 4 メタデータと同じ)
・Field Requirement:Business Required(メタデータがNullable=falseなので)
・Maximum Length: 40
9、すべてのフィールドを保存後、すべてのカスタマイズをパブリッシュします。
10、Views, All Customers - Add Columnsよりすべての列をビューに追加、保存します。
11、Advanced Viewに移動し、customerに関するクエリを実行すると、以下のようなデータが表示されるはずです。