Il manquait des fichiers dans le module Mercanet (sur Git)

This commit is contained in:
2024-01-12 10:37:52 +01:00
parent 4054fddbe5
commit 485580e0b2
22 changed files with 2034 additions and 0 deletions

View File

@@ -0,0 +1,104 @@
<?php
/*************************************************************************************/
/* Copyright (c) Franck Allimant, CQFDev */
/* email : thelia@cqfdev.fr */
/* web : http://www.cqfdev.fr */
/* */
/* For the full copyright and license information, please view the LICENSE */
/* file that was distributed with this source code. */
/*************************************************************************************/
namespace Mercanet\Controller;
use Mercanet\Mercanet;
use Symfony\Component\HttpFoundation\Response;
use Thelia\Controller\Admin\BaseAdminController;
use Thelia\Core\Security\AccessManager;
use Thelia\Core\Security\Resource\AdminResources;
use Thelia\Form\Exception\FormValidationException;
use Thelia\Tools\URL;
/**
* Class ConfigureController
* @package Mercanet\Controller
* @author Franck Allimant <franck@cqfdev.fr>
*/
class ConfigureController extends BaseAdminController
{
public function downloadLog()
{
if (null !== $response = $this->checkAuth(AdminResources::MODULE, 'mercanet', AccessManager::UPDATE)) {
return $response;
}
$logFilePath = sprintf(THELIA_ROOT."log".DS."%s.log", Mercanet::MODULE_DOMAIN);
return Response::create(
@file_get_contents($logFilePath),
200,
array(
'Content-type' => "text/plain",
'Content-Disposition' => sprintf('Attachment;filename=mercanet-log.txt')
)
);
}
public function configure()
{
if (null !== $response = $this->checkAuth(AdminResources::MODULE, 'mercanet', AccessManager::UPDATE)) {
return $response;
}
$configurationForm = $this->createForm('mercanet_configuration');
$message = null;
try {
$form = $this->validateForm($configurationForm);
// Get the form field values
$data = $form->getData();
foreach ($data as $name => $value) {
if (is_array($value)) {
$value = implode(';', $value);
}
Mercanet::setConfigValue($name, $value);
}
$merchantId = $data['merchantId'];
// Log configuration modification
$this->adminLogAppend(
"mercanet.configuration.message",
AccessManager::UPDATE,
"Mercanet configuration updated"
);
// Redirect to the success URL,
if ($this->getRequest()->get('save_mode') == 'stay') {
// If we have to stay on the same page, redisplay the configuration page/
$url = '/admin/module/Mercanet';
} else {
// If we have to close the page, go back to the module back-office page.
$url = '/admin/modules';
}
return $this->generateRedirect(URL::getInstance()->absoluteUrl($url));
} catch (FormValidationException $ex) {
$message = $this->createStandardFormValidationErrorMessage($ex);
} catch (\Exception $ex) {
$message = $ex->getMessage();
}
$this->setupFormErrorContext(
$this->getTranslator()->trans("Mercanet configuration", [], Mercanet::MODULE_DOMAIN),
$message,
$configurationForm,
$ex
);
return $this->generateRedirect(URL::getInstance()->absoluteUrl('/admin/module/Mercanet'));
}
}

View File

@@ -0,0 +1,242 @@
<?php
/*************************************************************************************/
/* Copyright (c) Franck Allimant, CQFDev */
/* email : thelia@cqfdev.fr */
/* web : http://www.cqfdev.fr */
/* */
/* For the full copyright and license information, please view the LICENSE */
/* file that was distributed with this source code. */
/*************************************************************************************/
namespace Mercanet\Controller;
use Mercanet\Api\MercanetApi;
use Mercanet\Mercanet;
use Thelia\Core\Event\Order\OrderEvent;
use Thelia\Core\Event\TheliaEvents;
use Thelia\Core\HttpFoundation\Response;
use Thelia\Exception\TheliaProcessException;
use Thelia\Model\OrderQuery;
use Thelia\Model\OrderStatusQuery;
use Thelia\Module\BasePaymentModuleController;
/**
* Class PaymentController
* @package Mercanet\Controller
* Franck Allimant <franck@cqfdev.fr>
*/
class PaymentController extends BasePaymentModuleController
{
protected static $resultCodes = [
'00' => ' Transaction acceptée',
'02' => ' Demande dautorisation par téléphone à la banque à cause dun dépassement du plafond dautorisation sur la carte, si vous êtes autorisé à forcer les transactions',
'03' => ' Contrat commerçant invalide',
'05' => ' Autorisation refusée',
'11' => ' Utilisé dans le cas d\'un contrôle différé. Le PAN est en opposition',
'12' => ' Transaction invalide, vérifier les paramètres transférés dans la requête',
'14' => ' Coordonnées du moyen de paiement invalides (ex: n° de carte ou cryptogramme visuel de la carte) ou vérification AVS échouée',
'17' => ' Annulation de lacheteur',
'30' => ' Erreur de format',
'34' => ' Suspicion de fraude (seal erroné)',
'54' => ' Date de validité du moyen de paiement dépassée',
'75' => ' Nombre de tentatives de saisie des coordonnées du moyen de paiement sous Sips Paypage dépassé',
'90' => ' Service temporairement indisponible',
'94' => ' Transaction dupliquée : la référence de transaction est déjà utilisé',
'97' => ' Délai expiré, transaction refusée',
'99' => ' Problème temporaire du serveur de paiement.',
];
/**
* Traitement de la réponse manuelle. La réponse manuelle est l'URL vers laquelle le client est
* redirigé une fois le paiement effectué (ou annulé).
*
* La validation de commande est efectuée dans le traitement de la réponse automatique (le callback de la banque).
*/
public function processManualResponse(): void
{
$this->getLog()->addInfo(
$this->getTranslator()->trans(
"Mercanet manual response processing.",
[],
Mercanet::MODULE_DOMAIN
)
);
$paymentResponse = new MercanetApi(Mercanet::getConfigValue('secretKey'));
$paymentResponse->setResponse($_POST);
$this->getLog()->addInfo(
$this->getTranslator()->trans(
'Response parameters : %resp',
['%resp' => print_r($paymentResponse->getDataString(), true)],
Mercanet::MODULE_DOMAIN
)
);
$order = OrderQuery::create()
->filterById($paymentResponse->getParam('ORDERID'))
->filterByPaymentModuleId(Mercanet::getModuleId())
->findOne();
if ($paymentResponse->isValid() && $paymentResponse->isSuccessful()) {
$this->redirectToSuccessPage($order->getId());
}
$resultCode = $paymentResponse->getParam('RESPONSECODE');
// Annulation de la commande
if ((int) $resultCode === 17) {
$this->processUserCancel($order->getId());
}
$message = self::$resultCodes[$resultCode] ?? 'Raison inconnue';
$this->redirectToFailurePage($order->getId(), $message);
}
/**
* @return \Symfony\Component\HttpFoundation\Response
* @throws \Exception
*/
public function processMercanetRequest()
{
$this->getLog()->addInfo(
$this->getTranslator()->trans(
"Mercanet automatic response processing.",
[],
Mercanet::MODULE_DOMAIN
)
);
$paymentResponse = new MercanetApi(Mercanet::getConfigValue('secretKey'));
$paymentResponse->setResponse($_POST);
$this->getLog()->addInfo(
$this->getTranslator()->trans(
'Response parameters : %resp',
['%resp' => print_r($paymentResponse->getDataString(), true)],
Mercanet::MODULE_DOMAIN
)
);
if ($paymentResponse->isValid()) {
if (null !== $order = OrderQuery::create()
->filterById($paymentResponse->getParam('ORDERID'))
->filterByPaymentModuleId(Mercanet::getModuleId())
->findOne()) {
if ($paymentResponse->isSuccessful()) {
$this->confirmPayment($order->getId());
$this->getLog()->addInfo(
$this->getTranslator()->trans(
'Order ID %id is confirmed, transaction référence "%trans"',
[
'%id' => $order->getId(),
'%trans' => $paymentResponse->getParam('TRANSACTIONREFERENCE')
],
Mercanet::MODULE_DOMAIN
)
);
} else {
$this->getLog()->addError(
$this->getTranslator()->trans(
'Cannot validate order. Response code is %resp',
['%resp' => $paymentResponse->getParam('RESPONSECODE')],
Mercanet::MODULE_DOMAIN
)
);
// Cancel order.
$event = (new OrderEvent($order))
->setStatus(OrderStatusQuery::getCancelledStatus()->getId());
$this->dispatch(TheliaEvents::ORDER_UPDATE_STATUS, $event);
$this->getLog()->addError(
$this->getTranslator()->trans('Order was canceled.', [], Mercanet::MODULE_DOMAIN)
);
}
} else {
$this->getLog()->addError(
$this->getTranslator()->trans(
'Cannot find an order for transaction référence "%trans"',
['%trans' => $paymentResponse->getParam('TRANSACTIONREFERENCE')],
Mercanet::MODULE_DOMAIN
)
);
}
} else {
$this->getTranslator()->trans(
'Got invalid response from Mercanet',
[ ],
Mercanet::MODULE_DOMAIN
);
}
$this->getLog()->addInfo(
$this->getTranslator()->trans(
"Automatic response processing terminated.",
[],
Mercanet::MODULE_DOMAIN
)
);
return new Response('OK');
}
/*
* @param $orderId int the order ID
* @return \Thelia\Core\HttpFoundation\Response
*/
public function processUserCancel($orderId): void
{
$this->getLog()->addInfo(
$this->getTranslator()->trans(
'User canceled payment of order %id',
['%id' => $orderId],
Mercanet::MODULE_DOMAIN
)
);
try {
if (null !== $order = OrderQuery::create()->findPk($orderId)) {
$currentCustomerId = $this->getSecurityContext()->getCustomerUser()->getId();
$orderCustomerId = $order->getCustomerId();
if ($orderCustomerId !== $currentCustomerId) {
throw new TheliaProcessException(
sprintf(
"User ID %d is trying to cancel order ID %d ordered by user ID %d",
$currentCustomerId,
$orderId,
$orderCustomerId
)
);
}
$event = new OrderEvent($order);
$event->setStatus(OrderStatusQuery::getCancelledStatus()->getId());
$this->dispatch(TheliaEvents::ORDER_UPDATE_STATUS, $event);
}
} catch (\Exception $ex) {
$this->getLog()->addError("Error occurred while canceling order ID $orderId: " . $ex->getMessage());
}
$this->redirectToFailurePage(
$orderId,
$this->getTranslator()->trans('you cancel the payment', [], Mercanet::MODULE_DOMAIN)
);
}
/**
* Return a module identifier used to calculate the name of the log file,
* and in the log messages.
*
* @return string the module code
*/
protected function getModuleCode()
{
return 'Mercanet';
}
}