概要
同僚がPower BI Desktop・ServicesにてBoxにあるファイルへ接続するカスタムコネクタを開発しておりましたので、その設定手順を紹介します。下記のGithubのレポジトリにて、MIT Licenseで公開しております。このコネクタを利用することで、BOXにおけるフォルダ内のファイルに接続することができます。
事前準備
- Visual Studio(2015以降)のインストール
- Power Query SDKのインストール
- オンプレミスゲートウェイのセットアップ
- Power BI Desktopのインストール
- 開発者コンソールを利用できるBoxアカウント
実施手順
1.BOX開発者コンソールにてアプリの作成
1-1. Boxにログイン後、左下にある"開発者コンソール"を選択。
1-2. BOX開発者コンソールにて、"アプリの新規作成"を選択。
1-3. "カスタムアプリ"を選択。
1-4. "ユーザー認証 (OAuth 2.0)"をチェックして、アプリ名を入力したうえで、"アプリの作成"を選択。
1-5. "OAuth 2.0リダイレクトURI"に、下記の値を入力。
1-6. "CORSドメイン"に、下記の値を入力。
1-7. "アプリケーションスコープ"の"Boxに格納されているすべてのファイルとフォルダへの書き込み"をチェック。
1-8. 2の手順で利用する"クライアントID"と"クライアントシークレット"の値を控えて、"変更を保存"を選択。
2.カスタムコネクタのビルド
2-1. 下記のレポジトリを、クローン、もしくは、ダウンロード。
2-2. "PQExtensionForBox.mproj"をVisual Studioで開く。
2-3. "client_id"のファイル内に"クライアントID"を、"client_secret"のファイル内に"クライアントシークレット"を入力。
2-4. "ソリューションの構成"を"Release"に設定。
2-5. ソリューションを右クリックして、"ソリューションのビルド"を選択。
2-6. ソリューションがあるフォルダにおける"./bin/Release"に、"PQExtensionForBox.mez"というファイルの存在を確認。
3.Power BI DesktopにてBoxへ接続したレポートの作成
3-1. "PQExtensionForBox.mez"ファイルを、Power Bi Desktopのカスタムコネクターを配置するディレクトリ(通常は、ドキュメント\Power BI Desktop\Custom Connectors)にコピー。
3-2. Power BI Desktopを起動後、"ファイル"タブを選択後、"オプションと設定"->"オプション"を選択。
3-3. "データ拡張機能"にある"(非推奨)検証または警告せずに、あらゆる拡張機能の読み込みを許可する"をチェックして、"OK"を選択。Power BI desktopを再起動。
3-4. "データを取得"にて、"PQExtenstionForBox"というコネクタを選択し、"接続"を選択。
3-5. インポートするファイルがあるフォルダのURLを入力して、"OK"を選択。
3-6. "サインイン"を選択して、Boxにへの接続を許可。
3-7. "FileList"をチェックして、"データの変換"を選択。
3-8. "Table"を選択。
3-9. "Table"を選択。
3-10. "1行目をヘッダーとして使用"を選択。
3-11. "閉じて適用"を選択します。
3-11. 確認用のビジュアルを作成して、Power BI Servicesに発行。
4.Power BI Servicesにてカスタムコネクタの設定
4-1. "PQExtensionForBox.mez"ファイルを、on-premises data gatewayのカスタムコネクターを配置するディレクトリ(通常は、C:\WINDOWS\ServiceProfiles\PBIEgwService\Documents\Power BI Desktop\Custom Connectors)にコピー。
4-2. Power BI Servicesにログイン後、右上の"ゲートウェイの管理"を選択。
4-3. 接続しているオンプレミスゲートウェイを選択後、"データソースの追加"を選択。
4-4. 下記の設定を実施後、"資格情報を編集"にてBoxへの認証を実施したうえで、"追加"を選択。
項目 | 入力値 |
---|---|
データソース名 | 適切な名前 |
データソースの種類 | PQExtensionForBox |
Url | ファイルを配置しているBoxのフォルダのURL |
認証方法 | OAuth2 |
![]() |