Definition architecture

This commit is contained in:
Michael RICOIS 2015-09-29 16:59:45 +00:00
parent bdce1b423e
commit b35b5c7329
27 changed files with 593 additions and 106 deletions

View File

@ -1,4 +1,29 @@
<?php <?php
return array( return array(
array(
'label'=> "Prestations",
'title' => "",
'controller' => 'index',
'action' => 'index',
'pages' => array(
array(
'label' => "Résumé",
'title' => 'Listes de vos prestations',
'controller' => 'presta',
'action' => 'index',
),
array(
'label' => "Fichiers",
'title' => 'Listes de vos fichiers',
'controller' => 'presta',
'action' => 'files',
),
),
),
array(
'label'=> "Contact",
'title' => "Contact",
'controller' => 'contact',
'action' => 'index',
),
); );

View File

@ -0,0 +1,8 @@
<?php
class FileController extends Zend_Controller_Action
{
public function init(){}
public function indexAction(){}
}

View File

@ -4,7 +4,7 @@ class IndexController extends Zend_Controller_Action
public function indexAction() public function indexAction()
{ {
// --- Liste des prestations
} }

View File

@ -0,0 +1,8 @@
<?php
class PrestaController extends Zend_Controller_Action
{
public function init(){}
public function indexAction(){}
}

View File

