新しい税エンジンの実装
このチュートリアルでは、 CommerceTaxEngine インターフェイスを実装して、新しい税エンジンを追加する方法を示します。
税エンジンは、取引が行われるときに税金の計算を実行します。 Liferay Commerceは、固定税率用の FixedCommerceTaxEngine 、および住所による税金計算用の ByAddressCommerceTaxEngine という2つのデフォルト税エンジンを提供します。
概要
サンプルをデプロイする
このセクションでは、税エンジンをLiferay Commerceのインスタンスで実行する例を示します。
新しいLiferay インスタンスを起動し、以下を実行します。
docker run -it -m 8g -p 8080:8080 liferay/portal:7.4.3.120-ga120。
http://localhost:8080でLiferayへのサインインします。 メールアドレス test@liferay.com とパスワード test を使用してください。 プロンプトが表示されたら、パスワードを learn に変更します。
次に、以下の手順に従います:
-
Acme Commerce Tax Engine をダウンロードし、解凍する。
curl https://resources.learn.liferay.com/commerce/latest/en/developer-guide/sales/liferay-q4b9.zip -O
unzip liferay-q4b9.zip
-
サンプルをビルドしてデプロイします。
./gradlew deploy -Ddeploy.docker.container.id=$(docker ps -lq)
noteこのコマンドは、デプロイされたjarをDockerコンテナの
/opt/liferay/osgi/modules
にコピーするのと同じです。 -
Dockerコンテナコンソールでデプロイを確認します。
STARTED com.acme.q4b9.impl_1.0.0
-
サンプルの税エンジンが追加されたことを確認します。 ブラウザで
https://localhost:8080
を開きます。 次に、アプリケーションメニュー()をクリックし、 [コマース] → [Channels] に移動します。 新しいチャネルを編集します。 新しい税エンジン([Q4B9 Commerce Tax Engine])がリストに表示されます。
Commerce 2.1以前のバージョンでは、 [サイト管理] → [コマース] → [設定] → [税金] → [税の計算]に移動して、税エンジンを確認します。
これで、CommerceTaxEngine
を実装する新しい税エンジンを正常にビルトおよびデプロイできました。
次に、詳細をさらに詳しく見ていきましょう。
サンプルの説明
このセクションでは、デプロイしたサンプルについて確認します。 最初に、OSGi登録用のクラスに注釈を付けます。 次に、CommerceTaxEngine
インターフェイスを確認します。 最後に、CommerceTaxEngine
の実装を完了します。
OSGi登録用のクラスに注釈を付ける
@Component(
property = "commerce.tax.engine.key=q4b9", service = CommerceTaxEngine.class
)
Liferay Commerceが 税エンジンレジストリ 。で新しいエンジンを他のエンジンと区別できるように、税エンジンに個別のキーを提供することが重要です。 すでに使用されているキーを再利用すると、既存の関連付けられている税エンジンが上書きされます。
CommerceTaxEngine
インターフェイスを確認する
次のメソッドを実装します。
public CommerceTaxValue getCommerceTaxValue(
CommerceTaxCalculateRequest commerceTaxCalculateRequest)
throws CommerceTaxEngineException;
このメソッドでは、税エンジンのビジネスロジックが実装されます。 詳細は CommerceTaxValue を参照してください。
public String getDescription(Locale locale);
これは、税エンジンの簡単な説明を返します。 言語キーで説明を取得する際のリファレンスについては、 Q4B9CommerceTaxEngine.java の実装を参照してください。
public String getName(Locale locale);
これは、税エンジンの名前を返します。 このメソッドは、
getDescription
メソッドと同様に動作します。
税エンジンを完成させる
税エンジンは、税の計算を実行するロジックで構成されています。 以下を行います。
ビジネスロジックをgetCommerceTaxValue
に追加する
@Override
public CommerceTaxValue getCommerceTaxValue(
CommerceTaxCalculateRequest commerceTaxCalculateRequest)
throws CommerceTaxEngineException {
BigDecimal flatTaxValue = _ONE_POINT_FIVE_ZERO;
if (commerceTaxCalculateRequest.isPercentage()) {
flatTaxValue = _ONE_POINT_FIVE_ZERO.divide(new BigDecimal(100.0));
flatTaxValue = flatTaxValue.multiply(
commerceTaxCalculateRequest.getPrice());
}
return new CommerceTaxValue(
"q4b9", "q4b9-commerce-tax-engine", flatTaxValue);
}
private static final BigDecimal _ONE_POINT_FIVE_ZERO = new BigDecimal(
"1.50");
CommerceTaxCalculateRequest
パラメータには、計算に必要な情報が含まれています。 この例では、CommerceTaxCalculateRequest
からの価格と、レートをパーセンテージとして適用するかどうかを示す値を使用します。CommerceTaxCalculateRequest
で使用できる他のメソッドを見つけるには、 CommerceTaxCalculateRequest.java を参照してください。
言語キーをLanguage.properties
に追加する
モジュール内の Language.properties ファイルに言語キーとその値を追加します。
q4b9-commerce-tax-engine=Q4B9 Commerce Tax Engine
this-tax-engine-serves-a-fixed-x-percent-flat-tax-rate=This tax engine serves a fixed {0} percent flat tax rate.
詳しくは、 MVCポートレットでのローカライズされたメッセージの使用 をご覧ください。
まとめ
CommerceTaxEngine
インターフェイスを実装するための基本を理解し、Liferay Commerceに新しい税エンジンを追加しました。