Payment module for OXID Version 4.7.x (ce, pe), 4.8.x (ce, pe), and 4.9.x (ce, pe)
- PCI DSS compatibility
- Payment means: Credit Card (Visa, Visa Electron, Mastercard, Maestro, Diners, Discover, JCB, AMEX), Direct Debit (ELV)
- Optional fast checkout configuration allowing your customers not to enter their payment detail over and over during checkout
- Improved payment form with visual feedback for your customers
- Supported Languages: German, English, Spanish, French, Italian, Portuguese
- Backend Log with custom View accessible from your shop backend
We’ve introduced a “payment form” option for easier compliance with PCI requirements. In addition to having a payment form directly integrated in your checkout page, you can use our embedded PayFrame solution to ensure that payment data never touches your website. PayFrame is enabled by default, but you can choose between both options in the plugin settings. Later this year, we’re bringing you the ability to customise the appearance and text content of the PayFrame version. To learn more about the benefits of PayFrame, please visit our FAQ.
Download the module here: https://github.com/paymill/paymill-oxid/archive/master.zip
- Merge the content of the PAYMILL-OXID-Module directory with your OXID installation.
- Clear the OXID tmp folder.
- In your administration backend activate the Paymill plugin.
- Go to the configuration section where you can insert your private and public key (which you can find in your Paymill cockpit https://app.paymill.de/).
- In the main menu goto PAYMILL > Checklist; The checklist allows you to verify that the module has been successfully configured. It also fixes missing tables, block etc.
To activate PAYMILL payment follow these steps:
- In the main menu goto Shop Settings > Payment Methods
- Choose the payment method you want to activate
- Click on Assign User Groups and assign the right user groups
- Go to tab Country, click on Assign Countries, and assign the right countries
- In the main menu goto Shop Settings > Shipping Methods
- Choose a shipping type (e.g. Standard) and go to tab Payment
- Click on Assign Payment Methods and assign the payment method
- Repeat last 2 steps for other shipping types
If you want to update from an version earlier than 2.1 (starting from 2.0.0) you have to run the update.sql first.
- Azure-template is supported by default.
- To support a custom template based on Azure, adapt the template structure within the modules/paymill/out/blocks directory to your custom theme. The files most interesting for you are 'paymill_select_payment.tpl and 'paymill_select_header.tpl'.
In case of any errors turn on the debug mode in the PAYMILL module settings. Open the javascript console in your browser and check the debug messages during the checkout process.
You can access the logging within your administration backend under PAYMILL > PAYMILL log
The payment is processed when an order is placed in the shop frontend.
Fast Checkout: Fast checkout can be enabled by selecting the option in the PAYMILL Basic Settings. If any customer completes a purchase while the option is active this customer will not be asked for data again. Instead a reference to the customer data will be saved allowing comfort during checkout.
Because the invoice pdf cannot be automatically extended without breaking custom invoices, we decided to not extend the invoice pdf. To add prenotification to the invoice manually add following snippet:
- Open "Shoproot/modules/invoicepdf/myorder.php" or for OXID 4.8 and newer "Shoproot/modules/oe/invoicepdf/myorder.php" in your preferred editor.
- Change the following lines:
Old:
protected function _setPayUntilInfo( &$iStartPos )
{
$text = $this->_oData->translate( 'ORDER_OVERVIEW_PDF_PAYUPTO' ).date( 'd.m.Y', mktime( 0, 0, 0, date ( 'm' ), date ( 'd' ) + 7, date( 'Y' ) ) );
$this->font( $this->getFont(), '', 10 );
$this->text( 15, $iStartPos + 4, $text );
$iStartPos += 4;
}
New:
protected function _setPayUntilInfo( &$iStartPos )
{
// PAYMILL Start
$oPayment = oxNew('oxpayment');
$oPayment->loadInLang($this->_oData->getSelectedLang(), $this->_oData->oxorder__oxpaymenttype->value);
if ($oPayment->oxpayments__oxid->value == "paymill_elv") {
$translatedText = $this->_oData->translate('PAYMILL_PRENOTIFICATION_TEXT');
$myConfig = oxRegistry::getConfig();
$daysUntilWithdraw = $myConfig->getConfigParam('PAYMILL_PRENOTIFICATION');
$orderDate = $this->_oData->oxorder__oxorderdate->value;
$dateTime = new DateTime($orderDate);
$dateTime->modify('+' . $daysUntilWithdraw . ' day');
$dateFormat = $this->_oData->translate('PAYMILL_DATE_FORMAT');
$date = $dateTime->format($dateFormat);
$text = $translatedText . ' ' . $date;
} else {
// PAYMILL END
$text = $this->_oData->translate( 'ORDER_OVERVIEW_PDF_PAYUPTO' ).date( 'd.m.Y', mktime( 0, 0, 0, date ( 'm' ), date ( 'd' ) + 7, date( 'Y' ) ) );
// PAYMILL START
}
// PAYMILL END
$this->font( $this->getFont(), '', 10 );
$this->text( 15, $iStartPos + 4, $text );
$iStartPos += 4;
}