/** * 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.'); }
/** * 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; }