7
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

[MF請求API仕様確認編]他のサービスに繋げよう!Power Appsカスタム コネクタの使い方

Last updated at Posted at 2020-07-11

##皆さん!カスタム コネクタ繋げてますか!

Power Appsには沢山の標準コネクタが用意されていますが、当然まだ対応してないサービスも沢山あります。

私も、1年前からマネーフォワード請求(MF請求)へ接続して、見積もりの詳細を既存のアプリに取り込みたくて、挑戦しては挫折を繰り返していました。

しかし、今年のde:code2020を視聴して、ようやく各項目の機能とか入力内容を理解できたのと、他のサービスにつなげる際の注意点について、皆さんに共有させてもらいたいと思って、この記事を書きました。

少し長くなるので、分割して書かせてくださいね。

あ!先にお断りですが、他のサービスにPower Appsを繋げたくて、このブログに辿り着いたかも知れませんが、カスタム コネクタはプレミアムコネクタで有料となります。
詳しくは、下記のページを参照してください。
https://powerapps.microsoft.com/ja-jp/pricing/

#Part1:MF請求APIの仕様確認編
##繋げるサービスのAPI仕様を確認しよう
まずは、繋げたいサービスに、どんな機能があるのか、API仕様について確認します。

※市民開発者の方へ:APIとは、別のアプリから情報をやり取りする為の接続口を指します。接続口には、見積を検索する機能など、サービス提供してくれる会社が用意している機能が用意されていますので仕様を確認します。

■今回はMF請求のAPI仕様書を確認します。
https://invoice.moneyforward.com/api/v2/swagger_ui?_ga=2.179953634.759551439.1594435535-613194841.1594435535
ページをみていただくと、沢山の機能が用意されているのがわかります。

私は、見積もり検索して見積項目や単価、合計金額などをデータとして取り込みたいので、見積書一覧の検索を確認しました。
MF見積一覧APIスクショ.png

「見積書一覧の検索」の項目を開くと、どんな値を送ってあげる必要があるのか確認できます。
パラメーター.png
この機能では、必須かどうかは別ですが、下記データを送る必要があるとわかります。

  • q(string):検索文字列
  • range(object):詳細後程記述
  • page(integer):ページ番号
  • par_page(integer)1ページあたりの表示数
  • excise_type:消費税項目のデータ型

####ここで、大きく挫折したんですよ💦
range(object)って何

入力ボックスがあるだけで、何を送るのか例もないので全然わからない、、、
何も入力せずに送信テストすると当月分の見積もりを検索対象に応答してくる(サラッと書きますが、ここ気付くのに相当時間が掛かりました)ので、rangeは期間の範囲だと連想しましたが、どんな値を送るのかは記載されていないので、ここは諦めてMF請求のサポートに連絡して教えてもらいました。

Swaggerから見積書検索のAPIを利用する場合、お手数ではございますが、下記のようなJSONのフォーマットで入力をお願いいたします。

{
"range[key]": "created_at",
"range[from]": "2020-02-10",
"range[to]": "2020-07-30"
}

keyの部分にあたるものは、「created_at/quote_date/expired_date」のいずれかを入力していただきますようお願い申し上げます。

なお、keyがない場合には「created_at」で検索が行われ、かつ、「from」・「to」が指定されていない場合には、それぞれリクエストした月の1日と末日となる仕組みでございます。

生成されるURLにつきましては、下記の通りとなります。
/api/v2/quotes/search?range[key]=created_at&range[from]=2020-02-10&range[to]=2020-07-30”

おぉ!なるほど、こんな形で送ってあげるのね!!
めちゃめちゃ納得です:hugging:

以上で、仕様の把握が出来ました。

##MF請求の画面でテストする

ということで、MF請求APIは、この画面で動作テストができますので、試してみます。

テストをする前に、誰でも自分の見積書に繋げて内容を見られると困りますよね?💦
ですので、MF請求に繋げるには、認証(ログインみたいなもの)をしなくてはいけません。
これはサービス毎に違いまして、API Key方式やOAuth方式などがあります。
MF請求ではOAuth方式を採用していますので、事前に設定をします。

####1.MF請求へログイン
右上の歯車から「API連携β(開発者向け)」を選びます。
MF請求API画面.png

####2.接続設定
「新規作成」ボタンを押して表示された画面に
接続テスト設定.png

上記のように入力します。

  • 名前:好きなネーミングで大丈夫です
  • Redirect URI:https://invoice.moneyforward.com/api/swagger_ui/oauth2_redirect

    アクセス認可が終わった後にリダイレクトされる URI を指定しています。
    何を見てこのURIを入力しているかというと、先ほどのMF請求API仕様ページにある「OAuth認証手順」にRedirect URIについて書かれています。

    https://invoice.moneyforward.com/api/v2/swagger_ui?_ga=2.179953634.759551439.1594435535-613194841.1594435535
  • Scopes:readとwriteがありますが、今回は読み出しなのでread。

「マネーフォワード クラウド請求書API利用規約を確認した上で内容に同意する」のチェックボックスをチェックして、「作成」を押します。

リダイレクトURL.png

  • Client ID
  • Client Secret

この二つの値は、テスト動作をするページで利用しますので、どこかに控えるか、別タブとして開いておいてください。

####3.API仕様ページからテスト送信を試す。
先ほどの、MF請求API仕様ページに戻って、ページ上部にある「Authorize」ボタンを押します。
オーソライズボタン.png
https://invoice.moneyforward.com/api/v2/swagger_ui?_ga=2.179953634.759551439.1594435535-613194841.1594435535

表示画面に、先ほどメモした
クライアントキー.png

  • Client ID
  • Client Secret
    を入力。
  • Scopeはreadを選びます。

入力終わったら、「Authorize」ボタンを押すと許可完了画面が表示される筈です。
オーソライズOK.png

「Close」ボタンを押すと元のAPI一覧画面に戻りますので、以上で接続設定が完了です。

ページ下部にスクロールして、先ほどの「見積書一覧の検索」の項目を開いて、「Try it out」ボタンを押して各項目を入力します。
パラメーター.png

  • q:検索文字列。
    取引先(完全一致)、ステータス、件名etcを入れてみてください。見積番号でもOKでした。
  • range:
    {

    "range[key]": "created_at",

    "range[from]": "2020-01-01",

    "range[to]": "2020-07-30"

    }
  • page:1
  • par_page:100
  • excise_type:boolean

最後に「Execute」ボタンを押すと、成功すると、下記のように200のレスポンスコードが返ってきます。
レスポンス結果.png
Response bodyに、指定したキーワードや期間の検索結果が表示されていれば、動作確認は終了です。

Power Appsでのカスタム コネクタの設定は、次回ご説明します。
お楽しみに!

7
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?