@ -7,17 +7,15 @@
<span class="icon-bar"></span> <span class="icon-bar"></span>
<span class="icon-bar"></span> <span class="icon-bar"></span>
</button> </button>
<a class="navbar-brand" href="<?=$this->url(array('controller'=>'index', 'action'=>'index'), null, true)?>">Backoffice</a> <a class="navbar-brand" href="<?=$this->url(array('controller'=>'index', 'action'=>'index'), null, true)?>">WebFiler</a>
</div> </div>
<div class="collapse navbar-collapse"> <div class="collapse navbar-collapse">
<ul class="nav navbar-nav"> <ul class="nav navbar-nav">
<?php foreach ($this->navigation()->getContainer() as $page) {?> <?php foreach ($this->navigation()->getContainer() as $page) {?>
<li class="dropdown<?php if ( $page->isActive(true) ) { echo ' active'; } ?>"> <li class="dropdown<?php if ( $page->isActive(true) ) { echo ' active'; } ?>">
<?php if ( $page->hasPages() ) {?>
<a href="#" class="dropdown-toggle" data-toggle="dropdown"><?=$page->label?> <b class="caret"></b></a> <a href="#" class="dropdown-toggle" data-toggle="dropdown"><?=$page->label?> <b class="caret"></b></a>
<ul class="dropdown-menu"> <ul class="dropdown-menu">
<li><a href="<?=$page->getHref()?>">Accueil</a></li>
<li class="divider"></li>
<?php if ( $page->hasPages() ) {?>
<?php foreach ( $page->getPages() as $child ) {?> <?php foreach ( $page->getPages() as $child ) {?>
<?php if ( $child->getHref() == '#') {?> <?php if ( $child->getHref() == '#') {?>
<li class="divider"></li> <li class="divider"></li>
@ -25,6 +23,8 @@
<li <?php if ( $child->isActive(true) ) { echo "class='active'"; } ?>><a href="<?=$child->getHref()?>"><?=$child->label?></a></li> <li <?php if ( $child->isActive(true) ) { echo "class='active'"; } ?>><a href="<?=$child->getHref()?>"><?=$child->label?></a></li>
<?php }?> <?php }?>
<?php }?> <?php }?>
<?php } else {?>
<a href="#"><?=$page->label?></a>
<?php }?> <?php }?>
</ul> </ul>
</li> </li>

View File

@ -0,0 +1,14 @@
<?php
class Zend_View_Helper_FileSize extends Zend_View_Helper_Abstract
{
public function fileSize($size)
{
$units = array('KB', 'MB', 'GB', 'TB', 'PB');
$currUnit = '';
while (count($units) > 0 && $size > 1024) {
$currUnit = array_shift($units);
$size /= 1024;
}
return ($size | 0) . ' ' . $currUnit;
}
}

View File

@ -0,0 +1,17 @@
<?php
class Zend_View_Helper_ProfileLink extends Zend_View_Helper_Abstract
{
public function profileLink()
{
$auth = Zend_Auth::getInstance();
if ($auth->hasIdentity()) {
$username = $auth->getIdentity()->username;
$logoutUrl = $this->view->url(array(
'controller' => 'user',
'action' => 'logout'
), null, true);
return '<a href="'.$logoutUrl.'" title="Se déconnecter" class="navbar-link">Déconnexion : ' . $username . '</a>';
}
}
}

View File

@ -1 +1,6 @@
<?php <div class="container-fluid">
<h3>Liste des prestations</h3>
</div>

View File

@ -13,7 +13,7 @@
<div class="container"> <div class="container">
<form class="form-signin" method="<?=$this->form->getMethod()?>" action="<?=$this->form->getAction()?>"> <form class="form-signin" method="<?=$this->form->getMethod()?>" action="<?=$this->form->getAction()?>">
<h2 class="form-signin-heading">Backoffice</h2> <h2 class="form-signin-heading">WebFiler</h2>
<input name="login" value="<?=$this->form->getValue('login')?>" type="text" class="form-control" placeholder="Identifiant" autofocus> <input name="login" value="<?=$this->form->getValue('login')?>" type="text" class="form-control" placeholder="Identifiant" autofocus>
<input name="pass" value="<?=$this->form->getValue('pass')?>" type="password" class="form-control" placeholder="Mot de passe"> <input name="pass" value="<?=$this->form->getValue('pass')?>" type="password" class="form-control" placeholder="Mot de passe">
<button class="btn btn-lg btn-primary btn-block" type="submit">Connexion</button> <button class="btn btn-lg btn-primary btn-block" type="submit">Connexion</button>

View File

@ -9,7 +9,7 @@
"classmap": [ "classmap": [
"application/", "application/",
"library/Application/", "library/Application/",
"library/Scores/", "library/Scores/"
] ]
}, },
"authors": [ "authors": [

66
composer.lock generated Normal file
View File

@ -0,0 +1,66 @@
{
"_readme": [
"This file locks the dependencies of your project to a known state",
"Read more about it at https://getcomposer.org/doc/01-basic-usage.md#composer-lock-the-lock-file",
"This file is @generated automatically"
],
"hash": "21cd92d8299580fb00abd42b96cd39d8",
"content-hash": "29c45f207db6f7e602df7361e5d3b32e",
"packages": [
{
"name": "zendframework/zendframework1",
"version": "1.12.16",
"source": {
"type": "git",
"url": "https://github.com/zendframework/zf1.git",
"reference": "8a3c471ef0a337d303cd5ae578e64c2ba1d2c025"
},
"dist": {
"type": "zip",
"url": "https://api.github.com/repos/zendframework/zf1/zipball/8a3c471ef0a337d303cd5ae578e64c2ba1d2c025",
"reference": "8a3c471ef0a337d303cd5ae578e64c2ba1d2c025",
"shasum": ""
},
"require": {
"php": ">=5.2.11"
},
"require-dev": {
"phpunit/dbunit": "1.3.*",
"phpunit/phpunit": "3.7.*"
},
"type": "library",
"extra": {
"branch-alias": {
"dev-master": "1.12.x-dev"
}
},
"autoload": {
"psr-0": {
"Zend_": "library/"
}
},
"notification-url": "https://packagist.org/downloads/",
"include-path": [
"library/"
],
"license": [
"BSD-3-Clause"
],
"description": "Zend Framework 1",
"homepage": "http://framework.zend.com/",
"keywords": [
"ZF1",
"framework"
],
"time": "2015-09-15 15:49:51"
}
],
"packages-dev": [],
"aliases": [],
"minimum-stability": "stable",
"stability-flags": [],
"prefer-stable": false,
"prefer-lowest": false,
"platform": [],
"platform-dev": []
}

View File

@ -18,81 +18,28 @@ class Application_Controller_Plugin_Auth extends Zend_Controller_Plugin_Abstract
$checkAuth = false; $checkAuth = false;
} }
// --- Pas d'authentification sur ces services
if ( in_array($controller, array('service', 'import'))
|| ( $controller == 'fichier' && $action == 'logs' )
|| ( $controller == 'fichier' && $action == 'kbis' )
|| ( $controller == 'fichier' && $action == 'csv' )
|| ( $controller == 'fichier' && $action == 'associations' )
|| ( $controller == 'fichier' && $action == 'greffes' )
|| ( $controller == 'fichier' && $action == 'crm' )) {
$checkAuth = false;
}
$checkWs = true;
if ( $controller == 'fichier' ) {
$checkWs = false;
}
if ($checkAuth) { if ($checkAuth) {
$login = $request->getParam('login');
$pass = $request->getParam('pass', '');
$hach = $request->getParam('hach');
if (!empty($hach)) {
$pass = $hach;
}
$auth = Zend_Auth::getInstance(); $auth = Zend_Auth::getInstance();
// --- On vérifie le tout lors d'une connexion par url // --- Pas authentifié
if ( !empty($login) && !empty($pass) ) { if ( !$auth->hasIdentity() || time() > $auth->getIdentity()->time ) {
$authAdapter = new Scores_Auth_Adapter_Db($login, $pass, $checkWs); $layout = Zend_Layout::getMVCInstance();
$result = $auth->authenticate($authAdapter); if (!$layout->isEnabled()){
echo "Identification incorrect ou périmé.";
} else {
$this->_response->setRedirect('/user/login')->sendResponse();
}
if ($result->isValid()) { // --- Authentifié => on met à jour la session
$storage = new Zend_Auth_Storage_Session();
$session = new Zend_Session_Namespace($storage->getNamespace());
//$session->setExpirationSeconds(86400);
$auth->setStorage($storage);
} else {
$layout = Zend_Layout::getMVCInstance();
if ( !$layout->isEnabled() ){
echo "Identification incorrect ou périmé.";
} else {
$request->setModuleName('default')
->setControllerName('user')
->setActionName('logout');
}
}
//Sinon on reste sur le standard
} else { } else {
//Pas authentifié $identity = $auth->getIdentity();
if ( !$auth->hasIdentity() || time() > $auth->getIdentity()->time ) { $identity->time = time() + $identity->timeout;
$auth->getStorage()->write($identity);
$layout = Zend_Layout::getMVCInstance();
if (!$layout->isEnabled()){
echo "Identification incorrect ou périmé.";
} else {
$this->_response->setRedirect('/user/login')->sendResponse();
}
//Authentifié => on met à jour la session
} else {
$identity = $auth->getIdentity();
$identity->time = time() + $identity->timeout;
$auth->getStorage()->write($identity);
}
} }
} }
} }
} }

