2013-11-05 12:18:30 +01:00
|
|
|
<?php
|
2017-01-31 15:41:43 +01:00
|
|
|
use Monolog\Logger;
|
|
|
|
use Monolog\Handler\StreamHandler;
|
|
|
|
use Monolog\Processor\IntrospectionProcessor;
|
|
|
|
|
2013-11-05 12:18:30 +01:00
|
|
|
class Bootstrap extends Zend_Application_Bootstrap_Bootstrap
|
|
|
|
{
|
|
|
|
protected function _initConfig()
|
|
|
|
{
|
|
|
|
$config = new Zend_Config($this->getOptions());
|
|
|
|
Zend_Registry::set('config', $config);
|
|
|
|
|
2015-07-03 15:28:52 +02:00
|
|
|
define('MYSQL_HOST', $config->profil->db->metier->params->host);
|
|
|
|
define('MYSQL_USER', $config->profil->db->metier->params->username);
|
|
|
|
define('MYSQL_PASS', $config->profil->db->metier->params->password);
|
2016-11-29 15:10:11 +01:00
|
|
|
define('LOG_PATH', $config->profil->path->shared.'/log');
|
2015-07-03 15:28:52 +02:00
|
|
|
|
|
|
|
// Entreprise
|
|
|
|
define('SPHINX_ENT_HOST', $config->profil->sphinx->ent->host);
|
|
|
|
define('SPHINX_ENT_PORT', intval($config->profil->sphinx->ent->port));
|
|
|
|
define('SPHINX_ENT_VERSION', $config->profil->sphinx->ent->version);
|
|
|
|
|
|
|
|
// Dirigeants
|
|
|
|
define('SPHINX_DIR_HOST', $config->profil->sphinx->dir->host);
|
|
|
|
define('SPHINX_DIR_PORT', intval($config->profil->sphinx->dir->port));
|
|
|
|
define('SPHINX_DIR_VERSION', $config->profil->sphinx->dir->version);
|
|
|
|
|
|
|
|
// Historique
|
|
|
|
define('SPHINX_HISTO_HOST', $config->profil->sphinx->histo->host);
|
|
|
|
define('SPHINX_HISTO_PORT', intval($config->profil->sphinx->histo->port));
|
|
|
|
define('SPHINX_HISTO_VERSION', $config->profil->sphinx->histo->version);
|
|
|
|
|
|
|
|
// Actionnaire
|
|
|
|
define('SPHINX_ACT_HOST', $config->profil->sphinx->act->host);
|
|
|
|
define('SPHINX_ACT_PORT', intval($config->profil->sphinx->act->port));
|
|
|
|
define('SPHINX_ACT_VERSION', $config->profil->sphinx->act->version);
|
|
|
|
|
|
|
|
//Old
|
|
|
|
define('SPHINX_HOST', $config->profil->sphinx->ent->host);
|
|
|
|
define('SPHINX_PORT', intval($config->profil->sphinx->ent->port));
|
|
|
|
|
2013-11-05 12:18:30 +01:00
|
|
|
return $config;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Initialisation global des paramètres de vue
|
2016-11-29 15:10:11 +01:00
|
|
|
protected function _initViewSettings()
|
|
|
|
{
|
|
|
|
$this->bootstrap('view');
|
|
|
|
|
|
|
|
$view = $this->getResource('view');
|
|
|
|
$view->setEncoding('UTF-8');
|
|
|
|
$view->doctype('HTML5');
|
|
|
|
|
|
|
|
$view->headMeta()
|
|
|
|
->appendName('viewport', 'width=device-width, initial-scale=1.0')
|
|
|
|
->appendHttpEquiv('X-UA-Compatible', 'IE=edge')
|
|
|
|
->appendHttpEquiv('Content-Type', 'text/html; charset=UTF-8')
|
2013-11-05 12:18:30 +01:00
|
|
|
->appendHttpEquiv('Content-Language', 'fr-FR');
|
2013-11-05 14:13:59 +01:00
|
|
|
|
2016-11-29 15:10:11 +01:00
|
|
|
//Favicon - Touch icon for iOS 2.0+ and Android 2.1+
|
|
|
|
$view->headLink()->headLink(array(
|
|
|
|
'rel' => 'apple-touch-icon-precomposed',
|
|
|
|
'href' => '/favicon-152.png'
|
|
|
|
));
|
|
|
|
//Favicon - targeted to any additional png size
|
|
|
|
$view->headLink()->headLink(array(
|
|
|
|
'rel' => 'icon',
|
|
|
|
'type' => 'image/png',
|
|
|
|
'href' => '/favicon-32.png'
|
|
|
|
));
|
|
|
|
$view->headLink()->headLink(array(
|
|
|
|
'rel' => 'shortcut icon',
|
|
|
|
'type' => 'image/x-icon',
|
|
|
|
'href' => '/favicon.ico')
|
|
|
|
);
|
|
|
|
|
|
|
|
$view->headLink()
|
|
|
|
->appendStylesheet('/assets/libs/bootstrap-3.3.7/css/bootstrap.min.css', 'all')
|
|
|
|
->appendStylesheet('/assets/themes/default/css/docs.css', 'all')
|
|
|
|
->appendStylesheet('/assets/themes/default/css/main.css', 'all');
|
|
|
|
|
|
|
|
$view->headScript()
|
|
|
|
->appendFile('/assets/libs/html5shiv.min.js', 'text/javascript', array('conditional' => 'lt IE 9'))
|
|
|
|
->appendFile('/assets/libs/respond.min.js', 'text/javascript', array('conditional' => 'lt IE 9'))
|
|
|
|
->appendFile('/assets/libs/jquery-1.12.4.min.js', 'text/javascript')
|
|
|
|
->appendFile('/assets/libs/bootstrap-3.3.7/js/bootstrap.min.js', 'text/javascript');
|
|
|
|
|
|
|
|
$view->headTitle()->setSeparator(' - ');
|
|
|
|
$view->headTitle('Web Service API - Scores & Decisions');
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function _initRouter()
|
|
|
|
{
|
|
|
|
$this->bootstrap('frontController');
|
|
|
|
$front = $this->getResource('frontController');
|
|
|
|
$router = $front->getRouter();
|
|
|
|
|
|
|
|
// Lire les services disponibles et créer les routes
|
|
|
|
$services = require_once APPLICATION_PATH . '/../library/WsScore/ServicesConfig.php';
|
|
|
|
foreach ($services as $section => $params) {
|
|
|
|
if ($params['actif']) {
|
|
|
|
$route = new Zend_Controller_Router_Route($section.'/:version', array(
|
2017-01-31 15:41:43 +01:00
|
|
|
'controller' => 'service',
|
|
|
|
'action' => 'index',
|
|
|
|
'service' => $section,
|
|
|
|
'version' => '',
|
2016-11-29 15:10:11 +01:00
|
|
|
));
|
|
|
|
$router->addRoute($section, $route);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Route pour WS Clients
|
|
|
|
$route = new Zend_Controller_Router_Route('clients/:client/:version', array(
|
2017-01-31 15:41:43 +01:00
|
|
|
'controller' => 'service',
|
|
|
|
'action' => 'index',
|
|
|
|
'service' => 'clients',
|
|
|
|
'client' => '',
|
|
|
|
'version' => ''
|
2016-11-29 15:10:11 +01:00
|
|
|
));
|
|
|
|
$router->addRoute('client', $route);
|
|
|
|
|
|
|
|
$fichierRoute = new Zend_Controller_Router_Route('fichier/:action/:fichier', array(
|
2017-01-31 15:41:43 +01:00
|
|
|
'controller' => 'fichier',
|
|
|
|
'fichier' => '',
|
2016-11-29 15:10:11 +01:00
|
|
|
));
|
|
|
|
$router->addRoute('fichier', $fichierRoute);
|
|
|
|
return $router;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function _initDb()
|
|
|
|
{
|
|
|
|
$c = new Zend_Config($this->getOptions());
|
|
|
|
try {
|
|
|
|
$db = Zend_Db::factory($c->profil->db->metier);
|
|
|
|
} catch (Exception $e) {
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
echo '<pre>';
|
|
|
|
print_r($e);
|
|
|
|
echo '</pre>';
|
|
|
|
} else {
|
|
|
|
echo "Le service rencontre actuellement un problème technique.";
|
|
|
|
}
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the default adapter to use with all model
|
|
|
|
*/
|
|
|
|
Zend_Db_Table::setDefaultAdapter($db);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function _initDoctrine()
|
|
|
|
{
|
|
|
|
$c = new Zend_Config($this->getOptions());
|
|
|
|
|
|
|
|
$config = new \Doctrine\DBAL\Configuration();
|
|
|
|
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
$logger = new Scores_Logger_Sql();
|
|
|
|
$config->setSQLLogger($logger);
|
|
|
|
}
|
|
|
|
|
|
|
|
$connectionParams = array(
|
|
|
|
'dbname' => $c->profil->db->metier->params->dbname,
|
|
|
|
'user' => $c->profil->db->metier->params->username,
|
|
|
|
'password' => $c->profil->db->metier->params->password,
|
|
|
|
'host' => $c->profil->db->metier->params->host,
|
|
|
|
'charset' => 'utf8',
|
|
|
|
'driver' => 'pdo_mysql',
|
|
|
|
);
|
|
|
|
|
|
|
|
try {
|
2016-10-03 11:24:32 +02:00
|
|
|
$conn = \Doctrine\DBAL\DriverManager::getConnection($connectionParams, $config);
|
2016-11-29 15:10:11 +01:00
|
|
|
} catch (\Doctrine\DBAL\DBALException $e) {
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
echo '<pre>';
|
|
|
|
print_r($e);
|
|
|
|
echo '</pre>';
|
|
|
|
} else {
|
|
|
|
echo "Le service rencontre actuellement un problème technique.";
|
|
|
|
}
|
|
|
|
exit;
|
|
|
|
}
|
2016-08-30 09:57:42 +02:00
|
|
|
|
2016-09-30 14:46:21 +02:00
|
|
|
Zend_Registry::set('doctrine', $conn);
|
2016-11-29 15:10:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
protected function _initCache()
|
|
|
|
{
|
|
|
|
if (APPLICATION_ENV!='development') {
|
|
|
|
//MetadataCache pour la base de données
|
|
|
|
$frontendOptions = array(
|
|
|
|
'lifetime' => 14400,
|
|
|
|
'automatic_serialization' => true
|
|
|
|
);
|
|
|
|
$backendOptions = array();
|
|
|
|
$cache = Zend_Cache::factory('Core', 'Apc', $frontendOptions, $backendOptions);
|
|
|
|
Zend_Db_Table_Abstract::setDefaultMetadataCache($cache);
|
|
|
|
}
|
|
|
|
}
|
2017-01-31 15:41:43 +01:00
|
|
|
|
|
|
|
protected function _initLogger()
|
|
|
|
{
|
|
|
|
$config = new Zend_Config($this->getOptions());
|
|
|
|
$logFile = $config->profil->path->shared.'/log/application.log';
|
|
|
|
|
|
|
|
$log = new Logger('APP');
|
|
|
|
if (APPLICATION_ENV == 'development') {
|
|
|
|
$level = Logger::DEBUG;
|
|
|
|
} else {
|
2017-02-02 16:04:51 +01:00
|
|
|
$level = Logger::INFO;
|
2017-01-31 15:41:43 +01:00
|
|
|
}
|
|
|
|
$log->pushHandler(new StreamHandler($logFile), $level);
|
|
|
|
$log->pushProcessor(new IntrospectionProcessor());
|
|
|
|
|
|
|
|
Zend_Registry::set('logger', $log);
|
|
|
|
}
|
2016-11-29 15:10:11 +01:00
|
|
|
}
|