Files
Phraseanet/lib/Alchemy/Phrasea/Controller/Prod/TOU.php
Romain Neutron c01af76587 Add TOU route
2012-10-09 14:18:31 +02:00

82 lines
2.4 KiB
PHP

<?php
/*
* This file is part of Phraseanet
*
* (c) 2005-2012 Alchemy
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Alchemy\Phrasea\Controller\Prod;
use Silex\Application;
use Silex\ControllerProviderInterface;
use Silex\ControllerCollection;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
/**
*
* @license http://opensource.org/licenses/gpl-3.0 GPLv3
* @link www.phraseanet.com
*/
class TOU implements ControllerProviderInterface
{
public function connect(Application $app)
{
$controllers = $app['controllers_factory'];
$controllers->post('/deny/{sbas_id}/', function(Application $app, Request $request, $sbas_id) {
$ret = array('success' => false, 'message' => '');
try {
$user = $app['Core']->getAuthenticatedUser();
$session = \Session_Handler::getInstance(\appbox::get_instance($app['Core']));
$databox = \databox::get_instance((int) $sbas_id);
$user->ACL()->revoke_access_from_bases(
$user->ACL()->get_granted_base(array(), array($databox->get_sbas_id()))
);
$user->ACL()->revoke_unused_sbas_rights();
$session->logout();
$ret = array('success' => true, 'message' => '');
} catch (\Exception $e) {
}
$Serializer = $app['Core']['Serializer'];
$datas = $Serializer->serialize($ret, 'json');
return new Response($datas, 200, array('Content-Type' => 'application/json'));
});
$controllers->get('/', function(Application $app, Request $request) {
$appbox = \appbox::get_instance($app['Core']);
$data = array();
foreach ($appbox->get_databoxes() as $databox) {
$cgus = $databox->get_cgus();
if (!isset($cgus[\Session_Handler::get_locale()])) {
continue;
}
$data[$databox->get_viewname()] = $cgus[\Session_Handler::get_locale()]['value'];
}
return new Response($app['Core']['Twig']->render('/prod/TOU.html.twig', array('TOUs' => $data)));
});
return $controllers;
}
}