View File

@ -0,0 +1,24 @@
<?php
class Application_Controller_Plugin_Menu extends Zend_Controller_Plugin_Abstract
{
/**
* Créer le menu en fonction des besoins et des paramètres en entrée
* @param Zend_Controller_Request_Abstract $request
*/
public function preDispatch(Zend_Controller_Request_Abstract $request)
{
$layout = Zend_Layout::getMVCInstance();
$controller = $request->getControllerName();
$action = $request->getActionName();
if ( $layout->isEnabled() && $controller!='user' )
{
$view = $layout->getView();
$config = include APPLICATION_PATH . '/configs/menu.config.php';
$container = new Zend_Navigation($config);
$view->navigation($container);
}
}
}

View File

@ -0,0 +1,6 @@
<?php
class Application_Model_Sdv1ClientsPresta extends Zend_Db_Table_Abstract
{
protected $_name = 'clients_presta';
protected $_schema = 'sdv1';
}

View File

@ -0,0 +1,13 @@
<?php
class Application_Model_Sdv1Utilisateurs extends Zend_Db_Table_Abstract
{
protected $_name = 'utilisateurs';
protected $_schema = 'sdv1';
protected $_referenceMap = array(
'Reporter' => array(
'columns' => 'idClient',
'refTableClass' => 'Sdv1Clients',
'refColumns' => 'id'
),
);
}

