Пример #1
0
 /**
  * Handle paybox Response listener
  *
  * @param PayboxResponseEvent $event
  */
 public function onPayboxIpnResponse(PayboxResponseEvent $event)
 {
     if ($event->isVerified()) {
         $this->logger->info('Verified Ipn received, payment is stored.');
         $ipnData = new IpnData($event->getData());
         $payment = new Payment();
         $payment->setAutorisation($ipnData->getAuthorisationId())->setTransaction($ipnData->getTransactionId())->setResponseCode($ipnData->getErrorCode())->setResponse($ipnData->getData())->setStatus($this->normalizer->normalize($ipnData->getErrorCode()));
         // On attache le paiement à l'intent
         $this->intentManager->attachPayment($ipnData->getIntentId(), $payment);
         return;
     }
     //unverified ipn... we just log it as warning
     //@TODO do something smartter to keep track of thoses
     $this->logger->warning('Unverified Ipn received, content is ignored.');
 }
Пример #2
0
 /**
  * traitement réel du paiement
  *
  * @param  Ecedi\Donate\OgoneBundle\Ogone\Response $response
  * @return Payment                                 the payment instance
  */
 protected function doHandle(Response $response)
 {
     //initialize payment
     $payment = new Payment();
     $payment->setAutorisation($response->getAcceptance())->setTransaction($response->getPayId())->setResponseCode($response->getStatus())->setResponse($response);
     $normalizer = $this->container->get('donate_ogone.status_normalizer');
     $payment->setStatus($normalizer->normalize($response->getStatus()));
     try {
         //validate response
         $this->validate($response);
         $this->logger->debug('Payment Status : ' . $payment->getStatus());
     } catch (UnauthorizedPostSaleException $e) {
         $this->logger->warning('Incorrectly signed post-sale received');
         $payment->setStatus(Payment::STATUS_INVALID);
     }
     //add payment to intent
     try {
         $intentId = $this->getIntentId($response);
         $this->logger->debug('found intent id ' . $intentId);
     } catch (CannotDetermineOrderIdException $e) {
         $this->logger->warning('CannotDetermineOrderIdException');
         $intentId = false;
         //TODO le payment p-e ok, mais il est orphelin
     }
     $this->intentManager->attachPayment($intentId, $payment);
     return $payment;
 }