ratepay / shopware5-module
Ratepay payment methods for Shopware 5
Installs: 11
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 7
Forks: 6
Open Issues: 0
Type:shopware-plugin
Requires
- php: ^5.6 || ^7.0 || ^8.0
- ratepay/php-library: ^1.8
- shopware/shopware: ^5.5.0 || ^5.6.0 || ^5.7.0
- 7.0.x-dev
- 7.0.0
- 6.2.x-dev
- 6.1.x-dev
- 6.1.4
- 6.1.3
- 6.1.2
- 6.1.1
- 6.1.0
- 6.0.x-dev
- 6.0.5
- 6.0.4
- 6.0.3
- 6.0.2
- 6.0.1
- 6.0.0
- 6.0.0-alpha1
- 5.5.x-dev
- 5.5.1
- dev-task/RATEPLUG-234_bundle-compatibilty
- dev-task/RATEPLUG-225_redesign-calculator
- dev-task/RATEPLUG-219_respect-phone-settings
- dev-task/RATEPLUG-205_detail-page_installment-info
- dev-task/RATEPLUG-221_offline-calculator
- dev-task/RATEPLUG-215_installment-multiple-profile-ids
- dev-task/RATEPLUG-218_unique-number
- dev-task/RATEPLUG-202_installment-data
- dev-task/RATEPLUG-201_feature_skip_missing_pos
This package is auto-updated.
Last update: 2024-12-11 09:38:28 UTC
README
============================================
Installation
via packagist (recommended)
This is only possible if you use the composer setup of shopware
- execute
composer require ratepay/shopware5-module
in your project directory - Log into your Shopware-backend
- Install & configure the module
via Shopware store (or GitHub release download)
- Download the plugin from the Shopware store
- Upload it via the Plugin Manager or put it into the folder
custom/plugins/RpayRatePay
- Log into your Shopware-backend
- Install & configure the module
Changelog
please have a look into plugin.xml
Shopware CLI Commands
You can use the Shopware CLI to perform operations on Ratepay orders.
All commands have the same structure:
./bin/console ratepay:<operation> <order> [<orderDetail>] [<qty>]
example operation deliver
all elements of the order (with the id 125
) will be delivered
./bin/console ratepay:deliver 125
example operation return
2
elements with item-number SW0001
of the order (with the transaction-id 54-214XXXXXX2133
) will be returned
./bin/console ratepay:return 54-214XXXXXX2133 SW0001 2
example operation cancel
all elements with item-number SW0001
of the order (with the order-number 200012
) will be canceled
./bin/console ratepay:cancel 200012 SW0001
Request services
There are a three request services registered in the container:
-
\RpayRatePay\Services\Request\PaymentDeliveryService
Use this service to do deliveries for order.
-
RpayRatePay\Services\Request\PaymentReturnService
Use this service to do returns for order.
-
RpayRatePay\Services\Request\PaymentCancelService
Use this service to do cancellations for order.
Usage of the request services
Get the request service via dependency injection. The id of the service is the classname (symfony 3 style)
perform just a few products
use \RpayRatePay\DTO\BasketPosition;
$orderDetail = [ instance of \Shopware\Models\Order\Detail ]
$order = [ instance of \Shopware\Models\Order ]
$basketPosition = new BasketPosition($productNumber, $qty);
$basketPosition->setOrderDetail($orderDetail);
$basketPositions[] = $basketPosition;
$basketPosition = new BasketPosition($productNumber, $qty);
$basketPosition->setOrderDetail($orderDetail);
$basketPositions[] = $basketPosition;
[...]
$basketPositions[] = new BasketPosition(BasketPosition::SHIPPING_NUMBER, 1);
$requestService->setItems($basketPositions);
$requestService->setOrder($order);
$response = $requestService->doRequest();
If you want to deliver/cancel/return the shipping costs of an order, you need to provide shipping
as a string as $productNumber
. The $qty
must be 1
.
You must not call setOrderDetail()
on the $basketPosition
.
Please note that you always have to call setOrderDetail()
if you want to deliver/cancel/return a product or voucher, except the shipping costs.
perform full action
If you want to do a full deliver/cancel/return, just call the following:
$order = [ instance of \Shopware\Models\Order ]
$response = $requestService->doFullAction($order);
(already delivered/returned/canceled items will be ignored.)
Response
you will get an \RatePAY\Model\Response\AbstractResponse
or a boolean as response.
If you get an AbstractResponse
, just call isSuccessful()
to verify if the request was successful.
If you get a boolean with the value true
the operation has been registered to in the database, but has not been sent to the gateway.
This will happen, if the order is an installment and there an open (not delivered/canceled) items in the order.
Feature flags
You can enable specific features by setting the flags in the plugin configuration.
*Please note: *You should test each feature very carefully, because they may break your processes in some cases.
Please contact your contact person to make sure that this feature will work in your installation.
Separate the features with a comma and no spaces.