getRequest(); $this->siret = $request->getParam('siret'); $this->id = $request->getParam('id', 0); $this->entrep = new SessionEntreprise($this->siret, $this->id); } public function indexAction(){} /** * Commande de status association */ public function cmdassociationAction() { $user = new Utilisateur(); $request = $this->getRequest(); $email = $this->getParam('email', ''); if(!empty($email)) { $erreur = false; $config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/configuration.ini', 'path'); $fp=fopen(realpath($config->data).'/'.$config->log.'/commande_asso.csv', 'a'); fwrite($fp, date('Y/m/d H:i:s').";$siren;".$email.';'.$login.';'.$user->getEmail().';'.$user->getIpAddress()."\n"); fclose($fp); $siren = substr($this->siret, 0, 9); $infoAsso = new stdClass(); $infoAsso->siren = $siren; $infoAsso->waldec = ''; $infoAsso->idEntreprise = $this->id; $infoAsso->raisonSociale = $this->entrep->getRaisonSociale(); $infoDemande = new stdClass(); $infoDemande->reference = $request->getParam('ref'); $infoDemande->email = $email; $infoDemande->tel = $request->getParam('tel'); $infoDemande->fax = ''; $infoDemande->nom = ''; $infoDemande->service = ''; $infoDemande->societe = ''; $infoDemande->adresse = ''; $infoDemande->cp = ''; $infoDemande->ville = ''; $ws = new WsScores(); $reponse = $ws->setCmdAsso($infoAsso, $infosDemande); $annee = substr($reponse->result->dateCommande,0,4); $mois = substr($reponse->result->dateCommande,4,2); $jour = substr($reponse->result->dateCommande,6,2); $heure = substr($reponse->result->dateCommande,8,2); $minutes = substr($reponse->result->dateCommande,10,2); $ref = $reponse->result->refCmde; if( isset($ref) && !empty($ref) ) { $message = 'Votre demande à été prise en compte le '.$jour.'/'.$mois.'/'.$annee.' à '.$heure.' h '.$minutes.' sous la référence '.$ref.'.'; } else { $message = 'Une erreur s\'est produite lors du passage de votre commande.'; } } else { $message="ERREUR : Veuillez saisir une adresse email valide pour la commande de pièces."; } $this->view->assign('message', $message); $this->view->assign('siren', substr($this->siret, 0,9)); $this->view->assign('siret', $this->siret); $this->view->assign('id', $this->id); $this->view->assign('raisonSociale', $this->entrep->getRaisonSociale()); } /** * Affichage formulaire commande de status association */ public function assocationAction() { $user = new Utilisateur(); $this->view->assign('ModeEdition', $user->checkModeEdition()); $this->view->assign('email', $user->getEmail()); $this->view->assign('siren', substr($this->siret, 0,9)); $this->view->assign('siret', $this->siret); $this->view->assign('id', $this->id); $this->view->assign('raisonSociale', $this->entrep->getRaisonSociale()); } /** * Affichage liste d'actes infogreffe */ public function actesAction() { $this->view->headLink()->appendStylesheet('/themes/default/styles/pieces.css', 'all'); $this->view->headScript()->appendFile('/themes/default/scripts/pieces.js', 'text/javascript'); $user = new Utilisateur(); //Catégorie Juridique $cj = $this->entrep->getFormeJuridique(); if( in_array($cj, $this->association_cj) ) { $this->_forward('association'); } $request = $this->getRequest(); $siren = substr($this->siret,0,9); $vecteur = 'XL'; $ref = ''; //Affichage des actes disponible $infogreffe = new Infogreffe(); $reponse = $infogreffe->getGreffeActes($siren, $vecteur, $ref); //Gestion des erreurs dans la réponse /* * Construire la réponse pour affichage * Date, Type, Décisions, */ $infosActes = array(); if (count($reponse['result'])>0) { $items = $reponse['result']; //Traitement dernier statut à jour if(array_key_exists(0, $items)) { $acteS = $items[0]['actes'][0]; //Commande enregistré dans la bdd et fichier existe $lienCommande = ''; $checkFile = false; if( $user->checkModeEdition() ) { $lib = 'Voir le dernier ficher dans le système.'; $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('*') ->where('siren = ?', $siren) ->order('dateCommande DESC'); $rows = $commandes->fetchAll($rowset); } else { $lib = 'Télécharger votre dernière commande.'; $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('*') ->where('siren = ?', $siren) ->andWhere('login = ?', $user->getLogin()) ->order('dateCommande DESC'); $rows = $commandes->fetchAll($rowset); } $rows = $commandes->fetchAll($rowset); $nbCommandes = count($rows); if ($nbCommandes>0) { foreach($rows as $commande) { if(substr($commande->refDocument, 0, 3) == 'ST-') { $ref = trim($commande->refDocument); $config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/configuration.ini', 'path'); $refFile = realpath($config->data).'/'. $config->pdf.'/acte-'.$siren.'-'.trim($commande->refDocument).'.pdf'; $checkFile = true; break; } } } if( $checkFile && file_exists($refFile) ) { $lienCommande = '
'. ''.$lib.''; } //Génération du lien de commande suivant le mode de diffusion switch($acteS['mode']) { case 'C': if( $user->checkPerm('actes') ) { $title = 'Commander le document correspondant'; $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'statuts', 'mode' => 'C', 'siret' => $siren, 'ref' => $acteS['ref'], )); } else { $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; $href = '#'; } break; } $infosStatut['mode'] = $acteS['mode']; $infosStatut['lib'] = $acteS['type_lib']; $infosStatut['ref'] = $acteS['ref']; $infosStatut['href'] = $href; $infosStatut['title'] = $title; $infosStatut['decision'] = 'Le dernier statut à jour'; $infosActes[] = $infosStatut; //Suppression du dernier statut à jour unset($items[0]); } //Fin traitement dernier statut à jour //Traitement des actes normaux foreach($items as $key => $depot) { $infosActe = array(); //Parcours standard des actes pour affichage foreach($depot['actes'] as $num => $acte) { $infosActe['date'] = $acte['date_acte']; $infosActe['mode'] = $acte['mode']; $infosActe['lib'] = $acte['type_lib']; $infosActe['ref'] = $acte['ref']; $infos = array( 'num_acte' => $acte['num_acte'], 'date_acte' => $acte['date_acte'], 'type' => $acte['type'], 'type_lib' => $acte['type_lib'], 'decision' => $acte['decision'] ); switch($acte['mode']) { case 'fichier': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'acte', 'mode' => 'fichier', 'siret' => $siren, 'ref' => $acte['ref'], )); $title = 'Télécharger le document correspondant'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'T': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'acte', 'mode' => 'T', 'siret' => $siren, 'ref' => $acte['ref'], )); $title = 'Télécharger le document correspondant'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'C': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'acte', 'mode' => 'C', 'siret' => $siren, 'ref' => $acte['ref'], 'info' => urlencode(serialize($infos)) )); $title = 'Recevoir le document directement par mail (sous 3/5 jours ouvrés)'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'courrier': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'acte', 'mode' => 'courrier', 'siret' => $siren, 'ref' => $acte['ref'], 'info' => urlencode(serialize($infos)) )); $title = 'Recevoir le document directement par mail (sous 15 jours ouvrés)'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; } $infosActe['href'] = $href; $infosActe['title'] = $title; $infosActe['decision'] = ''; if($depot['num_depot']>=0) { $data = ''; if(!empty($acte['decision'])) { $data.= $acte['decision'].'
'; } $data.= 'Dépot n°'.$depot['num_depot'].' du '.$depot['date_depot']; if($acte['nbpages_acte']>1) { $data.= ', '.$acte['nbpages_acte'].' pages'; } elseif($acte['nbpages_acte']==1) { $data.= ', '.$acte['nbpages_acte'].' page'; } $infosActe['decision'] = $data; } $infosActes[] = $infosActe; } // Fin acte } // Fin depot } $this->view->assign('ModeEdition', $user->checkModeEdition()); $this->view->assign('InfosActes', $infosActes); $this->view->assign('siren', $siren); $this->view->assign('siret', $this->siret); $this->view->assign('raisonSociale', $this->entrep->getRaisonSociale()); } /** * Affichage liste de bilans infogreffe */ public function bilansAction() { $this->view->headLink()->appendStylesheet('/themes/default/styles/pieces.css', 'all'); $this->view->headScript()->appendFile('/themes/default/scripts/pieces.js', 'text/javascript'); //Catégorie Juridique $cj = $this->entrep->getFormeJuridique(); if( in_array($cj, $this->association_cj) ) { $this->_forward($action); } $user = new Utilisateur(); $request = $this->getRequest(); $siren = substr($this->siret,0,9); $vecteur = 'XL'; $ref = ''; //Affichage des bilans disponible $infogreffe = new Infogreffe(); $reponse = $infogreffe->getGreffeBilans($siren, $vecteur, $ref); //Gestion des erreurs dans la réponse $infosBilans = array(); if (count($reponse['result'])>0) { $items = $reponse['result']; foreach($items as $key => $item) { $infosBilan = array(); $infosBilan['date'] = $item['date_cloture']; $infosBilan['type'] = 'Comptes millésime '.$item['millesime']; $infosBilan['mode'] = $item['mode']; $infos = array( 'date_cloture' => $item['date_cloture'], 'type' => $item['millesime'], 'decision' => $item['num_depot'] ); switch($item['mode']) { case 'fichier'; if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'bilan', 'siret' => $siren, 'ref' => $item['ref'], 'mode' => 'fichier', 'info' => urlencode(serialize($infos)), )); $title = 'Télécharger le document correspondant'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'T': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'bilan', 'siret' => $siren, 'ref' => $item['ref'], 'mode' => 'T', )); $title = 'Télécharger le document correspondant'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'C': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'bilan', 'siret' => $siren, 'ref' => $item['ref'], 'mode' => 'C', 'info' => urlencode(serialize($infos)), )); $title = 'Recevoir le document directement par mail (sous 3/5 jours ouvrés)'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; case 'courrier': if ( $user->checkPerm('actes') ) { $href = $this->view->url(array( 'controller' => 'pieces', 'action' => 'bilan', 'siret' => $siren, 'ref' => $item['ref'], 'mode' => 'courrier', 'info' => urlencode(serialize($infos)), )); $title = 'Recevoir le document directement par mail (sous 15 jours ouvrés)'; } else { $href = '#'; $title = 'Vous n\'avez pas les droits nécessaires pour commander le document correspondant.'; } break; } $infosBilan['href'] = $href; $infosBilan['title'] = $title; $infosBilan['decision'] = 'Dépot n°'.$item['num_depot']; $infosBilans[] = $infosBilan; } } $this->view->assign('ModeEdition', $user->checkModeEdition()); $this->view->assign('InfosBilans', $infosBilans); $this->view->assign('siren', $siren); $this->view->assign('siret', $this->siret); $this->view->assign('raisonSociale', $this->entrep->getRaisonSociale()); } /** * Affichage formulaire de commande courrier S&D */ public function cmdcourrierAction() { //Désactivation affichage $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $request = $this->getRequest(); $dejaCommande = $request->getParam('dejaCommande', false); $noemail = $request->getParam('noemail', false); $sameLogin = $request->getParam('sameLogin', false); $typeCommande = $request->getParam('typeCommande', ''); $idCommande = $request->getParam('idCommande', ''); Zend_Registry::get('firebug')->info('cmdcourrier'); if(!$dejaCommande || ($dejaCommande && $noemail) ) { $user = new Utilisateur(); $siren = $request->getParam('siret', 0); $info = $request->getParam('info', 0); $ref = $request->getParam('ref', ''); $vue = $request->getParam('vue', ''); $this->view->assign('siren', $siren); $this->view->assign('info', $info); $this->view->assign('typeCommande', $typeCommande); $this->view->assign('idCommande', $idCommande); $this->view->assign('ref', $ref); $this->view->assign('vue', $vue); $this->view->assign('email', $user->getEmail()); $this->renderScript('pieces/cmdcourrier.phtml'); } elseif(!$noemail && $dejaCommande && $sameLogin) { $this->view->assign('typeCommande', $typeCommande); $this->view->assign('idCommande', $idCommande); $this->renderScript('pieces/cmdcourrier-cmd1.phtml'); } elseif(!$noemail && $dejaCommande && !$sameLogin) { $this->renderScript('pieces/cmdcourrier-cmd2.phtml'); } } /** * Enregistrement d'une commande de pièces par courrier */ public function sauvcmdAction() { $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $request = $this->getRequest(); $info = $request->getParam('info', ''); $email = $request->getParam('emailCommande', ''); $idCommande = $request->getParam('idCommande', ''); $type = $request->getParam('type', ''); $ref = $request->getParam('ref', ''); $siren = substr($this->siret,0,9); $info = !empty($info) ? unserialize(urldecode($_REQUEST['info'])) : $info = false; $lib = empty($info['decision']) ? '' : $info['decision']; if(!empty($email)){ $user = new Utilisateur(); $login = $user->getLogin(); $ip = $user->getIpAddress(); $config = Zend_Config_Ini(APPLICATION_PATH.'/configs/configuration.ini', 'path'); $fp = fopen($config->data.'/'.$config->log.'/commande_greffe.csv', 'a'); fwrite($fp,date('Y/m/d H:i:s').";$siren;".$ref.';'.$login.';'.$email.';'.$ip."\n"); fclose($fp); $tabCommande = array( 'idUser' => $user->getId(), 'emailCommande' => $email, 'login' => $login, 'siren' => $siren, 'refDocument' => $ref, 'libDocument' => $lib, 'typeCommande' => $type, 'dateCommande' => date('YmdHis') ); //Enregistrement dans la bdd des informations de la commande $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); $commande = new Application_Model_Commandes($db); $idCommande = $commande->insert($tabCommande); //Suppression fichier de vérouillage $lockFile = APPLICATION_PATH.'/../cache/'.$siren.'-'.$ref.'.txt'; if (file_exists($lockFile)) { unlink($lockFile); } if(INFOGREFFE_DEBUG) $idCommande = $idCommande.'_TEST'; if($type=='G') { $infogreffe = new Infogreffe(); //Commande switch($vue) { case 'actes': $reponse = $infogreffe->getGreffeActes($siren, 'C', $ref, $idCommande); break; case 'bilans': $reponse = $infogreffe->getGreffeBilans($siren, 'C', $ref, $idCommande); break; case 'statuts': $reponse = $infogreffe->getGreffeStatut($siren, 'C', $ref, $idCommande); break; } } if( isset($reponse) && !empty($reponse['error']) && $reponse['error']['errNum']!=17 ) { $message = $reponse['error']['errNum'].' - '.$reponse['error']['errMsg']; $ws->setLog('greffe_'.$vue, $siren, 0, 'Erreur '.$reponse['error']['errNum']); } else { $commande->update(array('statutCommande'=>0), 'idCommande = '.$idCommande); $message = 'Votre commande a été enregistré le '. date('d').'/'.date('m').'/'.date('Y'). ' à '.date('G').' h '.date('i'). ' sous la référence '.$type.$idCommande; //Envoi mail de commande courrier if($type=='C') { require_once 'Scores/Mail.php'; $mail = new Mail(); $mail->setFrom('contact'); $mail->addToKey('pieces'); $mail->setSubject('[COMMANDE PIECES] - '.'COMMANDE DE '.strtoupper($vue)); $mail->setBodyTexte( 'COMMANDE DE '.strtoupper($vue). ' en courrier manuel
'.EOL. 'Ref Scores et Décision : '.$ref.EOL. 'pour login '.$login.EOL ); $mail->send(); } $ws->setLog('greffe_'.$vue, $siren, 0, $ref.'/'.$type.$idCommande); } }else{ $message = 'Votre commande n\'a pas été prise en compte.'. 'Vous n\'avez pas saisie d\'adresse email'; } $this->view->assign('message', $message); $this->view->assign('siret', $this->siret); $this->view->assign('siren', $this->siren); $session = new SessionEntreprise($this->siret); $this->view->assign('raisonSociale', $session->getRaisonSociale()); } public function statutsAction(){} /** * Commande de bilan */ public function bilanAction() { $user = new Utilisateur(); if (!$user->checkPerm('ACTES')){ $this->_forward('perms', 'error'); } //Désactivation affichage $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $request = $this->getRequest(); $vecteur = $request->getParam('mode'); $info = $request->getParam('info'); $ref = $request->getParam('ref'); $siren = substr($this->siret,0,9); $ws = new WsScores(); switch($vecteur) { case 'C': $dejaCommande = false; $noemail = false; $sameLogin = false; $idCommande = 0; $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('idCommande, login, emailCommande, dateCommande') ->where("siren=$siren AND refDocument='$ref' AND statutCommande!=9"); $rows = $commandes->fetchAll($rowset); if (count($rows)!=0) { $dejaCommande = true; if ($rows[0]['login']==$user->getLogin()) { $dateCommande = WDate::dateT('Y-m-d','d/m/Y',$rows[0]['dateCommande']); $idCommande = $rows[0]['idCommande']; if(empty($rows[0]['emailCommande'])) $noemail = true; $sameLogin = true; } } $params = array( 'idCommande' => $idCommande, 'dejaCommande' => $dejaCommande, 'noemail' => $noemail, 'sameLogin' => $sameLogin, 'siren' => $siren, 'info' => $info, 'vue' => 'bilans', ); $this->_forward('cmdcourrier', 'pieces', null, $params); break; case 'courrier': $dejaCommande = false; $noemail = false; $sameLogin = false; $idCommande = 0; //Vérification des commandes if (preg_match('/^([0-9]{4})[_sociaux-|_-]/', $ref, $matches)) { $searchRef = '^'.$matches[1].'[_-|_sociaux-]'; } elseif (preg_match('/^([0-9]{4})_consolide-/', $ref, $matches)) { $searchRef = '^'.$matches[1].'_consolide-'; } else { $searchRef = $ref; } $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('idCommande, login, emailCommande, dateCommande') ->where("siren=$siren AND refDocument='$searchRef'"); $rows = $commandes->fetchAll($rowset); if (count($rows)!=0) { $dejaCommande = true; if ($rows[0]['login']==$user->getLogin()) { $dateCommande = WDate::dateT('Y-m-d','d/m/Y',$rows[0]['dateCommande']); $idCommande = $rows[0]['idCommande']; if(empty($rows[0]['emailCommande'])) $noemail = true; $sameLogin = true; } } $params = array( 'idCommande' => $idCommande, 'dejaCommande' => $dejaCommande, 'noemail' => $noemail, 'sameLogin' => $sameLogin, 'siren' => $siren, 'info' => $info, 'vue' => 'bilans', ); $this->_forward('cmdcourrier', 'pieces', null, $params); break; case 'fichier': $ws->setLog('greffe_bilans', $siren, 0, $ref); $info = unserialize($info); $config = new Zend_Config_Ini(APPLICATION_PATH . '/configs/configuration.ini', 'path'); $pathData = realpath($config->data); if(file_exists($pathData.'/pdf/bilan-'.$siren.'-'.$ref.'.pdf')){ $suffixe = 'bilan'; }elseif(file_exists($pathData.'/pdf/acte-'.$siren.'-'.$ref.'.pdf')){ $suffixe = 'acte'; } $href = '/fichier/pdf/'.$suffixe.'-'.$siren.'-'.$ref.'.pdf'; echo '
Ouvrir le bilan millésime '.$info['type'].''; break; break; case 'T': $infogreffe = new Infogreffe(); $reponse = $infogreffe->getGreffeBilans($siren, $vecteur, $ref); if(empty($reponse['error'])) { $items = $reponse['result']['bilan']; } else { $error = $reponse['error']['errNum'].' - '.$reponse['error']['errMsg']; } if ($error!='') { $ws->setLog('greffe_bilans', $siren, 0, 'Erreur '.$reponse['error']['errNum']); echo '
Erreur : '.$error; exit; } $info = unserialize(urldecode($info)); foreach($items as $item) { if($item['url_acces']!==false) { $ws->setLog('greffe_bilan', $siren, 0, $ref); $href = '/fichier/pdf/'.$item['url_acces']; echo '
Ouvrir le bilan millésime '.$item['millesime'].''; } else { $ws->setLog('greffe_bilans', $siren, 0, 'Erreur telechargement '.$ref); echo '
Impossible de télécharger le fichier auprès de notre partenaire.'; } } break; } } /** * Commande d'acte */ public function acteAction() { $user = new Utilisateur(); if (!$user->checkPerm('ACTES')){ $this->_forward('perms', 'error'); } //Désactivation affichage $this->_helper->layout()->disableLayout(); $this->_helper->viewRenderer->setNoRender(true); $request = $this->getRequest(); $vecteur = $request->getParam('mode'); $info = $request->getParam('info'); $ref = $request->getParam('ref'); $siren = substr($this->siret,0,9); $ws = new WsScores(); switch($vecteur) { case 'C': $dejaCommande = false; $noemail = false; $sameLogin = false; $idCommande = 0; $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('idCommande, login, emailCommande, dateCommande') ->where("siren=$siren AND refDocument='$ref' AND statutCommande!=9"); $rows = $commandes->fetchAll($rowset); if (count($rows)!=0) { $dejaCommande = true; if ($rows[0]['login']==$user->getLogin()) { $dateCommande = WDate::dateT('Y-m-d','d/m/Y',$rows[0]['dateCommande']); $idCommande = $rows[0]['idCommande']; if(empty($rows[0]['emailCommande'])) $noemail = true; $sameLogin = true; } } $params = array( 'idCommande' => $idCommande, 'dejaCommande' => $dejaCommande, 'noemail' => $noemail, 'sameLogin' => $sameLogin, 'siren' => $siren, 'info' => $info, 'vue' => 'actes', ); $this->_forward('cmdcourrier', 'pieces', null, $params); break; case 'courrier': $dejaCommande = false; $noemail = false; $sameLogin = false; $idCommande = 0; //Vérification des commandes if (preg_match('/^([0-9]{4})[_sociaux-|_-]/', $ref, $matches)) { $searchRef = '^'.$matches[1].'[_-|_sociaux-]'; } elseif (preg_match('/^([0-9]{4})_consolide-/', $ref, $matches)) { $searchRef = '^'.$matches[1].'_consolide-'; } else { $searchRef = $ref; } $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); Zend_Db_Table_Abstract::setDefaultAdapter($db); $commandes = new Application_Model_Commandes(); $rowset = $commandes->select('idCommande, login, emailCommande, dateCommande') ->where("siren=$siren AND refDocument='$searchRef'"); $rows = $commandes->fetchAll($rowset); if (count($rows)!=0) { $dejaCommande = true; if ($rows[0]['login']==$user->getLogin()) { $dateCommande = WDate::dateT('Y-m-d','d/m/Y',$rows[0]['dateCommande']); $idCommande = $rows[0]['idCommande']; if(empty($rows[0]['emailCommande'])) $noemail = true; $sameLogin = true; } } $params = array( 'idCommande' => $idCommande, 'dejaCommande' => $dejaCommande, 'noemail' => $noemail, 'sameLogin' => $sameLogin, 'siren' => $siren, 'info' => $info, 'vue' => 'actes', ); $this->_forward('cmdcourrier', 'pieces', null, $params); break; case 'fichier': $ws->setLog('greffe_actes', $siren, 0, $ref); $info = unserialize(urldecode($info)); $href = '/fichier/pdf/acte-'.$siren.'-'.$ref.'.pdf'; echo '
Ouvrir le fichier '.$info['type_lib'].' '; exit; break; case 'T': $infogreffe = new Infogreffe(); $reponse = $infogreffe->getGreffeActes($siren, $vecteur, $ref); if (empty($reponse['error'])) { $items = $reponse['result']['actes']; } else { $error = $reponse['error']['errNum'].' - '.$reponse['error']['errMsg']; } if ($error!='') { $ws->setLog('greffe_acte', $siren, 0, 'Erreur '.$reponse['error']['errNum']); echo '
Erreur : '.$error; exit; } foreach($items as $item) { if($item['num_acte']==$info['num_acte']) { if($item['url_acces']!==false) { $ws->setLog('greffe_actes', $siren, 0, $ref); $href = '/fichier/pdf/'.$item['url_acces']; echo '
Ouvrir le fichier '.$item['type_acte_libelle'].' '; exit; } else { $ws->setLog('greffe_actes', $siren, 0, 'Erreur telechargement '.$ref); echo '
Impossible de télécharger le fichier '.$item['type_acte_libelle'].' auprès de notre partenaire.'; exit; } } } break; } } /** * Commande de pièces, kbis, privileges, nantissements */ public function commandeAction() { $request = $this->getRequest(); $this->view->headLink()->appendStylesheet('/themes/default/styles/pieces.css', 'all'); $this->view->headScript()->appendFile('/themes/default/scripts/pieces.js', 'text/javascript'); $siren = substr($this->siret, 0, 9); $session = new SessionEntreprise($this->siret, $this->id); $user = new Utilisateur(); $permKbis = false; $kbisErrCJ = false; $kbisErrDEP = false; if ($user->checkPerm('kbis')) { $permKbis = true; //Vérification que le kbis est disponible //=> FormeJuridique if (($session->getFormeJuridique()>=91 && $session->getFormeJuridique()<=93) || ($session->getFormeJuridique()>=9110 && $session->getFormeJuridique()<=9300) ) { $kbisErrCJ = true; } //=> Département $dep = substr($session->getCodeCommune(),0,2); if ( in_array($dep, array('00','57','67','68','97','98')) ) { $kbisErrDEP = true; } } $permPriv = false; if ($user->checkPerm('privileges')){ $permPriv = true; } $permSurvPriv = false; if ($user->checkPerm('survpriv')){ $permSurvPriv = true; } $message = ''; //Validation du formulaire if ($request->isPost() && $request->getParam('op')=='kbis') { $ref = $request->getParam('ref'); $method = $request->getParam('method'); switch($method) { case 'M': $email = $request->getParam('emailKbisM', ''); //Vérification des champs if (!empty($email)) { //Envoi du mail require_once 'Scores/Mail.php'; $mail = new Mail(); $mail->setFrom('contact'); $mail->addToKey('pieces'); $mail->setSubject('[COMMANDE PIECES] - KBIS par email'); $mail->setBodyTexte( 'COMMANDE DE PIECES - Demande de kbis par email
'.EOL. 'Demande pour recevoir le KBIS de SIREN :'. ''. $this->siret.'
'.EOL. 'pour login '.$user->getLogin().'('.$email.')
'.EOL. 'Référence : '.$ref ); //Enregistrement dans la bdd $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); $commandesKbis = new Application_Model_CommandesKbis($db); $data = array( 'idUser' => $user->getId(), 'login' => $user->getLogin(), 'email' => $email, 'societe' => '', 'nom' => '', 'adresse' => '', 'cp' => '', 'ville' => '', 'siren' => substr($this->siret,0,9), 'raisonSociale' => $this->entrep->getRaisonSociale(), 'type' => 'M', 'dateCommande' => date('Y-m-d H:i:s'), ); $commandesKbis->insert($data); $message = 'Votre demande de reception de Kbis par email a été prise en compte'; $ws = new WsScores(); $ws->setLog('kbis', $this->siret, 0, 'mail'); } else { $message = 'Erreur : adresse email non renseignée.'; $this->view->assign('ref', $ref); $this->view->assign('method', $method); $this->view->assign('emailKbisM', $email); } break; case 'C': $email = $ref = $request->getParam('emailKbisC', ''); //Vérification des champs $fields = array('societe', 'nom', 'prenom', 'adresse', 'cp', 'ville'); $params = $request->getParams(); $error = false; foreach($fields as $field) { if(empty($params[$field])) $error = true; } if(!$error) { //Envoi du mail require_once 'Scores/Mail.php'; $mail = new Mail(); $mail->setFrom('contact'); $mail->addToKey('pieces'); $mail->setSubject('[COMMANDE PIECES] - KBIS par courrier'); $mail->setBodyTexte( 'COMMANDE DE PIECES - Demande de kbis par courrier'.EOL. 'Demande pour recevoir le kbis de siren : '. ''. $this->siret.'
'.EOL. 'pour login '.$user->getLogin(). '('.$email.')'.'
'.EOL. 'Societe :'.$params['societe'].'
'.EOL. 'Nom : '.$params['nom'].'
'.EOL. 'Prenom : '.$params['prenom'].'
'.EOL. 'Adresse : '.$params['adresse'].'
'.EOL. 'CP : '.$params['cp'].'
'.EOL. 'Ville : '.$params['ville'] ); $mail->send(); //Enregistrement dans la bdd $dbConfig = new Zend_Config_Ini(APPLICATION_PATH.'/configs/databases.ini'); $db = Zend_Db::factory($dbConfig->db->sdv1); $commandesKbis = new Application_Model_CommandesKbis($db); $data = array( 'idUser' => $user->getId(), 'login' => $user->getLogin(), 'email' => $email, 'societe' => $params['societe'], 'nom' => $params['nom'].' '.$$params['prenom'], 'adresse' => $params['adresse'], 'cp' => $params['cp'], 'ville' => $params['ville'], 'siren' => substr($this->siret,0,9), 'raisonSociale' => $this->entrep->getRaisonSociale(), 'type' => 'C', 'dateCommande' => date('Y-m-d H:i:s'), ); $commandesKbis->insert($data); $message = 'Votre commande à été prise en compte, vous recevrez ce document sous 3/5 jours'; $ws = new WsScores(); $ws->setLog('kbis', $this->siret, 0, 'courrier'); } else { $message = 'Erreur : Tous les champs doivent être renseigner.'; $this->view->assign('emailKbisC', $email); $this->view->assign('method', $method); $this->view->assign('societe', $params['societe']); $this->view->assign('nom', $params['nom']); $this->view->assign('prenom', $params['prenom']); $this->view->assign('adresse', $params['adresse']); $this->view->assign('cp', $params['cp']); $this->view->assign('ville', $params['ville']); } break; } $this->view->assign('message', $message); } if ($request->isPost() && $request->getParam('op')=='privileges') { $ref = $request->getParam('ref'); $privileges = $request->getParam('privileges'); $email = $request->getParam('email', ''); if (!empty($email)) { if ( in_array('SprivSurv',$privileges) ) { $ws = new WsScores(); $ws->setSurveillance($this->siret, $email, $ref, 'privileges'); $privilegesLog = join('-', $privileges); } $key = array_search('SprivSurv', $privileges); if ($key!==FALSE) unset($privileges[$key]); if (count($privileges)>0) { $privilegesJ = join(', ', $privileges); $privilegesLog = join('-', $privileges); require_once 'Scores/Mail.php'; $mail = new Mail(); $mail->setFrom('contact'); $mail->addToKey('pieces'); $mail->setSubject('[COMMANDE PIECES] - PRIVILEGES par email'); $mail->setBodyTexte( 'COMMANDE DE PRIVILEGES - par email
'.EOL. 'Demande pour recevoir ('.$privilegesJ.') pour SIREN : '. ''. $this->siret.'
'.EOL. 'pour login '.$user->getLogin().'('.$email.')
'.EOL. 'Référence : '.$ref ); $mail->send(); } $message = 'Votre commande a bien été prise en compte, vous recevrez ces documents sur votre e-mail.'; $ws = new WsScores(); $ws->setLog('privileges', $this->siret, 0, 'mail:'.$privilegesLog); } else { $message = 'Erreur : adresse email non renseignée.'; $this->view->assign('ref', $ref); $this->view->assign('privileges', $privileges); $this->view->assign('email', $email); } $this->view->assign('message', $message); } $this->view->assign('KbisErreurCJ', $kbisErrCJ); $this->view->assign('KbisErreurDEP', $kbisErrDEP); $this->view->assign('permKbis', $permKbis); $this->view->assign('permKbis', $permKbis); $this->view->assign('permPriv', $permPriv); $this->view->assign('permSurvPriv', $permSurvPriv); $this->view->assign('user', $user); $this->view->assign('siren', $siren); $this->view->assign('siret', $this->siret); $this->view->assign('raisonSociale', $session->getRaisonSociale()); } /** * Gestion téléchargement des kbis */ public function kbisAction() { } /** * Téléchargement de kbis par la passerelle SD */ public function kbispasserelleAction() { } /** * Téléchargement de kbis par infogreffe */ public function kbisinfogreffeAction() { } /** * Affiche les privilèges en surveillance */ public function privilegesAction() { $request = $this->getRequest(); $type = $request->getParam('type', null); $siren = substr($this->siret, 0, 9); $detail = false; if (!empty($type)){ $detail = true; } $session = new SessionEntreprise($this->siret, $this->id); $ws = new WsScores(); if ($detail){ $infos = $ws->getPrivilegesDetail($siren, array($type)); } else { $infos = $ws->getPrivilegesCumul($siren); } Zend_Registry::get('firebug')->info($infos); $privileges = $infos->result->item; $this->view->assign('privileges', $privileges); $this->view->assign('siren', $siren); $this->view->assign('siret', $this->siret); $this->view->assign('raisonSociale', $session->getRaisonSociale()); } }