はじめに
SAP ECC 6.0 から SAP S/4HANA に世代交代がすすんで、 SAP と外部システムとの連携に OData を用いる機会も増えてきたように感じます。特に Fiori では、UI とバックエンド間の連携で OData が利用されていることもあり、OData の役割が今まで以上に高まってきています。
本記事では、SAP S/4HANA で公開されている購買発注の OData エンドポイントを使って、UiPath からの SAP OData 呼び出し方法について説明します。
本記事に記載の内容は下記環境で動作確認しています。S/4HANA バージョン 1909 を利用している都合上、OData V2 を使っての説明となっています。V4 が利用できる場合は適時読み替えてください。
製品 | バージョン |
---|---|
SAP S/4HANA | 1909 FPS00 |
SAP GUI | 7.70 |
OData とは
OData (Open Data Protocol) は RESTFul なアーキテクチャを用いた Web API の一種です。UiPath では Orchestrator をはじめとした各製品の API で OData が採用されているため馴染みのある方もいらっしゃるかもしれません。
OData の詳細を知りたい方は下記リンクよりご確認いただければと思います。
UiPath と SAP は親和性が高い
UiPath リリース初期から SAP GUI/WebGUI などの GUI ベース自動化に対応しており、UIAutomation バージョン 2020.4 からは SAP GUI 専用のアクティビティも提供されるようになったりと継続的に改良が加えられており、リリースを重ねるごとに安定性が増しています。
また、BAPI の呼び出しを実現する UiPath.SAP.BAPI.Activities が公式アクティビティパックとして提供されており、API 経由での SAP 自動化も比較的容易に実装することが出来ます。もちろん OData による API 呼び出しも実装可能です。
詳しくは UiPath 公式ブログに記事がございますのでご確認ください。
OData API の探し方
S/4HANA に限らず SAP 製品向けに公開されている OData API は SAP Business Accelerator Hub で探すことができます。
ご利用の S/4HANA の環境に応じて下記より製品を選択していきます。オンプレの場合は SAP S/4HANA を選択します。
- SAP S/4HANA Cloud Public Edition
- SAP S/4HANA Cloud Private Edition
- SAP S/4HANA
製品を選択したら、APIs → ODATA V2 または ODATA V4 と進んでいくことで API エンドポイントの一覧を見ることが出来ます。目的のエンドポイントが V2 と V4 の両方で提供されている場合、ご利用の SAP 環境で V4 を利用できるのであれば V4 をご利用いただくと良いかと思います。
今回利用する購買発注の OData API は Purchase Order となります。クリックして詳細を開きます。
API Reference → Purchase Order と進むと、CRUD ごとのエンドポイントが用意されていることを確認することができます。今回は、POST の /A_PurchaseOrder
を利用します。
OData V4 用のエンドポイントは /PurchaseOrder となります。
POST /A_PurchaseOrder をクリックすると、リクエストパラメータやレスポンス情報を確認できます。ぱっと見た感じではトランザクションコード ME21N から入力できる項目と同じように見えますね。
ご利用の SAP 環境で目的のエンドポイントが利用できるか確認する
ドキュメントで確認する方法と、ご利用の SAP 環境で確認する方法をご紹介します。
ドキュメントで確認する
API の Overview にある Business Documentation をクリックすると SAP Help Portal にある該当 OData API のページが開きます。
ご利用中の S/4HANA のバージョンに切替えることでそのバージョンで API が利用可能か確認できるかと思います。(私が利用している 1909 FPS00 は選択肢に出てきませんでした)
実環境で確認する
OData V2 の場合はトランザクションコード /n/IWBEP/REG_SERVICE
にて確認できます。
Technical Service Name を入力して Display ボタンをクリックします。API が存在する場合は、API の説明を見ることが出来ます。
/n/IWBEP/REG_SERVICE
のように先頭に /n
を付けないと画面表示できないので必ず付与ください。
Technical Service Name は SAP Help Portal の 該当 OData API ページに記載の Technical name となります。
検索結果です。私の SAP 環境で /A_PurchaseOrder
を利用することが出来そうです。
SAP GUI から OData を実行してみる
エンドポイントの利用可否を確認できたところで、次は SAP GUI から該当エンドポイントの動作確認をしてみます。トランザクションコードは /n/IWFND/GW_CLIENT
です。
/A_PurchaseOrder
の URL は Overview ページにある Configuration Details をクリックすることで確認することが出来ます。
https://{host}:{port}/sap/opu/odata/sap/API_PURCHASEORDER_PROCESS_SRV
以下の情報を入力して、実行をクリックします。
製品 | バージョン |
---|---|
HTTP メソッド | POST |
プロトコル | HTTPS |
要求 URI | /sap/opu/odata/sap/API_PURCHASEORDER_PROCESS_SRV/A_PurchaseOrder |
要求 ヘッダ |
Content-Type : application/json Accept : application/json sap-client : 接続先クライアント |
今回は以下のデモデータを使います。リクエストボディに貼り付けてください。
{
"CompanyCode": "1710",
"PurchaseOrderType": "NB",
"PurchasingGroup": "001",
"PurchasingOrganization": "1710",
"Supplier": "17300001",
"to_PurchaseOrderItem": [
{
"Material": "TG11",
"NetPriceAmount": "130.00",
"NetPriceQuantity": "1",
"OrderQuantity": "1",
"Plant": "1710",
"PurchaseOrderItemCategory": "0"
}
]
}
HTTP ステータス 201 が返ってきたので無事登録できたようです。レスポンスボディを見ると、伝票番号 4500000865 が発行されていることが分かります。
おわりに
長くなりましたので、本記事はここまでで終わりとします。
次の記事で UiPath から OData の購買要求 API /A_PurchaseOrder
を使って OData API の呼び出し方法について説明します。
UiPath から SAP S/4HANA の OData を呼び出すシリーズ