View File

@ -1 +1,5 @@
<?php <?php
class Application_Model_WebfilerPrestaDetail extends Zend_Db_Table_Abstract
{
}

View File

@ -1 +1,5 @@
<?php <?php
class Application_Model_WebfilerPrestaFiles extends Zend_Db_Table_Abstract
{
}

View File

@ -1 +1,5 @@
<?php <?php
class Application_Model_WebfilerPrestaLogin extends Zend_Db_Table_Abstract
{
}

View File

@ -1 +1,5 @@
<?php <?php
class Application_Model_WebfilerPrestaManuel extends Zend_Db_Table_Abstract
{
}

View File

@ -1 +1,5 @@
<?php <?php
class Application_Model_WebfilerUser extends Zend_Db_Table_Abstract
{
}

View File

@ -0,0 +1,72 @@
<?php
class Scores_Auth_Adapter_Webfiler implements Zend_Auth_Adapter_Interface
{
protected $_username;
protected $_password;
protected $_hash;
protected $_timeout = 3600;
/**
*
* @param string $username
* @param string $password
*/
public function __construct($username, $password)
{
$this->_username = $username;
$this->_password = $password;
}
/**
* Override the timeout
* @param integer $seconds
*/
public function setTimeout($seconds = null)
{
if ($seconds===null)
return;
$this->_timeout = $seconds;
}
/**
* (non-PHPdoc)
* @see Zend_Auth_Adapter_Interface::authenticate()
*/
public function authenticate()
{
$userM = new Application_Model_Sdv1Utilisateurs();
$sql = $userM->select()
->setIntegrityCheck(false)
->from(array('u'=>'user'), array('u.clientId', 'u.id', 'u.login', 'u.password'), 'webfiler')
->join(array('c'=>'clients'), 'u.clientId = c.id', array(), 'sdv1')
->where('u.login=?', $this->_username)
->where('u.deleted=?', 0)
->where('c.actif=?','Oui');
$result = $userM->fetchRow($sql);
$identity = new stdClass();
$identity->username = $this->_username;
if ( null === $result ) {
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_IDENTITY_NOT_FOUND, $identity);
} else {
if ( password_verify($this->_password, $result->password) ) {
$identity->hash = $result->password;
$identity->id = $result->id;
$identity->clientId = $result->clientId;
$timeout = (!empty($result->timeout)) ? $result->timeout : $this->_timeout;
$identity->timeout = $timeout;
$identity->time = time() + $timeout;
return new Zend_Auth_Result(Zend_Auth_Result::SUCCESS, $identity);
} else {
return new Zend_Auth_Result(Zend_Auth_Result::FAILURE_CREDENTIAL_INVALID, $identity);
}
}
}
}

View File

@ -1,31 +1,15 @@
<?php <?php
// Define path to application directory // --- Define path to application directory
defined('APPLICATION_PATH') defined('APPLICATION_PATH')
|| define('APPLICATION_PATH', realpath(dirname(__FILE__) . '/../application')); || define('APPLICATION_PATH', realpath(__DIR__ . '/../application'));
// Define application environment // --- Define application environment
defined('APPLICATION_ENV') defined('APPLICATION_ENV')
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production')); || define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
// Ensure library/ is on include_path // --- Composer autoload
set_include_path(implode(PATH_SEPARATOR, array( require_once realpath(__DIR__ . '/../vendor/autoload.php');
realpath(APPLICATION_PATH . '/../library'),
get_include_path(),
)));
if (APPLICATION_ENV != 'production'){ // --- Create application, bootstrap, and run
ini_set("soap.wsdl_cache_enabled", "0"); $application = new Zend_Application(APPLICATION_ENV, APPLICATION_PATH . '/configs/application.ini');
} $application->bootstrap()->run();
require_once '../config/config.php';
/** Zend_Application */
require_once 'Zend/Application.php';
// Create application, bootstrap, and run
$application = new Zend_Application(
APPLICATION_ENV,
APPLICATION_PATH . '/configs/application.ini'
);
$application->bootstrap()
->run();

