oo

新しい支払い方法の実装

このチュートリアルでは、 CommercePaymentMethod インターフェイスを実装して、新しい支払い方法を追加する方法を示します。

支払方法とは、顧客が注文に対して支払う様々な方法を表します。 Liferay Commerceは、 Authorize.NetMercanetMoney OrderPayPal などのいくつかのすぐに使える支払い手段を提供します。

すぐに使える支払方法

概要

  1. サンプルをデプロイする
  2. サンプルの説明
  3. 追加情報

サンプルをデプロイする

このセクションでは、支払方法をLiferay Commerceのインスタンスで実行する例を示します。 新しいLiferay インスタンスを起動し、以下を実行します。

docker run -it -m 8g -p 8080:8080 liferay/portal:7.4.3.112-ga112。

http://localhost:8080でLiferayへのサインインします。 メールアドレス test@liferay.com とパスワード test を使用してください。 プロンプトが表示されたら、パスワードを learn に変更します。

次に、以下の手順に従います。

  1. Acme Commerce Payment Method をダウンロードし、解凍してください。

    curl https://resources.learn.liferay.com/commerce/latest/ja/developer-guide/sales/liferay-b1c3.zip -O
    
    liferay-b1c3.zipを解凍してください。
    
  2. サンプルをビルドしてデプロイします。

    ./gradlew deploy -Ddeploy.docker.container.id=$(docker ps -lq)
    
    note

    このコマンドは、デプロイされたjarをDockerコンテナの/opt/liferay/osgi/modulesにコピーするのと同じです。

  3. Dockerコンテナコンソールでデプロイを確認します。

    STARTED com.acme.b1c3.impl_1.0.0
    
  4. サンプルの支払方法が追加されたことを確認します。 ブラウザでhttps://localhost:8080を開きます。 次にアプリケーションメニュー (Applications Menu)をクリックし、 [commerce] → [Channels] に移動します。その後、 [Payment Methods] セクションまでスクロールします。

note

Liferay Commerce 2.1以前のバージョンでは、[サイト管理] → [commerce] → [設定] → [支払方法]に移動します。

新しい支払方法

これで、CommercePaymentMethodを実装する新しい支払方法を正常に構築およびデプロイできました。

さらに詳しく見ていきましょう。

サンプルの説明

このセクションでは、デプロイしたサンプルについて確認します。 最初に、OSGi登録用のクラスに注釈を付けます。 次に、 CommercePaymentMethodインターフェイスを確認します。 最後に、CommercePaymentMethodの実装を完了します。

OSGi登録用のクラスに注釈を付ける

