161 lines
4.5 KiB
PHP
161 lines
4.5 KiB
PHP
<?php
|
|
class IndexController extends Zend_Controller_Action
|
|
{
|
|
|
|
public function indexAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$idClient = $request->getParam('idClient', null);
|
|
$this->view->assign('idClient', $idClient);
|
|
|
|
//Liste des profils
|
|
$profilM = new Application_Model_Profil();
|
|
$sql = $profilM->select();
|
|
$this->view->assign('listProfil', $profilM->fetchAll($sql));
|
|
|
|
$commandesM = new Application_Model_Commandes();
|
|
|
|
//Liste des fichiers en attente de profil
|
|
$sql = $commandesM->select()->where('idProfil = ?', 0);
|
|
$this->view->assign('fileAttenteProfil', $commandesM->fetchAll($sql));
|
|
|
|
//Liste des enrichissements en cours
|
|
$sql = $commandesM->select()
|
|
->where('idProfil != ?', 0)
|
|
->where("dateStop = '0000-00-00 00:00:00'");
|
|
$this->view->assign('fileEnCours', $commandesM->fetchAll($sql));
|
|
|
|
//Liste des enrichissements terminé
|
|
$sql = $commandesM->select()
|
|
->where("dateStop != '0000-00-00 00:00:00'")
|
|
->where("error = ''")
|
|
->order('dateStart DESC');
|
|
|
|
if ( null != $idClient ) {
|
|
$sql->where('fichier LIKE "'.$idClient.'-%"');
|
|
} else {
|
|
$sql->limit(5);
|
|
}
|
|
|
|
$this->view->assign('fileFinish', $commandesM->fetchAll($sql));
|
|
|
|
//Récupérer les clients
|
|
$c = Zend_Registry::get('config');
|
|
$sqlmetier = Zend_Db::factory($c->profil->db->metier);
|
|
$sql = $sqlmetier->select()
|
|
->from('sdv1.clients', array('id', 'nom'))
|
|
->where("actif = 'Oui'");
|
|
$clients = $sqlmetier->fetchAll($sql, null, Zend_Db::FETCH_OBJ);
|
|
|
|
$this->view->assign('clients', $clients);
|
|
|
|
}
|
|
|
|
public function getinfoAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$this->_helper->viewRenderer->setNoRender(true);
|
|
|
|
$request = $this->getRequest();
|
|
$id = $request->getParam('id');
|
|
if (!empty($id)){
|
|
$commandesM = new Application_Model_Commandes();
|
|
$result = $commandesM->find($id);
|
|
$info = $result->current();
|
|
$output = array(
|
|
'nbLigneT' => $info->nbLigneT,
|
|
);
|
|
echo json_encode($output);
|
|
}
|
|
}
|
|
|
|
public function getfileAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$this->_helper->viewRenderer->setNoRender(true);
|
|
$request = $this->getRequest();
|
|
$file = $request->getParam('file', '');
|
|
$content_type = 'application/csv-tab-delimited-table';
|
|
$c = Zend_Registry::get('config');
|
|
$path = $c->profil->path->data . DIRECTORY_SEPARATOR . 'export' . DIRECTORY_SEPARATOR;
|
|
//Envoi du fichier sur la sortie standard
|
|
if ( file_exists($path.$file) ) {
|
|
header('Content-Transfer-Encoding: none');
|
|
header('Content-type: ' . $content_type.'');
|
|
header('Content-Length: ' . filesize($path.$file));
|
|
header('Content-MD5: ' . base64_encode(md5_file($path.$file)));
|
|
header('Content-Disposition: filename="' . basename($path.$file) . '"');
|
|
header('Cache-Control: private, max-age=0, must-revalidate');
|
|
header('Pragma: public');
|
|
ini_set('zlib.output_compression', '0');
|
|
echo file_get_contents($path.$file);
|
|
} else {
|
|
echo "Impossible de charger le fichier. ($path$file)";
|
|
}
|
|
}
|
|
|
|
public function delAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$idfile = $request->getParam('idfile');
|
|
$commandesM = new Application_Model_Commandes($db);
|
|
$commandesM->delete('id='.$idfile);
|
|
$this->redirect('/');
|
|
}
|
|
|
|
public function restartAction()
|
|
{
|
|
$request = $this->getRequest();
|
|
$id = $request->getParam('id');
|
|
$option = $request->getParam('option');
|
|
if (!empty($id)){
|
|
$commandesM = new Application_Model_Commandes();
|
|
if($option=='last'){
|
|
$data = array(
|
|
'error' => 'Demande de reprise',
|
|
'dateStop' => '0000-00-00 00:00:00',
|
|
'fichierOut' => '',
|
|
);
|
|
|
|
}
|
|
if($option=='zero'){
|
|
$data = array(
|
|
'nbLigneT' => 0,
|
|
'error' => '',
|
|
'dateStart' => '0000-00-00 00:00:00',
|
|
'fichierOut' => '',
|
|
);
|
|
}
|
|
if($option=='back'){
|
|
$data = array(
|
|
'nbLigneT' => 0,
|
|
'error' => '',
|
|
'dateStart' => '0000-00-00 00:00:00',
|
|
'fichierOut' => '',
|
|
'idProfil' => 0,
|
|
);
|
|
}
|
|
$commandesM->update($data, "id=$id");
|
|
}
|
|
$this->view->request=$request;
|
|
$this->redirect('/index');
|
|
}
|
|
|
|
public function repriseAction()
|
|
{
|
|
$this->_helper->layout()->disableLayout();
|
|
$this->_helper->viewRenderer->setNoRender(true);
|
|
$request = $this->getRequest();
|
|
$id = $request->getParam('id');
|
|
if (!empty($id)){
|
|
$commandesM = new Application_Model_Commandes();
|
|
$data = array(
|
|
'error' => '',
|
|
);
|
|
$commandesM->update($data, "id=$id");
|
|
}
|
|
exec("php ".APPLICATION_PATH."/../batch/enrichissement.php --reprise --id ".$id." &");
|
|
$this->redirect('/index');
|
|
}
|
|
|
|
} |