View File

@ -0,0 +1,56 @@
/* Sticky footer styles
-------------------------------------------------- */
html,
body {
height: 100%;
/* The html and body elements cannot have any padding or margin. */
}
/* Wrapper for page content to push down footer */
#wrap {
min-height: 100%;
height: auto !important;
height: 100%;
/* Negative indent footer by its height */
margin: 0 auto -60px;
/* Pad bottom by footer height */
padding: 0 0 60px;
}
/* Set the fixed height of the footer here */
#footer {
height: 60px;
background-color: #f5f5f5;
}
/* Custom page CSS
-------------------------------------------------- */
/* Not required for template or sticky footer method. */
body { font-size:12px; }
.container .credit {
margin: 20px 0;
}
#footer > .container {
padding-left: 15px;
padding-right: 15px;
}
code {
font-size: 80%;
}
p.bg-classes {
padding:15px;
}
#wrap .h1, #wrap .h2, #wrap .h3, #wrap h1, #wrap h2, #wrap h3 {
margin-top: 10px;
}
#wrap .breadcrumb {
margin-bottom: 0px;
}

View File

@ -0,0 +1,73 @@
body {
background-color: #eee;
}
html,
body {
height: 100%;
/* The html and body elements cannot have any padding or margin. */
}
/* Wrapper for page content to push down footer */
#wrap {
min-height: 100%;
height: auto !important;
height: 100%;
/* Negative indent footer by its height */
margin: 0 auto -60px;
/* Pad bottom by footer height */
padding: 0 0 60px;
}
#wrap > .container {
padding: 60px 15px 0;
}
.container .credit {
margin: 20px 0;
}
/* Set the fixed height of the footer here */
#footer {
height: 60px;
background-color: #f5f5f5;
}
#footer > .container {
padding-left: 15px;
padding-right: 15px;
}
.form-signin {
max-width: 330px;
padding: 15px;
margin: 0 auto;
}
.form-signin .form-signin-heading,
.form-signin .checkbox {
margin-bottom: 10px;
}
.form-signin .checkbox {
font-weight: normal;
}
.form-signin .form-control {
position: relative;
font-size: 16px;
height: auto;
padding: 10px;
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
}
.form-signin .form-control:focus {
z-index: 2;
}
.form-signin input[type="text"] {
margin-bottom: -1px;
border-bottom-left-radius: 0;
border-bottom-right-radius: 0;
}
.form-signin input[type="password"] {
margin-bottom: 10px;
border-top-left-radius: 0;
border-top-right-radius: 0;
}

View File

@ -1 +0,0 @@
<?php

150
scripts/jobs/integrate.php Normal file
View File

