ノーコードでクラウド上のデータとの連携を実現。
詳細はこちら →こんにちは!ドライバー周りのヘルプドキュメントを担当している古川です。
Microsoft PowerApps は、データに連携するモバイルおよびタブレット向けアプリをドラッグ&ドロップとリッチな関数で実現します。CData API ServerとADO.NET Provider for CDS (もしくは250+ の他のADO.NET Providers)を組み合わせて使い、PowerApps のリモートデータソースへの連携機能を拡張することができます。PowerApps のCommon Data Service に別途データをコピーする必要はありません。CData API サーバーは、Microsoft Dataverse データにデータベースのようなアクセスを可能にし、SaaS API やNoSQL をインメモリのSQL-92 エンジンで操作できるようにします。
CData API Server は、Swagger のメタデータ標準をサポートします。Azure App Service、Microsoft Flow、およびPowerApps でSwagger メタデータからのUI 生成やコード生成が可能です。Swagger 定義を使えば、PowerApps からMicrosoft Dataverse に連携する関数が生成できます。本記事では、それらの関数をPowerApps から使って、リモートのMicrosoft Dataverse に連携する方法を説明します。
以下のステップに従って、安全なMicrosoft Dataverse OData サービスの作成を開始します。
API Server はスタンドアロンサーバーで実行されます。Windows では、組み込みのスタンドアロンサーバーまたはIIS を使用して展開できます。Java では、Java サーブレットコンテナで、API Server WAR ファイルをドロップします。詳細については、ヘルプドキュメントを参照してください。
API Server は、Microsoft Azure、Amazon EC2、Heroku にも簡単にデプロイできます。
API Server とADO.NET Provider for CDS を展開した後、[Settings]->[Connections]をクリックし、API Server の管理コンソールで新しい接続を追加して認証値とその他の接続プロパティを指定します。 次に、[Settings]->[Resources]をクリックして、API Server へのアクセスを許可する エンティティを選択できます。
ユーザー資格情報の接続プロパティを設定せずに接続できます。接続に最小限必要な接続プロパティは、以下のとおりです。
接続すると、CData 製品はデフォルトブラウザでOAuth エンドポイントを開きます。ログインして、CData 製品にアクセス許可を与えます。CData 製品がOAuth プロセスを完了します。
作成するOData サービスを決定したら、[Settings]->[Users]をクリックしてユーザーを承認します。API Server は、認証トークンベースの認証を使用して主要な認証スキームをサポートします。SSL を使用して、接続を認証及び暗号化することができます。アクセスはIP アドレスによって制限することもできます。デフォルトでは、ローカルマシンのみに制限されています。
また、CORS を有効にしてから[Settings]->[Server]とクリックして次のセクションを定義する必要があります。[*]なしですべてのドメインを許可するオプションを選択することもできます。
最後に、URL の一部としてauthtoken を渡すことにより、ユーザーが認証できるようにAPI Server を構成する必要があります。そのために、インストールディレクションのwww/app_data フォルダに移動し、settings.cfg ファイルを変更して[Application] セクションに次の行を追加します。
AllowAuthTokenInURL = true
メタデータを使用してCustom API 接続を作成します。Swagger 定義を取得するには、ブラウザで次の要求を行い、結果のJSON ファイルを保存します。
http://MySite:MyPort/api.rsc/$oas?version=2
以下のステップで、リモートMicrosoft Dataverse を検索する簡単なアプリを作成する方法を説明します。
以下のステップに従って、PowerApp からMicrosoft Dataverse に接続します。
以下のステップに従って、Microsoft Dataverse を検索できる簡単なアプリを作成します。Power Apps の数式を使用してMicrosoft Dataverse の行をギャラリーコントロールの行にバインドします。
[View]タブで[Gallery]->[Vertical]をクリックしてギャラリーを追加します。
ギャラリーを選択し、ギャラリー設定の[Advanced]タブでギャラリーの[Items]プロパティをMicrosoft Dataverse に割り当てます。以下の式を使用すると、Accounts テーブルの例にアクセスできます。
ForAll(CDataSwaggerAPI.getAllAccounts().value, {myAccountId: AccountId, myName: Name})
要素をクリックし、[Text]プロパティ(UI 要素の[Advanced]タブ) をThisItem.myAccountId またはThisItem.myName に設定してMicrosoft Dataverse 列をUI 要素に割り当てます。
ギャラリーに表示されるレコードをフィルタリングするには、[Screen]にTextInput を追加し、TextInput の[Text]プロパティをクリアしてギャラリーの[Items]プロパティを以下のような式にます。また、必要に応じてTextInput1 をギャラリーのTextInput コントロール名に置き換えます。
If(IsBlank(TextInput1.Text),
ForAll(CDataSwaggerAPI.getAllAccounts().value, {myAccountId: AccountId, myName: Name}),
ForAll(CDataSwaggerAPI.getAllAccounts({'$filter':Concatenate("contains(AccountId,",TextInput1.Text,")")}).value, {myAccountId: AccountId, myName: Name}))
この式は、API Server がリモートMicrosoft Dataverse に対して実行するOData クエリを作成し、最初にすべてのレコードをアプリに取り込むことをせずに現在のデータに対して検索が実行されるようにします。 サポートされているOData の詳細については、API Server のヘルプドキュメントを参照してください。
以下のステップに従って、ギャラリーで選択されたMicrosoft Dataverse レコードのフィールドを表示する編集可能な画面をロードします。
Navigate( Details, None )
各カラムについて、以下のことを行う必要があります。Custom API の場合、フォーム要素はAPI サーバーに対してどのリクエストを作成する必要があるかを検出できないため、データ変更式を手動で書く必要があることに注意してください。
アプリに基本的な更新機能とナビゲーションを提供するには、[Submit]ボタンと[Back]ボタンを追加します。
CDataSwaggerAPI.updateAccounts(BrowseGallery.Selected.myId,BrowseGallery.Selected.myId,{AccountId:TextInput1.Text,Name:TextInput2.Text})
Navigate( BrowseScreen, None )
これで、モバイルアプリまたはタブレットアプリでMicrosoft Dataverse を参照、検索、更新できるようになりました。