386 lines
13 KiB
PHP
386 lines
13 KiB
PHP
<?php
|
|
/*************************************************************************************/
|
|
/* */
|
|
/* Thelia */
|
|
/* */
|
|
/* Copyright (c) OpenStudio */
|
|
/* email : info@thelia.net */
|
|
/* web : http://www.thelia.net */
|
|
/* */
|
|
/* This program is free software; you can redistribute it and/or modify */
|
|
/* it under the terms of the GNU General Public License as published by */
|
|
/* the Free Software Foundation; either version 3 of the License */
|
|
/* */
|
|
/* 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 General Public License for more details. */
|
|
/* */
|
|
/* You should have received a copy of the GNU General Public License */
|
|
/* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
/* */
|
|
/*************************************************************************************/
|
|
namespace Thelia\Controller;
|
|
|
|
use Thelia\Core\Event\PdfEvent;
|
|
use Thelia\Core\Event\TheliaEvents;
|
|
use Thelia\Core\HttpFoundation\Response;
|
|
use Symfony\Component\DependencyInjection\ContainerAware;
|
|
|
|
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
|
|
use Symfony\Component\Routing\Exception\InvalidParameterException;
|
|
use Symfony\Component\Routing\Exception\MissingMandatoryParametersException;
|
|
use Symfony\Component\Routing\Exception\RouteNotFoundException;
|
|
use Symfony\Component\Routing\Router;
|
|
use Thelia\Core\Security\SecurityContext;
|
|
use Thelia\Core\Template\TemplateHelper;
|
|
use Thelia\Core\Translation\Translator;
|
|
use Thelia\Model\OrderQuery;
|
|
use Thelia\Tools\URL;
|
|
use Thelia\Tools\Redirect;
|
|
use Thelia\Core\Template\ParserContext;
|
|
use Thelia\Core\Event\ActionEvent;
|
|
use Symfony\Component\EventDispatcher\EventDispatcher;
|
|
use Thelia\Form\BaseForm;
|
|
use Thelia\Form\Exception\FormValidationException;
|
|
use Symfony\Component\EventDispatcher\Event;
|
|
use Thelia\Core\Event\DefaultActionEvent;
|
|
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException;
|
|
|
|
/**
|
|
*
|
|
* The defaut administration controller. Basically, display the login form if
|
|
* user is not yet logged in, or back-office home page if the user is logged in.
|
|
*
|
|
* @author Franck Allimant <franck@cqfdev.fr>
|
|
* @author Manuel Raynaud <mraynaud@openstudio.fr>
|
|
*/
|
|
|
|
abstract class BaseController extends ContainerAware
|
|
{
|
|
|
|
/**
|
|
* Return an empty response (after an ajax request, for example)
|
|
* @param int $status
|
|
* @return \Thelia\Core\HttpFoundation\Response
|
|
*/
|
|
protected function nullResponse($status = 200)
|
|
{
|
|
return new Response(null, $status);
|
|
}
|
|
|
|
/**
|
|
* Return a JSON response
|
|
*/
|
|
protected function jsonResponse($json_data, $status = 200)
|
|
{
|
|
return new Response($json_data, $status, array('content-type' => 'application/json'));
|
|
}
|
|
|
|
/**
|
|
* @param $pdf
|
|
* @param $fileName
|
|
* @param $status
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
*/
|
|
protected function pdfResponse($pdf, $fileName, $status = 200)
|
|
{
|
|
return Response::create($pdf, $status,
|
|
array(
|
|
'Content-type' => "application/pdf",
|
|
'Content-Disposition' => sprintf('Attachment;filename=%s.pdf', $fileName),
|
|
));
|
|
}
|
|
|
|
/**
|
|
* Dispatch a Thelia event
|
|
*
|
|
* @param string $eventName a TheliaEvent name, as defined in TheliaEvents class
|
|
* @param Event $event the action event, or null (a DefaultActionEvent will be dispatched)
|
|
*/
|
|
protected function dispatch($eventName, ActionEvent $event = null)
|
|
{
|
|
if ($event == null) $event = new DefaultActionEvent();
|
|
|
|
$this->getDispatcher()->dispatch($eventName, $event);
|
|
}
|
|
|
|
/**
|
|
* Return the event dispatcher,
|
|
*
|
|
* @return \Symfony\Component\EventDispatcher\EventDispatcher
|
|
*/
|
|
public function getDispatcher()
|
|
{
|
|
return $this->container->get('event_dispatcher');
|
|
}
|
|
|
|
/**
|
|
*
|
|
* return the Translator
|
|
*
|
|
* @return Translator
|
|
*/
|
|
public function getTranslator()
|
|
{
|
|
return $this->container->get('thelia.translator');
|
|
}
|
|
|
|
/**
|
|
* Return the parser context,
|
|
*
|
|
* @return ParserContext
|
|
*/
|
|
protected function getParserContext()
|
|
{
|
|
return $this->container->get('thelia.parser.context');
|
|
}
|
|
|
|
/**
|
|
* Return the security context, by default in admin mode.
|
|
*
|
|
* @return \Thelia\Core\Security\SecurityContext
|
|
*/
|
|
protected function getSecurityContext()
|
|
{
|
|
return $this->container->get('thelia.securityContext');
|
|
}
|
|
|
|
/**
|
|
* @return \Thelia\Core\HttpFoundation\Request
|
|
*/
|
|
protected function getRequest()
|
|
{
|
|
return $this->container->get('request');
|
|
}
|
|
|
|
/**
|
|
* Returns the session from the current request
|
|
*
|
|
* @return \Thelia\Core\HttpFoundation\Session\Session
|
|
*/
|
|
protected function getSession()
|
|
{
|
|
$request = $this->getRequest();
|
|
|
|
return $request->getSession();
|
|
}
|
|
|
|
/**
|
|
* Get all errors that occured in a form
|
|
*
|
|
* @param \Symfony\Component\Form\Form $form
|
|
* @return string the error string
|
|
*/
|
|
private function getErrorMessages(\Symfony\Component\Form\Form $form)
|
|
{
|
|
$errors = '';
|
|
|
|
foreach ($form->getErrors() as $key => $error) {
|
|
$errors .= $error->getMessage() . ', ';
|
|
}
|
|
|
|
foreach ($form->all() as $child) {
|
|
|
|
if (!$child->isValid()) {
|
|
|
|
$fieldName = $child->getConfig()->getOption('label', $child->getName());
|
|
|
|
$errors .= sprintf("[%s] %s, ", $fieldName, $this->getErrorMessages($child));
|
|
}
|
|
}
|
|
|
|
return rtrim($errors, ', ');
|
|
}
|
|
|
|
/**
|
|
* Validate a BaseForm
|
|
*
|
|
* @param BaseForm $aBaseForm the form
|
|
* @param string $expectedMethod the expected method, POST or GET, or null for any of them
|
|
* @throws FormValidationException is the form contains error, or the method is not the right one
|
|
* @return \Symfony\Component\Form\Form Form the symfony form object
|
|
*/
|
|
protected function validateForm(BaseForm $aBaseForm, $expectedMethod = null)
|
|
{
|
|
$form = $aBaseForm->getForm();
|
|
|
|
if ($expectedMethod == null || $aBaseForm->getRequest()->isMethod($expectedMethod)) {
|
|
|
|
$form->bind($aBaseForm->getRequest());
|
|
|
|
if ($form->isValid()) {
|
|
return $form;
|
|
} else {
|
|
$errorMessage = null;
|
|
if ($form->get("error_message")->getData() != null) {
|
|
$errorMessage = $form->get("error_message")->getData();
|
|
} else {
|
|
$errorMessage = sprintf("Missing or invalid data: %s", $this->getErrorMessages($form));
|
|
}
|
|
|
|
throw new FormValidationException($errorMessage);
|
|
}
|
|
} else {
|
|
throw new FormValidationException(sprintf("Wrong form method, %s expected.", $expectedMethod));
|
|
}
|
|
}
|
|
|
|
protected function generateOrderPdf($order_id, $fileName)
|
|
{
|
|
$html = $this->renderRaw(
|
|
$fileName,
|
|
array(
|
|
'order_id' => $order_id
|
|
),
|
|
TemplateHelper::getInstance()->getActivePdfTemplate()
|
|
);
|
|
|
|
$order = OrderQuery::create()->findPk($order_id);
|
|
|
|
try {
|
|
$pdfEvent = new PdfEvent($html);
|
|
|
|
$this->dispatch(TheliaEvents::GENERATE_PDF, $pdfEvent);
|
|
|
|
if ($pdfEvent->hasPdf()) {
|
|
return $this->pdfResponse($pdfEvent->getPdf(), $order->getRef());
|
|
}
|
|
|
|
} catch (\Exception $e) {
|
|
\Thelia\Log\Tlog::getInstance()->error(sprintf('error during generating invoice pdf for order id : %d with message "%s"', $order_id, $e->getMessage()));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
*
|
|
* redirect request to the specified url
|
|
*
|
|
* @param string $url
|
|
*/
|
|
public function redirect($url, $status = 302, $cookies = array())
|
|
{
|
|
Redirect::exec($url, $status, $cookies);
|
|
}
|
|
|
|
/**
|
|
* If success_url param is present in request or in the provided form, redirect to this URL.
|
|
*
|
|
* @param BaseForm $form a base form, which may contains the success URL
|
|
*/
|
|
protected function redirectSuccess(BaseForm $form = null)
|
|
{
|
|
if ($form != null) {
|
|
$url = $form->getSuccessUrl();
|
|
} else {
|
|
$url = $this->getRequest()->get("success_url");
|
|
}
|
|
|
|
if (null !== $url) $this->redirect($url);
|
|
}
|
|
|
|
/**
|
|
* Get a route path from the route id.
|
|
*
|
|
* @param string $routerName Router name
|
|
* @param string $routeId The name of the route
|
|
* @param mixed $parameters An array of parameters
|
|
* @param Boolean|string $referenceType The type of reference to be generated (one of the constants)
|
|
*
|
|
* @throws RouteNotFoundException If the named route doesn't exist
|
|
* @throws MissingMandatoryParametersException When some parameters are missing that are mandatory for the route
|
|
* @throws InvalidParameterException When a parameter value for a placeholder is not correct because
|
|
* it does not match the requirement
|
|
* @throws \InvalidArgumentException When the router doesn't exist
|
|
* @return string The generated URL
|
|
*/
|
|
protected function getRouteFromRouter($routerName, $routeId, $parameters = array(), $referenceType = Router::ABSOLUTE_URL)
|
|
{
|
|
/** @var Router $router */
|
|
$router = $this->container->get($routerName);
|
|
|
|
if ($router == null) {
|
|
throw new \InvalidArgumentException(sprintf("Router '%s' does not exists.", $routerName));
|
|
}
|
|
|
|
return $router->generate($routeId, $parameters, $referenceType);
|
|
}
|
|
|
|
/**
|
|
* Return a 404 error
|
|
* @throws \Symfony\Component\HttpKernel\Exception\NotFoundHttpException
|
|
*/
|
|
protected function pageNotFound()
|
|
{
|
|
throw new NotFoundHttpException();
|
|
}
|
|
|
|
/**
|
|
* Check if environment is in debug mode
|
|
*
|
|
* @return bool
|
|
*/
|
|
protected function isDebug()
|
|
{
|
|
return $this->container->getParameter('kernel.debug');
|
|
}
|
|
|
|
protected function accessDenied()
|
|
{
|
|
throw new AccessDeniedHttpException();
|
|
}
|
|
|
|
/**
|
|
* check if the current http request is a XmlHttpRequest.
|
|
*
|
|
* If not, send a
|
|
*/
|
|
protected function checkXmlHttpRequest()
|
|
{
|
|
if (false === $this->getRequest()->isXmlHttpRequest() && false === $this->isDebug()) {
|
|
$this->accessDenied();
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
* return an instance of \Swift_Mailer with good Transporter configured.
|
|
*
|
|
* @return \Swift_Mailer
|
|
*/
|
|
public function getMailer()
|
|
{
|
|
$mailer = $this->container->get('mailer');
|
|
|
|
return $mailer->getSwiftMailer();
|
|
}
|
|
|
|
/**
|
|
* @return a ParserInterface instance parser
|
|
*/
|
|
abstract protected function getParser($template = null);
|
|
|
|
/**
|
|
* Render the given template, and returns the result as an Http Response.
|
|
*
|
|
* @param $templateName the complete template name, with extension
|
|
* @param array $args the template arguments
|
|
* @param int $status http code status
|
|
* @return \Thelia\Core\HttpFoundation\Response
|
|
*/
|
|
abstract protected function render($templateName, $args = array(), $status = 200);
|
|
|
|
/**
|
|
* Render the given template, and returns the result as a string.
|
|
*
|
|
* @param $templateName the complete template name, with extension
|
|
* @param array $args the template arguments
|
|
* @param null $templateDir
|
|
*
|
|
* @return string
|
|
*/
|
|
abstract protected function renderRaw($templateName, $args = array(), $templateDir = null);
|
|
}
|