2010-11-22 13:50:12 +01:00
|
|
|
<?php
|
2017-02-13 13:53:40 +01:00
|
|
|
use Monolog\Logger;
|
|
|
|
use Monolog\Handler\StreamHandler;
|
|
|
|
use Monolog\Processor\IntrospectionProcessor;
|
2017-02-20 12:07:51 +01:00
|
|
|
use Monolog\Handler\ChromePHPHandler;
|
2017-02-13 13:53:40 +01:00
|
|
|
|
2010-11-22 13:50:12 +01:00
|
|
|
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
|
2012-07-30 11:13:34 +02:00
|
|
|
{
|
2015-10-05 17:38:02 +02:00
|
|
|
/**
|
|
|
|
* Set config available in all apps
|
|
|
|
*/
|
|
|
|
protected function _initConfig()
|
2012-11-05 16:33:01 +01:00
|
|
|
{
|
|
|
|
$config = new Zend_Config($this->getOptions());
|
|
|
|
Zend_Registry::set('config', $config);
|
|
|
|
return $config;
|
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2015-10-05 17:38:02 +02:00
|
|
|
/**
|
|
|
|
* Init controller with modules
|
|
|
|
*/
|
|
|
|
protected function _initController()
|
|
|
|
{
|
|
|
|
$this->bootstrap('frontController');
|
|
|
|
$front = $this->getResource('frontController');
|
|
|
|
$front->setControllerDirectory(array(
|
|
|
|
'default' => __DIR__ . '/modules/default/controllers',
|
|
|
|
'admin' => __DIR__ . '/modules/admin/controllers',
|
2016-02-09 09:41:36 +01:00
|
|
|
'file' => __DIR__ . '/modules/file/controllers',
|
2015-10-05 17:38:02 +02:00
|
|
|
));
|
|
|
|
|
|
|
|
return $front;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialisation global des paramètres de vue
|
|
|
|
*/
|
2010-11-22 13:50:12 +01:00
|
|
|
protected function _initViewSettings()
|
|
|
|
{
|
2011-01-11 09:43:13 +01:00
|
|
|
$this->bootstrap('view');
|
2012-07-30 11:13:34 +02:00
|
|
|
$view = $this->getResource('view');
|
|
|
|
$view->setEncoding('UTF-8');
|
2012-03-23 11:55:01 +01:00
|
|
|
$view->headTitle()->setSeparator(' - ');
|
|
|
|
$view->headTitle('Extranet Scores & Décisions');
|
2010-11-22 13:50:12 +01:00
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2015-10-05 17:38:02 +02:00
|
|
|
/**
|
|
|
|
* Some specific route
|
|
|
|
* @return unknown
|
|
|
|
*/
|
2011-01-05 10:59:49 +01:00
|
|
|
protected function _initRouter()
|
|
|
|
{
|
|
|
|
$this->bootstrap('frontController');
|
|
|
|
$front = $this->getResource('frontController');
|
|
|
|
$router = $front->getRouter();
|
2014-12-09 12:28:12 +01:00
|
|
|
|
2011-04-28 12:24:53 +02:00
|
|
|
$localauthRoute = new Zend_Controller_Router_Route('localauth/', array(
|
2015-10-27 09:31:20 +01:00
|
|
|
'module' => 'default',
|
2011-04-28 12:24:53 +02:00
|
|
|
'controller' => 'user',
|
2015-10-27 09:31:20 +01:00
|
|
|
'action' => 'login'
|
2011-01-05 10:59:49 +01:00
|
|
|
));
|
2014-12-09 12:28:12 +01:00
|
|
|
$router->addRoute('localauth', $localauthRoute);
|
|
|
|
|
2011-04-28 12:24:53 +02:00
|
|
|
$printRoute = new Zend_Controller_Router_Route('editer/:action/:fichier', array(
|
2015-10-27 09:31:20 +01:00
|
|
|
'module' => 'default',
|
2011-04-28 12:24:53 +02:00
|
|
|
'controller' => 'print',
|
|
|
|
'fichier' => '',
|
|
|
|
));
|
|
|
|
$router->addRoute('print', $printRoute);
|
2014-12-09 12:28:12 +01:00
|
|
|
|
2014-12-12 11:04:17 +01:00
|
|
|
$ssoRoute = new Zend_Controller_Router_Route('sso/:partner/', array(
|
2015-10-27 09:31:20 +01:00
|
|
|
'module' => 'default',
|
2014-12-09 12:28:12 +01:00
|
|
|
'controller' => 'auth',
|
|
|
|
'action' => 'index',
|
|
|
|
));
|
|
|
|
$router->addRoute('sso', $ssoRoute);
|
|
|
|
|
2011-01-05 10:59:49 +01:00
|
|
|
return $router;
|
|
|
|
}
|
|
|
|
|
2011-06-14 16:03:40 +02:00
|
|
|
protected function _initLogging()
|
|
|
|
{
|
2012-07-30 11:13:34 +02:00
|
|
|
//Firebug
|
2011-01-07 18:16:07 +01:00
|
|
|
$writer = new Zend_Log_Writer_Firebug();
|
2011-09-27 11:13:13 +02:00
|
|
|
if(APPLICATION_ENV=='production') {
|
2012-07-30 11:13:34 +02:00
|
|
|
$writer->setEnabled(false);
|
2011-09-27 11:13:13 +02:00
|
|
|
}
|
2011-01-07 18:16:07 +01:00
|
|
|
$logger = new Zend_Log($writer);
|
|
|
|
Zend_Registry::set('firebug', $logger);
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2011-08-05 11:24:08 +02:00
|
|
|
//Application Logger en Production
|
|
|
|
$AppLogger = new Zend_Log();
|
|
|
|
if (APPLICATION_ENV == 'production')
|
|
|
|
{
|
|
|
|
$Mail = new Zend_Mail();
|
|
|
|
$Mail->setFrom('production@scores-decisions.com')
|
|
|
|
->addTo('supportdev@scores-decisions.com');
|
2011-09-29 17:15:14 +02:00
|
|
|
$AppMailWriter = new Zend_Log_Writer_Mail($Mail);
|
2011-08-05 11:24:08 +02:00
|
|
|
$AppMailWriter->setSubjectPrependText('ERREUR');
|
|
|
|
$AppMailWriter->addFilter(Zend_Log::ERR);
|
2011-09-29 17:15:14 +02:00
|
|
|
$AppLogger->addWriter($AppMailWriter);
|
2011-08-05 11:24:08 +02:00
|
|
|
}
|
|
|
|
Zend_Registry::set('log', $AppLogger);
|
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2017-02-10 16:54:46 +01:00
|
|
|
/**
|
|
|
|
* Logs and Debug
|
|
|
|
*/
|
|
|
|
protected function _initLogger()
|
|
|
|
{
|
|
|
|
$config = new Zend_Config($this->getOptions());
|
|
|
|
$logFile = $config->profil->path->shared.'/log/application.log';
|
|
|
|
|
|
|
|
$log = new Logger('APP');
|
|
|
|
|
|
|
|
// Console Handler
|
|
|
|
if (in_array(APPLICATION_ENV, array('development', 'staging'))) {
|
2017-02-20 16:59:03 +01:00
|
|
|
//$log->pushHandler(new BrowserConsoleHandler());
|
|
|
|
//$log->pushHandler(new ChromePHPHandler());
|
2017-02-10 16:54:46 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// File Handler
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
$level = Logger::DEBUG;
|
|
|
|
} else {
|
|
|
|
$level = Logger::INFO;
|
|
|
|
}
|
|
|
|
$log->pushHandler(new StreamHandler($logFile), $level);
|
|
|
|
|
|
|
|
// Processor
|
|
|
|
$log->pushProcessor(new IntrospectionProcessor());
|
|
|
|
|
|
|
|
Zend_Registry::set('logger', $log);
|
|
|
|
}
|
|
|
|
|
2015-10-05 17:38:02 +02:00
|
|
|
/**
|
|
|
|
* Init database
|
|
|
|
*/
|
2012-01-29 12:28:40 +01:00
|
|
|
protected function _initDb()
|
|
|
|
{
|
2012-11-05 16:33:01 +01:00
|
|
|
$c = Zend_Registry::get('config');
|
2012-01-29 12:28:40 +01:00
|
|
|
try {
|
2012-11-16 15:12:03 +01:00
|
|
|
$db = Zend_Db::factory($c->profil->db->sdv1);
|
2012-07-30 11:13:34 +02:00
|
|
|
$db->getConnection();
|
2012-01-29 12:28:40 +01:00
|
|
|
} catch ( Exception $e ) {
|
2012-07-30 11:13:34 +02:00
|
|
|
if (APPLICATION_ENV == 'development') {
|
2012-11-05 16:33:01 +01:00
|
|
|
echo '<pre>'; print_r($e); echo '</pre>';
|
2012-07-30 11:13:34 +02:00
|
|
|
} else {
|
|
|
|
echo "Le service rencontre actuellement un problème technique.";
|
|
|
|
}
|
|
|
|
exit;
|
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2012-07-30 11:13:34 +02:00
|
|
|
/**
|
|
|
|
* Set the default adapter to use with all model
|
|
|
|
*/
|
|
|
|
Zend_Db_Table::setDefaultAdapter($db);
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2012-07-30 11:13:34 +02:00
|
|
|
/**
|
|
|
|
* Set Firebug Database profiler
|
|
|
|
*/
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
$profiler = new Zend_Db_Profiler_Firebug('All DB Queries');
|
|
|
|
$profiler->setEnabled(true);
|
|
|
|
$db->setProfiler($profiler);
|
2012-01-29 12:28:40 +01:00
|
|
|
}
|
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2015-10-05 17:38:02 +02:00
|
|
|
/**
|
|
|
|
* Init cache
|
|
|
|
*/
|
2012-03-15 16:56:06 +01:00
|
|
|
protected function _initCache()
|
|
|
|
{
|
2017-01-05 11:06:18 +01:00
|
|
|
// @todo : Remove for PHP7 Compatibility
|
2012-03-15 16:56:06 +01:00
|
|
|
//MetadataCache pour la base de données
|
2015-10-05 17:38:02 +02:00
|
|
|
$cache = Zend_Cache::factory('Core', 'Apc',
|
|
|
|
array('lifetime' => 28800, 'automatic_serialization' => true),
|
2013-06-03 09:17:05 +02:00
|
|
|
array()
|
|
|
|
);
|
2013-05-29 15:10:19 +02:00
|
|
|
Zend_Db_Table_Abstract::setDefaultMetadataCache($cache);
|
2012-03-15 16:56:06 +01:00
|
|
|
}
|
2013-05-14 11:32:08 +02:00
|
|
|
|
2013-05-29 15:10:19 +02:00
|
|
|
}
|