@ -0,0 +1,150 @@
<?php
// --- Define path to application directory
defined('APPLICATION_PATH')
|| define('APPLICATION_PATH', realpath(__DIR__ . '/../../application'));
// --- Define application environment
defined('APPLICATION_ENV')
|| define('APPLICATION_ENV', (getenv('APPLICATION_ENV') ? getenv('APPLICATION_ENV') : 'production'));
// --- Composer autoload
require_once realpath(__DIR__ . '/../../vendor/autoload.php');
// --- Create application, bootstrap, and run
$application = new Zend_Application(APPLICATION_ENV, APPLICATION_PATH . '/configs/application.ini');
try {
$opts = new Zend_Console_Getopt(
//Options
array(
'help|?' => "Affiche l'aide.",
'cron' => "Use in crontab",
'user=s' => "Regen for user et toutes ses prestations",
'presta=s' => "Regen for a prestation",
)
);
$opts->parse();
} catch (Zend_Console_Getopt_Exception $e) {
echo $e->getUsageMessage();
exit;
}
//Usage
if(count($opts->getOptions())==0 || isset($opts->help))
{
echo "Integrate file in webfiler.";
echo "\n\n";
echo $opts->getUsageMessage();
echo "\n";
exit;
}
$c = new Zend_Config($application->getOptions());
$db = Zend_Db::factory($c->resources->db);
$prestaSql = $db->select()
->from(array('p'=>'clients_presta'), array(), 'sdv1')
->join(array('c'=>'clients'), 'c.id = p.clientId ', 'sdv1')
->where('p.actif = ?', 1)
->where('c.actif = ?', 'Oui');
$prestaList = $db->fetchAll($prestaSql, Zend_Db::FETCH_OBJ);
foreach ($prestaList as $p) {
echo date('Y-m-d H:i:s')." - Recherche des paramètres pour la prestation ".$p->code."\n";
$params = array();
$paramSql = $db->select()->from('prestadetail', array(), 'webfiler')->where('prestaCode = ?', $p->code);
$paramResult = $db->fetchAll($paramSql, Zend_Db::FETCH_OBJ);
if (count($paramsResult) > 0) {
foreach ($params as $item) {
$params[$item->name] = $item->value;
}
} else {
echo date('Y-m-d H:i:s')." - Aucun paramètre.\n";
continue;
}
// --- Traitement
if (count($params) > 0) {
switch ($params['type']) {
case 'db':
// --- Lecture de la base de données pour obtenir la liste des fichiers
$stmt = $db->query($sql);
$rows = $stmt->fetchAll(Zend_Db::FETCH_OBJ);
if (count($rows) > 0) {
foreach ($rows as $f) {
$directory = $f->directory;
if (substr($f->directory, -1) == '/') {
$directory = substr($f->directory, 0, strlen($f->directory)-1);
}
if (substr($directory, 0, 1) == '/') {
$filename = $directory.'/'.$f->file;
} else {
$filename = $c->profil->path->secure.'/'.$directory.'/'.$f->file;
}
if (file_exists($filename)) {
$fileDate = filectime($filename);
$fileSize = filesize($filename);
$fileMd5 = md5_file($filename);
$fileSha1 = sha1_file($filename);
// --- Enregistrer dans la base
}
}
}
break;
case 'file':
// --- Lecture du repertoire pour obtenir la liste des fichiers
$directory = $params['directory'];
if (substr($params['directory'], -1) == '/') {
$directory = substr($params['directory'], 0, strlen($params['directory'])-1);
}
if (substr($directory, 0, 1) != '/') {
$directory = $c->profil->path->secure.'/'.$directory;
}
if ($handle = opendir($directory)) {
while (false !== ($file = readdir($handle))) {
if ($file != "." && $file != "..") {
// --- Masque de fichier
if (array_key_exists('filemask', $params)) {
$pattern = '/'.$params['filemask'].'/';
if (!preg_match($pattern, $file)) {
continue;
}
}
$filename = $directory.'/'.$file;
$fileDate = filectime($filename);
// --- Calcul du nombre de jours
$dateNow = new Zend_Date();
$dateFile = new Zend_Date($fileDate, Zend_Date::TIMESTAMP);
$difference = $dateNow->sub($dateFile);
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::DAY);
$measure->convertTo(Zend_Measure_Time::DAY);
$nbJour = $measure->getValue(0);
if ($nbJour > $params['maxkeepday']) {
continue;
}
$fileSize = filesize($filename);
$fileMd5 = md5_file($filename);
$fileSha1 = sha1_file($filename);
// --- Enregistrer dans la base
}
}
closedir($handle);
}
break;
default:
echo date('Y-m-d H:i:s')." - Type inconnu.\n";
break;
}
}
}