目次
- はじめに
- 概要
- 完成イメージ
- 実装前
- 実装方法
- 実装後
- まとめ
はじめに
今回は、Foundry(旧Fabric)のPreProcessor,PostProcessorの機能や
実装方法について紹介していきます。
※今回は、VoltMX Foundryを用いて説明を行います。
Quantumと基本的には同じですが、メソッド名が一部異なる点がありますので、
Quantumご利用の方は、メソッド名など読み替えながら進めてください。
概要
PreProcessorは、外部データソースにデータを渡す前に呼び出される機能です。
例えば、リクエスト値が空の場合にエラーメッセージを表示する等で使用することができます。
PostProcessorは、外部データからデータが受信された後、
そのデータがフロントアプリに返される前に呼び出される機能です。
例えば、アプリにデータを返す前に一部のデータ形式を変更したり、データを追加する際に使用することができます。
完成イメージ
では早速実装を行っていきましょう!
今回は例として、リクエストの値が空の場合に、
「○○を入力してください」とエラーを表示するような処理を加えてみたいと思います。
既にIntegration Serviceで外部APIを使用して、
天気情報を取得するgetWeatherというAPIを作成しておきましたので、
こちらを使って説明を行います。
リクエスト値であるcityName
を入力すると、
その都市の天気情報が取得できるという内容になっています。
実装前
現状はPreProcessorに何も設定を行っていないため、
リクエスト値を空にすると、このような結果となります。
このままだと、APIの呼び出しに失敗した、ということ以外何もわからないため、
何が原因のエラーなのかわかるように実装してみましょう!
実装方法
メニューを開く
まずは、Integration Serviceの「Advanced」のメニューを開きましょう。
すると、PreProcessor,PostProcessorを設定できる画面が開きます。
使用できる言語
ここでは、JavaまたはJavascript、Rules(※)の形式で記述することができます。
※補足
Rulesは、Fabric V8 SP4から追加されたオプションで、
より人間の言語に近づけたMVELという言語を採用しているため、
以下のように感覚的にわかりやすいコードで記述することができます。
name: "Convert account code to type in post-processor"
description: " Rule to convert account type to code and add details in result"
condition: "AccountType == 1"
actions:
- "results.addParam(\"AccountType\", \"Loan Account\")"
- "results.addParam(\"Message\", \"This is a Loan Account\")"
今回は、詳しく説明しませんが、
もっと詳しく知りたい方は公式ドキュメントを参考にしてみてくださいね👀
https://docs.kony.com/konylibrary/konyfabric/V9M2/kony_fabric_user_guide/Content/Rules.htm
コーディング
今回は、Javascriptを使用して記載します。
Javascriptのラジオボタンをクリックすると、
入力欄が表示されますので以下のように入力しました。
function processInput() {
//リクエスト値を取得する
var cityName = request.getParameter('cityName');
if (!cityName) {
var newOutputParam1 = new com.hcl.voltmx.middleware.dataobject.Param();
newOutputParam1.setName('errorCode');
newOutputParam1.setValue('ERR001');
result.setParam(newOutputParam1);
var newOutputParam2 = new com.hcl.voltmx.middleware.dataobject.Param();
newOutputParam2.setName('errorMessage');
newOutputParam2.setValue('都市名を入力してください。');
result.setParam(newOutputParam2);
return false;
} else {
return true;
}
}
processInput();
処理の順に説明を行っていきます。
getParameter
()内にRequest Inputで設定したパラメーターを指定することで、
その値に入力された値を取得することができるメソッドになります。
今回は、Request InputのcityNameというパラメータを取得し、
cityNameという変数に代入しています。
if文の中では、
cityNameのデータが存在しない場合、
エラーメッセージを表示し、
そうでない場合は、trueを返す処理を行っています。
new com.hcl.voltmx.middleware.dataobject.Param()
(※Quantumの場合は、new com.konylabs.middleware.dataobject.Param
)
こちらを実行する際、
setName
でキーを、setValue
でバリューを指定することで、
データ取得後の結果に新しいパラメーターを追加することができます。
今回、cityNameがない場合、
「都市名を入力してください」と表示したいので、
それぞれエラーコードとエラーメッセージを設定しています。
実装ができたので、早速実行してみましょう!
実装後
Request InputのcityNameを空にした状態で実行すると、
「都市名を入力してください」のエラーメッセージとエラーコードが表示され、
cityNameを入力した状態で実行すると、
正常に天気情報が取得できていることがわかりますね!
今回は、PreProcessorの実装方法を詳しくご説明しましたが、
PostProcessorについても同様に実装が可能です。
また、Integration Service以外にもOrchestration Serviceでも同じく設定が可能です。
使えるメソッドなどは公式ドキュメントに記載がありますので、
参考にしながら進めてみてくださいね!
・VoltMX
・Quantum
まとめ
今回は、Pre-Postprocessorの概要と使用方法について紹介しました。
フロントアプリと外部サービス間の処理の中で、
データを追加・削除したり形式を変更したりと便利な機能ですので、ぜひ使ってみてくださいね!
参考
https://docs.kony.com/konylibrary/konyfabric/kony_fabric_user_guide/Content/Rules_as_Pre_Post_Processors.htm
https://opensource.hcltechsw.com/volt-mx-docs/java_docs_apis/MiddlewareAPI/overview-summary.html
https://docs.kony.com/konylibrary/integration/MiddlewareAPI/overview-summary.html