view->headScript()->appendFile('/themes/default/scripts/enrichissement.js', 'text/javascript'); $this->view->headLink()->appendStylesheet('/themes/default/styles/enrichissement.css'); } /** * Enter description here ... */ public function indexAction(){} public function fileformAction() { $this->view->headScript()->appendFile('/themes/default/scripts/jquery.form.js', 'text/javascript'); $this->view->headScript()->appendFile('/themes/default/scripts/jqueryprogressbar.js', 'text/javascript'); $this->view->assign('filesize', ini_get('upload_max_filesize')); } public function fileuploadAction() { $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $config = Zend_Registrey::get('configuration'); $path = realpath($config->path->data).'/clients'; if(!file_exists($path)) mkdir($path); if ( isset($_FILES) && count($_FILES)==1 ){ $n = $_FILES['fichier']['name']; $s = $_FILES['fichier']['size']; $tmp_name = $_FILES['fichier']['tmp_name']; $name = $_REQUEST['ref']; $extValide = array('csv'); $extension = strrchr($n,'.'); $extension = substr($extension,1); //@todo : vérifier l'extension du fichier if (move_uploaded_file($tmp_name, $path.'/'.$name.'.'.$extension)){ echo "Uploadé !"; } else { echo "Erreur : ".$_FILES['fichier']['error']; } } } /** * Etat de progression de l'upload du fichier */ public function fileprogressAction() { $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $request = $this->getRequest(); $key = $request->getParam('key', ''); if ( !empty($key) ) { //$rep sera égal à false si la clef n'existe pas dans le cache apc $rep = apc_fetch('upload_'.$key); echo json_encode($rep); } } /** * Enregistrement de la commande pour l'ennrichissement */ public function commandeAction() { $this->_helper->layout()->disableLayout(); $request = $this->getRequest(); $idCriteres = $request->getParam('id', null); $idProfil = $request->getParam('profil', null); $comptage = new Table_Comptages(); $sql = $comptage->select()->where('idDefinition = ?', $idCriteres); $result = $comptage->fetchRow($sql); $idComptage = $result['idDefinition']; //Vérifier les profils du client if ( $idProfil===null ){ //Selection du profil du client $auth = Zend_Auth::getInstance(); $user = $auth->getIdentity(); $profilsM = new Table_EnrichissementProfils(); $sql = $profilsM->select() ->from($profilsM, array('id')) ->where('idClient=?', $user->idClient) ->where('login=?', $user->username) ->where('actif=?', 1); $profil = $profilsM->fetchRow($sql); $idProfil = $profil->id; } //Récupération des critères du ciblage $criteresM = new Table_Criteres(); $criteresRow = $criteresM->find($idCriteres); $criteres = $criteresRow->current(); $structure = json_decode($criteres->criteres, true); require_once 'Scores/Field.php'; $field = new Fields(); $values = $field->getValues($structure); //Récupération des SIRET require_once 'Scores/Ciblage.php'; $ciblage = new Ciblage($values, true); $infosExtraction = $ciblage->execute(true); //Attention calcul uniteInsee réelle //car si donnée insee alors toutes les lignes doivent être comptés en unité insee $data = array( 'idComptage' => $idComptage, 'reference' => $this->getRequest()->getParam('ref'), 'idCriteres' => $criteres->id, 'idProfil' => $idProfil, 'identifiants' => json_encode($infosExtraction), 'idProfil' => $idProfil, 'fichier' => '', 'nbLigneTotales' => count($infosExtraction), 'nbLigneTraites' => count($infosExtraction), 'uniteInsee' => $ciblage->calculRedevanceInsee(), 'error' => '', 'dateAdded' => date('YmdHis'), ); $identifiantsM = new Table_EnrichissementIdentifiants(); $idIdentifiant = $identifiantsM->insert($data); } /** * Demande de référence pour l'enrichissement */ public function referenceAction() { $this->_helper->layout()->disableLayout(); $request = $this->getRequest(); //Récupération du profil de l'utilisateur $auth = Zend_Auth::getInstance(); $user = $auth->getIdentity(); $profilsM = new Table_EnrichissementProfils(); $sql = $profilsM->select() ->from($profilsM, array('id', 'reference', 'tarifLigne', 'dataInsee')) ->where('idClient=?', $user->idClient) ->where('login=?', $user->username) ->where('actif=?', 1); $profil = $profilsM->fetchRow($sql); if ($profil!==null) { $this->view->assign('profil', true); $idCritere = $request->getParam('id', null); $comptagesM = new Table_Comptages(); $sql = $comptagesM->select() ->where('idDefinition = ?', $idCritere) ->order('dateAjout DESC') ->limit(1); $comptages = $comptagesM->fetchAll($sql); if ( $comptages->count()>0 ) { $item = $comptages[0]; //@todo : Si le ciblage n'est pas du jour, refaire le comptage par rapport aux critères de ciblage $this->view->assign('resultat', $item['resultat']); $this->view->assign('uniteInsee', $item['uniteInsee']); //Calcul du prix $redevanceInsee = 3.295/100; //Seuil de facturation 52 734 euros $prixInsee = $item['uniteInsee']*$redevanceInsee; $infoInsee = ''; if ($profil->dataInsee){ $prixInsee = $item['resultat']*$redevanceInsee; $infoInsee = "Votre profil inclus au moins une donnée Insee, la redevance sera applicable sur chaque ligne."; } $prix = $item['resultat'] * $profil->tarifLigne + $prixInsee; $this->view->assign('prix', $prix); $this->view->assign('prixInsee', $prixInsee); $this->view->assign('infoInsee', $infoInsee); $this->view->assign('id', $item['id']); } } } }