Inital commit
This commit is contained in:
@@ -16,9 +16,9 @@ use Symfony\Component\Routing\Router;
|
||||
use Thelia\Controller\Front\BaseFrontController;
|
||||
use Thelia\Core\Event\Order\OrderEvent;
|
||||
use Thelia\Core\Event\TheliaEvents;
|
||||
use Thelia\Core\HttpKernel\Exception\RedirectException;
|
||||
use Thelia\Log\Tlog;
|
||||
use Thelia\Model\OrderQuery;
|
||||
use Thelia\Model\OrderStatus;
|
||||
use Thelia\Model\OrderStatusQuery;
|
||||
|
||||
/**
|
||||
@@ -40,7 +40,7 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
abstract protected function getModuleCode();
|
||||
|
||||
/**
|
||||
* Initialize a module-specific logger.
|
||||
* Returns the module-specific logger, initializing it if required.
|
||||
*
|
||||
* @return Tlog a Tlog instance
|
||||
*/
|
||||
@@ -49,21 +49,31 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
if ($this->log == null) {
|
||||
$this->log = Tlog::getNewInstance();
|
||||
|
||||
$logFilePath = sprintf(THELIA_ROOT."log".DS."%s.log", strtolower($this->getModuleCode()));
|
||||
$logFilePath = $this->getLogFilePath();
|
||||
|
||||
$this->log->setPrefix("#LEVEL: #DATE #HOUR: ");
|
||||
$this->log->setDestinations("\\Thelia\\Log\\Destination\\TlogDestinationFile");
|
||||
$this->log->setConfig("\\Thelia\\Log\\Destination\\TlogDestinationFile", 0, $logFilePath);
|
||||
$this->log->setLevel(Tlog::INFO);
|
||||
}
|
||||
|
||||
return $this->log;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return string The path to the module's log file.
|
||||
*/
|
||||
protected function getLogFilePath()
|
||||
{
|
||||
return sprintf(THELIA_ROOT."log".DS."%s.log", strtolower($this->getModuleCode()));
|
||||
}
|
||||
|
||||
/**
|
||||
* Process the confirmation of an order. This method should be called
|
||||
* once the module has performed the required checks to confirm a valid payment.
|
||||
*
|
||||
* @param int $order_id the order ID
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function confirmPayment($order_id)
|
||||
{
|
||||
@@ -71,10 +81,11 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
$order_id = intval($order_id);
|
||||
|
||||
if (null !== $order = $this->getOrder($order_id)) {
|
||||
|
||||
$this->getLog()->addInfo(
|
||||
$this->getTranslator()->trans("Processing confirmation of order ref. %ref, ID %id",
|
||||
array('%ref' => $order->getRef(), '%id' => $order->getId()))
|
||||
$this->getTranslator()->trans(
|
||||
"Processing confirmation of order ref. %ref, ID %id",
|
||||
array('%ref' => $order->getRef(), '%id' => $order->getId())
|
||||
)
|
||||
);
|
||||
|
||||
$event = new OrderEvent($order);
|
||||
@@ -84,13 +95,16 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
$this->dispatch(TheliaEvents::ORDER_UPDATE_STATUS, $event);
|
||||
|
||||
$this->getLog()->addInfo(
|
||||
$this->getTranslator()->trans("Order ref. %ref, ID %id has been successfully paid.",
|
||||
array('%ref' => $order->getRef(), '%id' => $order->getId()))
|
||||
$this->getTranslator()->trans(
|
||||
"Order ref. %ref, ID %id has been successfully paid.",
|
||||
array('%ref' => $order->getRef(), '%id' => $order->getId())
|
||||
)
|
||||
);
|
||||
}
|
||||
} catch (\Exception $ex) {
|
||||
$this->getLog()->addError(
|
||||
$this->getTranslator()->trans("Error occured while processing order ref. %ref, ID %id: %err",
|
||||
$this->getTranslator()->trans(
|
||||
"Error occured while processing order ref. %ref, ID %id: %err",
|
||||
array(
|
||||
'%err' => $ex->getMessage(),
|
||||
'%ref' => ! isset($order) ? "?" : $order->getRef(),
|
||||
@@ -105,6 +119,53 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
|
||||
/**
|
||||
* Process the cancelation of a payment on the payment gateway. The order will go back to the
|
||||
* Save the transaction/payment ref in the order
|
||||
*
|
||||
* @param int $orderId the order ID
|
||||
* @param int $transactionRef the transaction reference
|
||||
*
|
||||
* @throws \Exception
|
||||
*/
|
||||
public function saveTransactionRef($orderId, $transactionRef)
|
||||
{
|
||||
try {
|
||||
$orderId = intval($orderId);
|
||||
|
||||
if (null !== $order = $this->getOrder($orderId)) {
|
||||
$event = new OrderEvent($order);
|
||||
|
||||
$event->setTransactionRef($transactionRef);
|
||||
|
||||
$this->dispatch(TheliaEvents::ORDER_UPDATE_TRANSACTION_REF, $event);
|
||||
|
||||
$this->getLog()->addInfo(
|
||||
$this->getTranslator()->trans(
|
||||
"Payment transaction %transaction_ref for order ref. %ref, ID %id has been successfully saved.",
|
||||
[
|
||||
'%transaction_ref' => $transactionRef,
|
||||
'%ref' => $order->getRef(),
|
||||
'%id' => $order->getId()
|
||||
]
|
||||
)
|
||||
);
|
||||
}
|
||||
} catch (\Exception $ex) {
|
||||
$this->getLog()->addError(
|
||||
$this->getTranslator()->trans(
|
||||
"Error occurred while saving payment transaction %transaction_ref for order ID %id.",
|
||||
[
|
||||
'%transaction_ref' => $transactionRef,
|
||||
'%id' => $orderId
|
||||
]
|
||||
)
|
||||
);
|
||||
|
||||
throw $ex;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Process the cancellation of a payment on the payment gateway. The order will go back to the
|
||||
* "not paid" status.
|
||||
*
|
||||
* @param int $order_id the order ID
|
||||
@@ -115,17 +176,21 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
|
||||
if (null !== $order = $this->getOrder($order_id)) {
|
||||
$this->getLog()->addInfo(
|
||||
$this->getTranslator()->trans("Processing cancelation of payment for order ref. %ref",
|
||||
array('%ref' => $order->getRef()))
|
||||
$this->getTranslator()->trans(
|
||||
"Processing cancelation of payment for order ref. %ref",
|
||||
array('%ref' => $order->getRef())
|
||||
)
|
||||
);
|
||||
|
||||
$event = new OrderEvent($order);
|
||||
|
||||
$event->setStatus(OrderStatus::CODE_NOT_PAID);
|
||||
$event->setStatus(OrderStatusQuery::getNotPaidStatus()->getId());
|
||||
|
||||
$this->getLog()->addInfo(
|
||||
$this->getTranslator()->trans("Order ref. %ref is now unpaid.",
|
||||
array('%ref' => $order->getRef()))
|
||||
$this->getTranslator()->trans(
|
||||
"Order ref. %ref is now unpaid.",
|
||||
array('%ref' => $order->getRef())
|
||||
)
|
||||
);
|
||||
|
||||
$this->dispatch(TheliaEvents::ORDER_UPDATE_STATUS, $event);
|
||||
@@ -140,7 +205,9 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
protected function getOrder($order_id)
|
||||
{
|
||||
if (null == $order = OrderQuery::create()->findPk($order_id)) {
|
||||
$this->getLog()->addError($this->getTranslator()->trans("Unknown order ID: %id", array('%id' => $order_id)));
|
||||
$this->getLog()->addError(
|
||||
$this->getTranslator()->trans("Unknown order ID: %id", array('%id' => $order_id))
|
||||
);
|
||||
}
|
||||
|
||||
return $order;
|
||||
@@ -154,13 +221,15 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
{
|
||||
$this->getLog()->addInfo("Redirecting customer to payment success page");
|
||||
|
||||
$this->redirectToRoute(
|
||||
'order.placed',
|
||||
[],
|
||||
[
|
||||
'order_id' => $order_id
|
||||
],
|
||||
Router::ABSOLUTE_PATH
|
||||
throw new RedirectException(
|
||||
$this->retrieveUrlFromRouteId(
|
||||
'order.placed',
|
||||
[],
|
||||
[
|
||||
'order_id' => $order_id
|
||||
],
|
||||
Router::ABSOLUTE_PATH
|
||||
)
|
||||
);
|
||||
}
|
||||
|
||||
@@ -174,14 +243,16 @@ abstract class BasePaymentModuleController extends BaseFrontController
|
||||
{
|
||||
$this->getLog()->addInfo("Redirecting customer to payment failure page");
|
||||
|
||||
$this->redirectToRoute(
|
||||
'order.failed',
|
||||
[],
|
||||
[
|
||||
'order_id' => $order_id,
|
||||
'message' => $message
|
||||
],
|
||||
Router::ABSOLUTE_PATH
|
||||
throw new RedirectException(
|
||||
$this->retrieveUrlFromRouteId(
|
||||
'order.failed',
|
||||
[],
|
||||
[
|
||||
'order_id' => $order_id,
|
||||
'message' => $message
|
||||
],
|
||||
Router::ABSOLUTE_PATH
|
||||
)
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user