Skip to content

Latest commit

 

History

History
169 lines (142 loc) · 5.55 KB

README.md

File metadata and controls

169 lines (142 loc) · 5.55 KB

magento-2-simple-protect

template for using the magento 2 - simple protect framework

Notes / Warnings

this implementation is currently in beta stage.Use at own risk! To use this implementation you have to get the magento-2-simple-protect framework.

Links

Documentation

Find the detailed documentation at: https://docs.payone.com/magento-2

Examples

Find more examples at: https://docs.payone.com/examples/magento-2/simple-protect

current module branch

github://PAYONE-GmbH/magento-2/simple-protect

Installation

manuell

  1. create directory:

'app/code/Payone/SimpleProtect' or 'vendor/payone-gmbh/magento-2-simpleProtect'

  1. copy the source, that you have a structure like this:
app/
└── code
    └── Payone
        └── SimpleProtect
            ├── composer.json
            ├── etc
            │   ├── di.xml
            │   ├── events.xml
            │   └── module.xml
            ├── Model
            │   └── SimpleProtect
            │       └── SimpleProtect.php
            ├── Observer
            │   └── OrderPaymentPlaceEnd.php
            └── registration.php
  1. install and activate the plugin
php bin/magento module:enable Payone_SimpleProtect
php bin/magento setup:upgrade
php bin/magento cache:clean
  1. update / change the code for your needs

entry points

pre payment-selection

method handlePrePaymentSelection

Implementing this method gives the following possibilities:

  1. Filtering out payment methods based on your own rule set
  2. Throwing a LocalizedException to send the user back to shipping method selection
@param  Quote $oQuote
@param  MethodInterface[] $aPaymentMethods
@return MethodInterface[]

Example

public function handlePrePaymentSelection(Quote $oQuote, $aPaymentMethods)
{
    if ($this->isOnlySafePaymentApplicable($oQuote, true) === true) {
        return $this->getSafePaymentMethods($aPaymentMethods);
    }
    return $aPaymentMethods;
}

post payment-selection

method handlePostPaymentSelection

Implementing this method gives the following possibilities:

  1. Throwing a LocalizedException will stop the order creation and throw the user back to payment selection with the given thrown message
  2. Throwing a FilterMethodListException with an array of safe payment methods will stop the order creation and throw the user back to payment selection with the given thrown message and remove all other payment methods except for the given ones
  3. Finishing the method - so throwing no Exception will finish the order creation
@param  Quote $oQuote
@return void
@throws LocalizedException
@throws FilterMethodListException

Example

public function handlePostPaymentSelection(Quote $oQuote)
{
    if ($this->isOnlySafePaymentApplicable($oQuote, false) === true) {
        $sMethodCode = $oQuote->getPayment()->getMethodInstance()->getCode();
        if (!in_array($sMethodCode, $this->safePaymentMethods)) {
            $this->checkoutSession->setPayoneSimpleProtectOnlySafePaymentsAllowed(true);
            throw new FilterMethodListException(__('Please select another payment method.'), $this->safePaymentMethods);
        }
    }
}

change / enter billing address

method handleEnterOrChangeBillingAddress

Implementing this method gives the following possibilities:

  1. Returning true will just continue the process without changing anything
  2. Returning a (changed) address object instance of AddressInterface will show an address correction prompt to the customer
  3. Throwing a LocalizedException will show the given exception message to the customer
@param AddressInterface $oAddressData
@param bool $blIsVirtual
@param double $dTotal
@return AddressInterface|bool
@throws LocalizedException

Example

public function handleEnterOrChangeBillingAddress(AddressInterface $oAddressData, $blIsVirtual, $dTotal)
    {
        $response = $this->protectFunnel->executeAddresscheck($oAddressData, $this->getOperationMode(), AddressCheckType::BASIC);
        if ($oAddressData->getCity() == "FalscheStadt") {
            $oAddressData->setCity($response->getCity());
            return $oAddressData;
        }
        return true;
    }

change / enter shipping address

method handleEnterOrChangeShippingAddress

Implementing this method gives the following possibilities:

  1. Returning true will just continue the process without changing anything
  2. Returning a (changed) address object instance of AddressInterface will show an address correction prompt to the customer
  3. Throwing a LocalizedException will show the given exception message to the customer
@param AddressInterface $oAddressData
@param bool $blIsVirtual
@param double $dTotal
@return AddressInterface|bool
@throws LocalizedException

Example

public function handleEnterOrChangeShippingAddress(AddressInterface $oAddressData, $blIsVirtual, $dTotal)
    {
        $response = $this->protectFunnel->executeAddresscheck($oAddressData, $this->getOperationMode(), AddressCheckType::BASIC);
        if ($oAddressData->getCity() == "FalscheStadt") {
            $oAddressData->setCity($response->getCity());
            return $oAddressData;
        }
        return true;
    }