ノーコードでクラウド上のデータとの連携を実現。
詳細はこちら →こんにちは!ドライバー周りのヘルプドキュメントを担当している古川です。
Microsoft PowerApps は、データに連携するモバイルおよびタブレット向けアプリをドラッグ&ドロップとリッチな関数で実現します。CData API ServerとADO.NET Provider for MySQL (もしくは250+ の他のADO.NET Providers)を組み合わせて使い、PowerApps のリモートデータソースへの連携機能を拡張することができます。PowerApps のCommon Data Service に別途データをコピーする必要はありません。CData API サーバーは、MySQL データにデータベースのようなアクセスを可能にし、SaaS API やNoSQL をインメモリのSQL-92 エンジンで操作できるようにします。
CData API Server は、Swagger のメタデータ標準をサポートします。Azure App Service、Microsoft Flow、およびPowerApps でSwagger メタデータからのUI 生成やコード生成が可能です。Swagger 定義を使えば、PowerApps からMySQL に連携する関数が生成できます。本記事では、それらの関数をPowerApps から使って、リモートのMySQL に連携する方法を説明します。
以下のステップに従って、安全なMySQL OData サービスの作成を開始します。
API Server はスタンドアロンサーバーで実行されます。Windows では、組み込みのスタンドアロンサーバーまたはIIS を使用して展開できます。Java では、Java サーブレットコンテナで、API Server WAR ファイルをドロップします。詳細については、ヘルプドキュメントを参照してください。
API Server は、Microsoft Azure、Amazon EC2、Heroku にも簡単にデプロイできます。
API Server とADO.NET Provider for MySQL を展開した後、[Settings]->[Connections]をクリックし、API Server の管理コンソールで新しい接続を追加して認証値とその他の接続プロパティを指定します。 次に、[Settings]->[Resources]をクリックして、API Server へのアクセスを許可する エンティティを選択できます。
Server およびPort プロパティがMySQL への接続には必須です。IntegratedSecurity をFALSE に設定した場合、User、Password も必須になります。 オプションで、Database を設定することもできます。Database は設定がない場合すべてのデータベースを使えるようになります。
パスワード方式によるSSH接続時に必要なプロパティ一覧を以下に示します。
接続文字列形式では以下のようになります。
User=admin;Password=adminpassword;Database=test;Server=mysql-server;Port=3306;UseSSH=true;SSHAuthMode=Password;SSHPort=22;SSHServer=ssh-server;SSHUser=root;SSHPassword=sshpasswd;
公開鍵認証によるSSH接続時に必要なプロパティ一覧を以下に示します。
接続文字列形式では以下のようになります。
User=admin;Password=adminpassword;Database=test;Server=mysql-server;Port=3306;UseSSH=true;SSHAuthMode=Public_Key;SSHClientCertType=PUBLIC_KEY_FILE;SSHPort=22;SSHServer=ssh-server;SSHUser=root;SSHClientCert=C:\Keys\key.pem;
作成する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
以下のステップで、リモートMySQL を検索する簡単なアプリを作成する方法を説明します。
以下のステップに従って、PowerApp からMySQL に接続します。
以下のステップに従って、MySQL を検索できる簡単なアプリを作成します。Power Apps の数式を使用してMySQL の行をギャラリーコントロールの行にバインドします。
[View]タブで[Gallery]->[Vertical]をクリックしてギャラリーを追加します。
ギャラリーを選択し、ギャラリー設定の[Advanced]タブでギャラリーの[Items]プロパティをMySQL に割り当てます。以下の式を使用すると、Orders テーブルの例にアクセスできます。
ForAll(CDataSwaggerAPI.getAllOrders().value, {myShipName: ShipName, myFreight: Freight})
要素をクリックし、[Text]プロパティ(UI 要素の[Advanced]タブ) をThisItem.myShipName またはThisItem.myFreight に設定してMySQL 列をUI 要素に割り当てます。
ギャラリーに表示されるレコードをフィルタリングするには、[Screen]にTextInput を追加し、TextInput の[Text]プロパティをクリアしてギャラリーの[Items]プロパティを以下のような式にます。また、必要に応じてTextInput1 をギャラリーのTextInput コントロール名に置き換えます。
If(IsBlank(TextInput1.Text),
ForAll(CDataSwaggerAPI.getAllOrders().value, {myShipName: ShipName, myFreight: Freight}),
ForAll(CDataSwaggerAPI.getAllOrders({'$filter':Concatenate("contains(ShipName,",TextInput1.Text,")")}).value, {myShipName: ShipName, myFreight: Freight}))
この式は、API Server がリモートMySQL に対して実行するOData クエリを作成し、最初にすべてのレコードをアプリに取り込むことをせずに現在のデータに対して検索が実行されるようにします。 サポートされているOData の詳細については、API Server のヘルプドキュメントを参照してください。
以下のステップに従って、ギャラリーで選択されたMySQL レコードのフィールドを表示する編集可能な画面をロードします。
Navigate( Details, None )
各カラムについて、以下のことを行う必要があります。Custom API の場合、フォーム要素はAPI サーバーに対してどのリクエストを作成する必要があるかを検出できないため、データ変更式を手動で書く必要があることに注意してください。
アプリに基本的な更新機能とナビゲーションを提供するには、[Submit]ボタンと[Back]ボタンを追加します。
CDataSwaggerAPI.updateOrders(BrowseGallery.Selected.myId,BrowseGallery.Selected.myId,{ShipName:TextInput1.Text,Freight:TextInput2.Text})
Navigate( BrowseScreen, None )
これで、モバイルアプリまたはタブレットアプリでMySQL を参照、検索、更新できるようになりました。