@Component(
    property = "commerce.payment.engine.method.key=b1c3",
    service = CommercePaymentMethod.class
)
public class B1C3CommercePaymentMethod implements CommercePaymentMethod {

Liferay Commerceが [支払方法レジストリ](https://github.com/liferay/liferay-portal/blob/[$LIFERAY LEARN PORTAL GIT TAG$]/modules/apps/commerce/commerce-payment-service/src/main/java/com/liferay/commerce/payment/internal/method/CommercePaymentMethodRegistryImpl.java) で新しい支払方法を他の支払方法と区別できるように、支払方法に個別のキーを提供することが重要です。 すでに使用されているキーを再利用すると、既存の関連付けられている支払方法が上書きされます。

CommercePaymentMethodインターフェイスを確認する

次のメソッドを実装します。

    public String getDescription(Locale locale);

これにより、 [支払い方法] 管理ページの「説明」列にデータが入力されます。 言語キーで説明を取得する際のリファレンスについては、 B1C3CommercePaymentMethod.java の実装を参照してください。

    public String getKey();

これにより、支払方法レジストリ内の支払方法に一意の識別情報が提供されます。 このキーを使用して、レジストリから支払方法を取得できます。 すでに使用されているキーを再利用すると、既存の関連付けられている支払方法が上書きされます。

    public String getName(Locale locale);

これにより、 [支払い方法] 管理ページの「Name」列にデータが入力されます。 このメソッドは、getDescriptionメソッドと同様に動作します。

    public int getPaymentType();

これにより、支払いエンジンが特定の支払方法をどのように使用するかが識別されます。

COMMERCE_PAYMENT_METHOD_TYPE_OFFLINEを使用して、この支払方法にオンライン処理要件がないことを支払エンジンに通知します。 すぐに使用できる支払いタイプ定数は他に2つあります:COMMERCE_PAYMENT_METHOD_TYPE_ONLINE_STANDARDCOMMERCE_PAYMENT_METHOD_TYPE_ONLINE_REDIRECTです。

    public String getServletPath();

オンラインの支払方法では、外部の支払いプロバイダーとの適切なインターフェイスを有効にするために、サーブレットが必要になる場合があります。 オフラインの支払方法にはサーブレットパスは必要ないため、getServletPathnullを返します。

支払方法を完了する

支払方法は、支払を処理および完了するためのバックエンドロジックと、さらに多くのオプションのカスタム動作で構成されています。 以下を行います。

支払処理ロジックを実装する

@Override
public boolean isProcessPayment有効() {
    return true;
}

このメソッドは、支払を処理する支払方法に対してtrueを返す必要があります。 これにより、支払方法でサポートされる機能が支払エンジンに通知されます。

@Override
public CommercePaymentResult processPayment(
        CommercePaymentRequest commercePaymentRequest)
    throws Exception {

    return new CommercePaymentResult(
        null, commercePaymentRequest.getCommerceOrderId(),
        CommerceOrderConstants.PAYMENT_STATUS_AUTHORIZED, false, null, null,
        Collections.emptyList(), true);
}

このメソッドにカスタム支払ロジックを実装します。 CommercePaymentResultには、支払の処理に関連する情報を格納する必要があります。 詳細は、 [CommercePaymentResult.java](https://github.com/liferay/liferay-portal/blob/[$LIFERAY LEARN PORTAL GIT TAG$]/modules/apps/commerce/commerce-api/src/main/java/com/liferay/commerce/payment/result/CommercePaymentResult.java) を参照してください。

支払完了ロジックを実装する

@Override
public boolean isComplete有効() {
    return true;
}

これは、支払を完了する支払方法に対してtrueを返す必要があります。 これにより、支払方法でサポートされる機能が支払エンジンに通知されます。

@Override
public CommercePaymentResult completePayment(
        CommercePaymentRequest commercePaymentRequest)
    throws Exception {

    return new CommercePaymentResult(
        null, commercePaymentRequest.getCommerceOrderId(),
        CommerceOrderConstants.PAYMENT_STATUS_PAID, false, null, null,
        Collections.emptyList(), true);
}

このメソッドにカスタム支払完了ロジックを実装します。 CommercePaymentResultは、支払いプロセスの完了に関連する情報を格納するコンテナです。 詳細は、 [CommercePaymentResult.java](https://github.com/liferay/liferay-portal/blob/[$LIFERAY LEARN PORTAL GIT TAG$]/modules/apps/commerce/commerce-api/src/main/java/com/liferay/commerce/payment/result/CommercePaymentResult.java) を参照してください。

オプションのメソッドを実装する

購読、定期的な支払、払い戻しなど、追加の機能を提供するために実装できる追加のメソッドがあります。 これらは、 CommercePaymentMethod.java で確認することができます。 これらのメソッドはペアで提供されます。1つは有効にするメソッドで、もう1つは特定の機能を実装するメソッドです。

これらのメソッドの多くは、オンラインAPIを使用した支払方法にとって重要です。 オンライン決済方法の例として、 PayPalCommercePaymentMethod を参照してください。

この例では、これらのオプションのメソッドをオーバーライドしていません。

言語キーをLanguage.propertiesに追加する

モジュール内の Language.properties ファイルに言語キーとその値を追加します。

b1c3-commerce-payment-method=B1C3 Commerce Payment Method
pay-via-b1c3-commerce-payment-method=Pay via B1C3 commerce payment method.

詳細は、 アプリケーションのローカライズ を参照してください。

まとめ

  CommercePaymentMethodインターフェイスを実装するための基本を理解し、Liferay Commerceに新しい支払方法を追加しました。

関連トピック

Capability: