enrichissement/application/controllers/IndexController.php

161 lines
4.5 KiB
PHP
Raw Normal View History

2012-01-13 13:35:11 +00:00
<?php
class IndexController extends Zend_Controller_Action
{
2012-05-15 15:02:37 +00:00
2012-01-13 13:35:11 +00:00
public function indexAction()
{
2012-12-04 16:36:12 +00:00
$request = $this->getRequest();
$idClient = $request->getParam('idClient', null);
2012-12-04 16:40:37 +00:00
$this->view->assign('idClient', $idClient);
2012-12-04 16:36:12 +00:00
//Liste des profils
2012-01-17 11:44:02 +00:00
$profilM = new Application_Model_Profil();
$sql = $profilM->select();
2012-01-19 15:25:47 +00:00
$this->view->assign('listProfil', $profilM->fetchAll($sql));
2012-05-15 15:02:37 +00:00
2013-09-09 15:03:03 +00:00
$commandesM = new Application_Model_Commandes();
2012-05-15 15:02:37 +00:00
//Liste des fichiers en attente de profil
2012-01-15 17:43:37 +00:00
$sql = $commandesM->select()->where('idProfil = ?', 0);
2012-05-15 15:02:37 +00:00
$this->view->assign('fileAttenteProfil', $commandesM->fetchAll($sql));
2012-01-15 17:43:37 +00:00
//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));
2012-05-15 15:02:37 +00:00
2012-01-15 17:43:37 +00:00
//Liste des enrichissements terminé
$sql = $commandesM->select()
->where("dateStop != '0000-00-00 00:00:00'")
2012-12-04 16:36:12 +00:00
->where("error = ''")
->order('dateStart DESC');
if ( null != $idClient ) {
2012-12-05 13:59:34 +00:00
$sql->where('fichier LIKE "'.$idClient.'-%"');
2012-12-04 16:36:12 +00:00
} else {
$sql->limit(5);
}
2012-01-15 17:43:37 +00:00
$this->view->assign('fileFinish', $commandesM->fetchAll($sql));
2012-12-04 16:36:12 +00:00
//Récupérer les clients
2013-10-29 10:25:57 +00:00
$c = Zend_Registry::get('config');
2016-11-25 19:25:18 +01:00
$sqlmetier = Zend_Db::factory($c->profil->db->metier);
2012-12-04 16:36:12 +00:00
$sql = $sqlmetier->select()
->from('sdv1.clients', array('id', 'nom'))
->where("actif = 'Oui'");
2012-12-04 16:36:12 +00:00
$clients = $sqlmetier->fetchAll($sql, null, Zend_Db::FETCH_OBJ);
2012-12-04 16:36:12 +00:00
$this->view->assign('clients', $clients);
2012-01-15 17:43:37 +00:00
}
2012-05-15 15:02:37 +00:00
public function getinfoAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
2012-05-15 15:02:37 +00:00
$request = $this->getRequest();
$id = $request->getParam('id');
if (!empty($id)){
2012-01-30 15:18:55 +00:00
$commandesM = new Application_Model_Commandes();
2012-05-15 15:02:37 +00:00
$result = $commandesM->find($id);
2012-01-30 15:19:38 +00:00
$info = $result->current();
2012-01-30 15:18:55 +00:00
$output = array(
2012-01-30 16:07:16 +00:00
'nbLigneT' => $info->nbLigneT,
2012-05-15 15:02:37 +00:00
);
2012-01-30 15:18:55 +00:00
echo json_encode($output);
2012-05-15 15:02:37 +00:00
}
}
2012-05-15 15:02:37 +00:00
2012-01-30 15:44:30 +00:00
public function getfileAction()
{
2012-01-30 15:42:37 +00:00
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
$request = $this->getRequest();
2012-01-30 15:44:30 +00:00
$file = $request->getParam('file', '');
2012-02-20 11:46:39 +00:00
$content_type = 'application/csv-tab-delimited-table';
2013-05-13 13:33:19 +00:00
$c = Zend_Registry::get('config');
2013-05-13 13:45:28 +00:00
$path = $c->profil->path->data . DIRECTORY_SEPARATOR . 'export' . DIRECTORY_SEPARATOR;
2012-02-20 11:46:39 +00:00
//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 {
2013-05-13 13:45:28 +00:00
echo "Impossible de charger le fichier. ($path$file)";
2012-02-20 11:46:39 +00:00
}
2012-01-30 15:42:37 +00:00
}
2012-05-15 15:02:37 +00:00
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');
2017-04-05 14:47:50 +02:00
$option = $request->getParam('option');
if (!empty($id)){
$commandesM = new Application_Model_Commandes();
2017-04-05 14:47:50 +02:00
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',
2012-05-15 15:02:37 +00:00
'fichierOut' => '',
);
2017-04-05 14:47:50 +02:00
}
if($option=='back'){
$data = array(
'nbLigneT' => 0,
'error' => '',
'dateStart' => '0000-00-00 00:00:00',
'fichierOut' => '',
'idProfil' => 0,
);
}
$commandesM->update($data, "id=$id");
}
2017-04-04 17:26:03 +02:00
$this->view->request=$request;
2017-04-05 14:47:50 +02:00
$this->redirect('/index');
}
2012-05-15 15:02:37 +00:00
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");
}
2012-05-15 15:02:37 +00:00
exec("php ".APPLICATION_PATH."/../batch/enrichissement.php --reprise --id ".$id." &");
2017-04-05 14:47:50 +02:00
$this->redirect('/index');
}
2012-05-15 15:02:37 +00:00
2012-01-13 13:35:11 +00:00
}