api/src/Payment/DataPersister/PaymentPaymentDataPersister.php
<?php
/**
* Copyright (c) 2020, MOBICOOP. All rights reserved.
* This project is dual licensed under AGPL and proprietary licence.
***************************
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <gnu.org/licenses>.
***************************
* Licence MOBICOOP described in the file
* LICENSE
**************************/
namespace App\Payment\DataPersister;
use ApiPlatform\Core\DataPersister\ContextAwareDataPersisterInterface;
use App\Payment\Exception\PaymentException;
use App\Payment\Ressource\PaymentPayment;
use App\Payment\Service\PaymentManager;
use Symfony\Component\Security\Core\Security;
/**
* @author Sylvain Briat <sylvain.briat@mobicoop.org>
*/
final class PaymentPaymentDataPersister implements ContextAwareDataPersisterInterface
{
private $paymentManager;
private $security;
public function __construct(PaymentManager $paymentManager, Security $security)
{
$this->paymentManager = $paymentManager;
$this->security = $security;
}
public function supports($data, array $context = []): bool
{
return $data instanceof PaymentPayment;
}
public function persist($data, array $context = [])
{
// call your persistence layer to save $data
if (isset($context['collection_operation_name']) && $context['collection_operation_name'] == 'post') {
/**
* @var PaymentPayment $data
*/
// If there is at least one online payment we check if the can pay electronicaly
$electronicPayment = false;
foreach ($data->getItems() as $item) {
if ($item['mode']==PaymentPayment::MODE_ONLINE) {
$electronicPayment = true;
}
}
if ($electronicPayment && !$this->paymentManager->checkValidForRegistrationToTheProvider($this->security->getUser())) {
throw new PaymentException(PaymentException::USER_INVALID);
}
$data = $this->paymentManager->createPaymentPayment($data, $this->security->getUser());
}
return $data;
}
public function remove($data, array $context = [])
{
// call your persistence layer to delete $data
}
}