138 lines
4.3 KiB
PHP
138 lines
4.3 KiB
PHP
<?php
|
|
|
|
class stPayNowFrontendActions extends stActions
|
|
{
|
|
public function executeReturn()
|
|
{
|
|
$status = $this->getRequestParameter('paymentStatus');
|
|
$id = $this->getRequestParameter('id');
|
|
$hash_code = $this->getRequestParameter('hash_code');
|
|
|
|
$order = OrderPeer::retrieveByIdAndHashCode($id, $hash_code);
|
|
|
|
stPayNow::log("Return from payment for order {$order->getNumber()} with parameters " . stPayNow::logFormat($this->getRequest()->getParameterHolder()->getAll()));
|
|
|
|
if ($status == 'ERROR')
|
|
{
|
|
return $this->redirect('@stPayNowFail?id='.$id.'&hash_code='.$hash_code);
|
|
}
|
|
elseif ($status != 'CONFIRMED')
|
|
{
|
|
$order->getOrderPayment()->setInProgress(true);
|
|
$order->getOrderPayment()->save();
|
|
}
|
|
else
|
|
{
|
|
$order->getOrderPayment()->setInProgress(false);
|
|
$order->getOrderPayment()->save();
|
|
}
|
|
|
|
$this->smarty = new stSmarty($this->getModuleName());
|
|
|
|
$this->smarty->assign('status', $status);
|
|
}
|
|
|
|
public function executeFail()
|
|
{
|
|
$this->smarty = new stSmarty($this->getModuleName());
|
|
|
|
$webpage = WebpagePeer::retrieveByState('CONTACT');
|
|
|
|
sfLoader::loadHelpers(array('Helper', 'stUrl'));
|
|
|
|
$id = $this->getRequestParameter('id');
|
|
$hash_code = $this->getRequestParameter('hash_code');
|
|
|
|
if ($webpage)
|
|
{
|
|
$this->smarty->assign('contact_url', st_url_for('stWebpageFrontend/index?url='.$webpage->getFriendlyUrl()));
|
|
}
|
|
|
|
$this->smarty->assign('payment_url', st_url_for('@stPaymentPay?id='.$id.'&hash_code='.$hash_code));
|
|
}
|
|
|
|
public function executeProcessPayment()
|
|
{
|
|
$order = OrderPeer::retrieveByIdAndHashCode($this->getRequestParameter('id'), $this->getRequestParameter('hash'));
|
|
|
|
$api = new stPayNow();
|
|
|
|
$url = $api->createPayment($order);
|
|
|
|
if ($url)
|
|
{
|
|
stPayNow::log('Success: '. $url);
|
|
|
|
return $this->renderJSON(array('redirect' => $url));
|
|
}
|
|
|
|
stPayNow::log('Failure: '. $api->getLastError());
|
|
|
|
return $this->renderJSON(array('redirect' => $this->getController()->genUrl('@stPayNowFail?id='.$order->getId().'&hash_code='.$order->getHashCode())));
|
|
}
|
|
|
|
public function executeNotify()
|
|
{
|
|
$data = trim(file_get_contents('php://input'));
|
|
$headers = getallheaders();
|
|
|
|
stPayNow::log('Payment notification: '. $data . ' with headers '.stPayNow::logFormat($headers));
|
|
|
|
if ($this->getRequestParameter('token') != stPayNow::getSecurityToken())
|
|
{
|
|
stPayNow::log('Wrong shop security token');
|
|
$this->getResponse()->setStatusCode(400);
|
|
return sfView::HEADER_ONLY;
|
|
}
|
|
|
|
$api = new stPayNow();
|
|
$notification = $api->parseStatusNotification($data, $headers);
|
|
|
|
if (false === $notification)
|
|
{
|
|
stPayNow::log('Wrong signature');
|
|
$this->getResponse()->setStatusCode(400);
|
|
return sfView::HEADER_ONLY;
|
|
}
|
|
|
|
$order = OrderPeer::retrieveByNumber($notification['externalId']);
|
|
|
|
if (!$order)
|
|
{
|
|
stPayNow::log(sprintf('Order "%s" does not exist', $notification['externalId']));
|
|
$this->getResponse()->setStatusCode(400);
|
|
return sfView::HEADER_ONLY;
|
|
}
|
|
elseif ($order->getOrderPayment())
|
|
{
|
|
$payment = $order->getOrderPayment();
|
|
|
|
switch ($notification['status'])
|
|
{
|
|
case 'CONFIRMED':
|
|
$payment->setInProgress(false);
|
|
$payment->setStatus(true);
|
|
$payment->save();
|
|
|
|
stPayNow::log(sprintf('Payment status for order "%s" updated succesfully', $order->getNumber()));
|
|
break;
|
|
|
|
case 'PENDING':
|
|
$payment->setInProgress(true);
|
|
break;
|
|
|
|
case 'REJECTED':
|
|
$payment->setInProgress(false);
|
|
break;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
stPayNow::log(sprintf('Payment for order "%s" does not exist', $notification['externalId']));
|
|
$this->getResponse()->setStatusCode(400);
|
|
return sfView::HEADER_ONLY;
|
|
}
|
|
|
|
return $this->renderText('OK');
|
|
}
|
|
} |