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);
$ws = new WsScores();
$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()
{
//On bascule soit vers kbispasserelle ou vers kbis infogreffe
$this->_forward('kbispasserelle', 'pieces', null, $this->getRequest()->getParams());
}
/**
* Téléchargement de kbis par la passerelle SD
*/
public function kbispasserelleAction()
{
$request = $this->getRequest();
$params = $request->getParams();
require_once 'Scores/Utilisateur.php';
$user = new Utilisateur();
//Mail
if (isset($params['op']) && $params['op']=='mailkbis')
{
if(!empty($params['email']))
{
require_once 'Scores/Mail.php';
$mail = new Mail();
$mail->setFrom('contact');
$mail->addToKey('pieces');
$mail->setSubject('[COMMANDE PIECES] - KBIS par email après essai(s) de téléchargement');
$mail->setBodyTexte(
'COMMANDE DE PIECES - Demande de kbis par email après essai(s) de téléchargement
'.EOL.
'Demande pour recevoir le kbis de SIREN : '.
''.
$this->siret.'
'.EOL.
'pour login '.$user->getLogin().'('.$params['email'].')
'
);
$ws = new WsScores();
$ws->setLog('kbis', $this->siret, 0, 'mail');
$this->view->assign('message',"Votre demande de reception de Kbis par email à été prise en compte");
} else {
$this->view->assign('message',"Votre demande n'a pas été prise en compte vous n'avez pas saisi d'email.");
}
}
//Téléchargement
if (isset($params['start']))
{
$start = $params['start'];
$siren = $params['siret'];
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
//Commande auprès du webservice
if($start>0 && $start<3)
{
$url = $this->getKbis($siren);
if($url===FALSE)
{
require_once 'Scores/Mail.php';
$mail = new Mail();
$mail->setFrom('contact');
$mail->addToKey('supportdev');
$mail->setSubject('[COMMANDE KBIS] - Erreur');
$mail->setBodyTexte(
'Commande de kbis par le login '.$user->getLogin().' ('.$user->getEmail().')
'.EOL.
'pour le SIREN :'.''.$this->siret.'
'.EOL.
'pour login '.$user->getLogin().'('.$email.')
'.EOL.
'Référence : '.$ref
);
$href = $this->view->url(array(
'controller' => 'pieces',
'action' => 'kbis',
'siret' => $siren,
));
echo 'Une erreur est survenue. Merci de réssayez en cliquant ici';
} else {
echo $url;
}
}
//Après 2 essais, on tente de relancer la commande
elseif($start>=3)
{
$href = $this->view->url(array(
'controller' => 'pieces',
'action' => 'kbis',
'siret' => $siren,
));
echo 'Une erreur est survenue. Merci de réssayez en cliquant ici';
}
elseif($start==0)
{
$path = APPLICATION_PATH . '/../cache/kbis/';
if (!is_dir($path)) mkdir($path);
//Le fichier existe sur l'extranet, etc....
if (file_exists($path.'kbis-'.$siren.'.pdf')
&& date('Ymd', filemtime($path.'kbis-'.$siren.'.pdf'))==date('Ymd')
&& filesize($path.'kbis-'.$siren.'.pdf')>2000 )
{
echo 'Visualiser le Kbis ';
$ws = new WsScores();
$ws->setLog('kbis', $siren, 0, 'direct');
}
//Le fichier n'existe pas sur l'extranet, etc...
else
{
require_once 'common/curl.php';
//Suppression du fichier si il existe
if(file_exists($path.'kbis-'.$siren.'.pdf')) unlink($path.'kbis-'.$siren.'.pdf');
//On check si le fichier est présent sur l'url
$page = getUrl($params['url'], '', '', '', false);
//Fichier non disponible
if($page['code']==408 || $page['code']==400){
echo 'FALSE';
//Ecriture du fichier sur le serveur en local
}else{
$body = $page['body'];
$fp = fopen($path.'kbis-'.$siren.'.pdf', 'w');
fwrite($fp, $body);
fclose($fp);
echo 'FALSE';
}
}
}
}
else
{
$this->view->headLink()->appendStylesheet('/themes/default/styles/kbis.css', 'all');
$this->view->headScript()->appendFile('/themes/default/scripts/jqueryprogressbar.js', 'text/javascript');
$this->view->assign('start', 1);
$session = new SessionEntreprise($params['siret']);
$this->view->assign('raisonSociale', $session->getRaisonSociale());
$this->view->assign('siren', $params['siret']);
$this->view->assign('email', $user->getEmail());
$this->view->assign('login', $user->getLogin());
}
}
/**
* A supprimer
* @param unknown_type $siren
*/
function getKbis($siren){
require_once 'Scores/Utilisateur.php';
$user = new Utilisateur();
$client = new SoapClient(null, array(
'trace' => 1,
'soap_version' => SOAP_1_1,
'location' => 'http://78.31.45.206:8088/ws/',
'uri' => 'http://78.31.45.206:8088/',
'login' => $user->getLogin(),
'password' => $user->getPassword(),
));
//ini_set('default_socket_timeout', 120); //timeout 2 min
$return = FALSE;
try {
$O = $client->getKbis($siren,1,0);
$kbis = $O['result'];
$return = $kbis['Url'];
} catch (SoapFault $fault) {
Zend_Registry::get('firebug')->info($fault);
}
return $return;
}
/**
* 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());
}
}