はじめに
こんにちは。すぎもんです
今回は、2023年10月に施工が控えている「インボイス制度」(=適格請求書発行方式)に関連するAPIを触ってみました。制度の詳細内容は省略しますが、部分的にざっくりいうと、適格請求書発行事業者として登録し、適格請求書を発行して、しっかり電子データとして保存しておきましょう、そのために必要な仕組み(システムなど)は用意しておきましょう。といった制度です。今回はその中の「適格請求書発行事業者としての登録情報」に関連するAPIです。
適格請求書発行事業者公表サイトとは
いわゆる、インボイス制度(=適格請求書発行方式)に関連したシステムです。消費税法の規定に基づき、適格請求書発行事業者情報(氏名や登録番号など)を公表していて、それらの情報がインターネット検索できるように国税庁が用意したサイトになります。
提供しているWeb-API機能では、利用者のシステムからインターネットを経由して、簡単なリクエスト(REST方式)を送信することで、指定した番号や期間の情報が取得できます。取引先から受け取った請求書等に記載された登録番号が有効かの確認に利用します。
(ご参考)国税庁適格請求書発行事業者公表サイト
今回やること
今回はDataSpiderを使って、適格請求書発行事業者公表サイトから、「登録番号」と「日付」を指定して情報を取得 してみます。
事前準備(Web-APIの準備)
DataSpiderとつなぐための事前準備として、適格請求書発行事業者公表システムのWeb-APIを準備します。
国税庁では、利用者が構築するシステムのインタフェース検証テストのため、
検証環境を提供しています。今回はその環境を利用します。
サイトTopページにある「ダウンロードWeb-API」⇒「適格請求書発行事業者公表システムWeb-API機能」を押下します。
画面遷移後、下方に画面スクロールして、
「Web-APIの検証」⇒「Web-API検証環境の提供について」を押下します。
このページで国税庁が提供する検証環境の概要や利用方法について確認できます。
適格請求書発行事業者公表システムWeb-API検証環境を利用するために、国税庁から発行されるアプリケーションIDが必要です。
アプリケーションIDは、DataSpiderの設定の時に必要なのでメモしましょう。
ページ内に添付された設定方法などの記載がある下記の資料を参照の上、
検証内容に該当する情報を確認します。
今回の検証での確認対象は、
「登録番号」と「日付」を指定して情報を取得する機能 です。
「登録番号と日付を指定して情報を取得する機能」について、リクエストフォーマット(仕様)は、下記の通りです。
条件は下表の項目について、各項目ID に対応する項目値を「項目ID=項目値」という形式でセットし、各条件を「&」でつなぐことで設定できます。
以上の確認内容を踏まえて、DataSpiderの設定をしていきましょう。
DataSpiderの設定(スクリプト変数の作成)
始めに、任意の名前でプロジェクトを作成して、
スクリプトを作成します。
デザイナ画面の表示は下記になります。
また、スクリプト内の処理で使うための「スクリプト変数」を作成しましょう。
スクリプト変数は、下記の通り、設定します。
変数名① : アプリケーションID
変数型 : 文字列型
初期値 : XXXXXXXXXXX
(※国税庁から通知されたアプリケーションID)
同様の手順で、下記の通り、2つのスクリプト変数を作成します。
・変数名② : 登録番号
・変数型 : 文字列型
・初期値 : T000000000XXXX
(XXXXは適切な数値を設定してください)
・変数名③ : 判定基準日
・変数型 : 文字列型
・初期値 : 2023-12-01
以上、3つのスクリプト作成が完了しました。
DataSpiderの設定(GET実行処理の設定)
次に、DataSpiderのデザイナ画面右側にある「ツールパレット」から、[ネットワーク] - [REST] - [GET実行]のアイコンを、デザイナ中央にドラッグ&ドロップして、設定画面を開きます。
「GET実行処理」の名前は、国税庁Web-API(valid)
とします。
「接続先」の設定をします。接続先のプルダウンリストから【追加】を選択します。
この設定では REST での接続先の URLを設定します。
下記のように設定して、完了を選択しましょう。
「接続テスト」を押下し、入力したURLがDataSpiderと通信できる状況か確認します。
・名前 : 国税庁 Web-API
・URL : https://kensyo.invoice-kohyo.nta.go.jp/1/
次に、「パス」は、「valid
」と設定し、「クエリパラメータ」を、下記の通り設定します。
・名前① : id
値① : ${アプリケーションID}
・名前② : number
値② : ${登録番号}
・名前③ : day
値③ : ${判定基準日}
・名前④ : type
値④ : 11
※「クエリパラメータ」は下記の表を参照して設定します。
”パス”は、「接続先」設定で指定した【URL】の後ろに付加され、
最終的な endpoint となります。
また、DataSpiderの変数は、${スクリプト変数名}と記載します。
以上で、「必須設定」タブの入力は完了です。
次に、「レスポンス設定」タブの設定です。
ここでは、リクエストに対するレスポンスをどのように扱うかを設定します。
ファイルパスは、任意のパスを指定してください。
・データ出力先 : ファイル
・ファイルパス : /data/インボイス/test_response.xml
以上で、DataSpiderでの設定は完了です。
DataSpider設定(スクリプトの完成)
最後に、デザイナ上のStart/Endアイコンと、GET実行アイコンをドラッグ&ドロップでつなげます。「Start」アイコンを「国税庁 Web-API(valid)」につなげ、「国税庁 Web-API(valid)」アイコンを End アイコンにつなげます。
スクリプトの完成です。
スクリプトの実行
デバック実行して、実行結果を確認してみましょう。
正常終了を確認したら、DataSpider エクスプローラで、スクリプト実行前後での実ファイルを確認します。
【スクリプト実行前】
DataSpiderのエクスプローラの「/data/インボイス」フォルダには何もありません。
【スクリプト実行後】
DataSpiderのエクスプローラの「/data/インボイス」フォルダに指定ファイル「test_response.xml
」が作成されています。
デバック実行が正常に終了すると、指定した/data/インボイス フォルダ
内に、
test_response.xml
が作成されていることが確認できました。
指定した「登録番号」の公開情報がファイル内にあるか確認します。
下記の通り、実ファイル内に登録番号と登録関連情報が記されており、成功です!
最後に
今回は、「DataSpiderで適格請求書発行事業者公表システムのWeb-API 使ってみた」でした。いかがでしょうか?別記事にもあるGET実行ではありますが、「クエリパラメータ」を複数指定して情報を取得する方法をご確認いただけたかと思います。
また、冒頭お伝えした通り、適格請求書発行事業者公表サイトは、「取引先から受け取った請求書等に記載された登録番号の有効性を確認する」ことが主目的です。今回の記事で使ったAPIを利用し、請求書情報含む取引先の情報を入力データとして、DataSpiderで登録番号の有効性を判断し、無効な取引先一覧をファイル化する…など、まだまだ色々とできそうですね。
是非、本記事を参考にDataSpiderを触ってみてください。
このブログでは、今後も様々な記事を投稿していきたいと思います。
ここまで読んでいただいた皆さん、ありがとうございました。それでは、また!