log($_SESSION,'SESSION');
$idCommande=0; // Par défaut, l'identifiant de commande Infogreffe est à 0
$siret = $_REQUEST['siret'];
$siren = substr($siret,0,9);
$idan = $_REQUEST['idan'];
$idEntreprise = $_REQUEST['idEntreprise'];
$source = $_REQUEST['source'];
$action = $_REQUEST['action'];
if ($action!='' && $action!='commande') die('Paramètres incorrects !');
$vecteurCommande=$_REQUEST['vecteur'];
//
if ($vecteurCommande!='')
{
if ($vecteurCommande!='C' && $vecteurCommande!='T') die('Paramètres incorrects !');
//Par défault
} else {
$vecteurCommande='T';
}
$message='';
require_once 'common/dates.php';
require_once 'common/curl.php';
require_once 'infogreffe/infogreffe.php';
require_once 'user/user.php';
//Elements de session
$tabInfo = $_SESSION['tabInfo'];
$login = strtolower($tabInfo['login']);
$raisonSociale = $tabInfo['entrep']['raisonSociale'];
isset($_REQUEST['rs'])? $raisonSociale = $_REQUEST['rs'] : '';
$cj = $tabInfo['entrep']['fj'];
$dep = substr(''.$tabInfo['entrep']['codeCommune'],0,2);
//Raison sociale inexacte
if ($siren != $tabInfo['entrep']['siren'])
{
require_once 'scoresws/scoresws.php';
$etab = scoresws_identitelight($siret, $siren, $idEntreprise);
if(!empty($etab))
{
$tabEntrep = array();
$tabEntrep['raisonSociale'] = $etab['Nom'];
$tabEntrep['siren'] = $etab['Siren'];
$tabEntrep['siret'] = $etab['Siret'];
$tabEntrep['tva'] = $etab['TvaNumero'];
$tabEntrep['isin'] = $etab['Isin'];
$tabEntrep['AutreId'] = $etab['AutreId'];
$tabEntrep['active'] = $etab['Statut'];
$tabEntrep['Source'] = $etab['Source'];
$tabEntrep['SourceId'] = $etab['SourceId'];
$tabEntrep['codeCommune'] = $etab['Dept'].$etab['codeCommune'];
$tabEntrep['nafEn'] = $etab['NafEnt'];
$tabEntrep['nafEt'] = $etab['NafEtab'];
$tabEntrep['fj'] = $etab['FJ'];
$_SESSION['tabInfo']['entrep'] = $tabEntrep;
$raisonSociale = $etab['Nom'];
}
}
?>
true // &force=true force le passage chez infogreffe
)
{
if ($action=='commande')
{
if(!empty($_REQUEST['email']) /*&& mailCommande($_REQUEST['email'], $siren, 'asso')*/)
{
$erreur = false;
$fp=fopen(PATH_LOGS.'commande_asso.csv', 'a');
fwrite($fp, date('Y/m/d H:i:s').";$siren;".$_REQUEST['email'].';'.$tabInfo['login'].';'.$tabInfo['email'].';'.$tabInfo['ip']."\n");
fclose($fp);
$infoAsso = array(
'Siren' => $siren,
'idEntreprise' => $idEntreprise,
'RaisonSociale' => $raisonSociale,
);
$infoDemande = array(
'Ref' => $_REQUEST['reference'],
'Tel' => $_REQUEST['tel'],
'Email' => $_REQUEST['email'],
);
$firephp->log($infoDemande,'infoDemande');
$firephp->log($infoAsso,'infoAsso');
try {
$O = $client->commandeAsso($siren, $infoAsso, $infoDemande);
$annee = substr($O['results']['dateCommande'],0,4);
$mois = substr($O['results']['dateCommande'],4,2);
$jour = substr($O['results']['dateCommande'],6,2);
$heure = substr($O['results']['dateCommande'],8,2);
$minutes = substr($O['results']['dateCommande'],10,2);
$ref = $O['results']['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.' .';
}
$firephp->log($O,'O');
} catch (SoapFault $fault) {
require_once 'soaperror.php';
processSoapFault($client,$fault,$_SESSION['tabInfo']);
$erreur = true;
}
if($erreur)
{
$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.";
}
}
if ($message!='')
{
?>
PIÈCES OFFICIELLES
Numéro identifiant Siren
=substr($siren,0,3).' '.substr($siren,3,3).' '.substr($siren,6,3)?>
Raison Sociale
=$raisonSociale?>
Actes & Statuts
Il n'est pas possible de visualiser les statuts des associations en ligne.
}elseif (!preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
?>
Vous n'avez pas les droits nécessaires pour commander des status.
}
// Fin Specificités des associations
/*elseif ( $dep=='00' || $dep=='57' || $dep=='67' || $dep=='68' || $dep=='97' || $dep=='98' || $vue=='rcs' )
{ // Déb ALSACE DOM
include('inpi.php');
}*/
// Déb hors ALSACE DOM
else
{
$firephp->log($action, 'action');
$firephp->log($vecteurCommande, 'vecteurCommande');
$firephp->log($_REQUEST, 'REQUEST');
$vue = $_REQUEST['vue'];
$option = trim(''.@$_REQUEST['option']); /* Si acte ou statuts : type_acte-date-greffe-dossier_millesime-dossier_statut-dossier_chrono-num_depot-num_acte */
$noemail = false;
if ($action=='commande' && !empty($_REQUEST['email']))
{
if(mailCommande($_REQUEST['email'], $siren, 'greffe'))
{
$message='Commande prise en compte';
$fp=fopen(PATH_LOGS.'commande_greffe.csv', 'a');
fwrite($fp, date('Y/m/d H:i:s').";$siren;".$_REQUEST['email'].';'.$tabInfo['login'].';'.$tabInfo['email'].';'.$tabInfo['ip']."\n");
fclose($fp);
$tabCommande = array( 'emailCommande' => $_REQUEST['email'] ); //On rentre l'adresse email
$wdb = new WDB();
$wdb->update('commandes', $tabCommande, "login='$login' AND siren='$siren'");
}else{
$message="ERREUR : Veuillez saisir une adresse email valide pour la commande de pièces";
}
}
/** Si on est en commande de courrier, on génère une réf unique **/
if ($vecteurCommande=='C')
{
$wdb = new WDB();
$rep = $wdb->select('commandes',
' idCommande, login, emailCommande, dateCommande',
"siren=$siren AND refDocument='$option'");
if (count($rep)==0)
{
$dejaCommande = false;
/** Aucune commande ne concerne ce document **/
$tabCommande = array(
'idUser' => $_SESSION['tabInfo']['id'],
//'emailCommande' => $_REQUEST['email'],
'login' => $login,
'siren' => $siren,
'refDocument' => $option,
'libDocument' => $_REQUEST['lib'],
'dateCommande' => date('YmdHis')
);
$idCommande = $wdb->insert('commandes', $tabCommande);
//noemail = true : on sait que l'email n'a pas ete saisie
}
else
{
$dejaCommande = true;
/** Document en cours de commande **/
if ($rep[0]['login']==$login)
{
$message2 = 'Votre commande a déjà été prise en compte le '.WDate::dateT('Y-m-d', 'd/m/Y',$rep[0]['dateCommande']);
if(empty($rep[0]['emailCommande']))
{
$firephp->info('Email manquant');
$noemail = true;
}
}
}
} //Fin commande courrier
$output = @$_REQUEST['output'];
$vecteur = 'XL';
switch($vue)
{
case 'kbis': $type='KB'; break;
case 'histo': $type='HQ'; break; //"T"/>'.XL
case 'statuts': $type='ST'; $vecteur = $vecteurCommande; break;
case 'actes': $type='AC'; if ($option!='') $vecteur = $vecteurCommande; break;
case 'LE': $type='ListeEtab'; break;
case 'PN': $type='PrivNant'; break;
case 'BI': $type='BilanImg'; break;
//case 'bilans': $type='BS'; break;
case 'bilans': $type='BI'; if ($option!='') $vecteur = $vecteurCommande; break;
case 'FA': $type='PrezProcol'; break;
case 'FI': $type='Inventaire'; break;
case 'jugements': $type='FJ'; break;
case 'FO': $type='Ordonnance'; break;
case 'FD': $type='DepotDivers'; break;
case 'SD': $type='SurvDemande'; break;
case 'SR': $type='SurvRevel'; break;
case 'SP': $type='SurvPortef'; break;
case 'rcs': break;
default : if ($action!='commande') die('Type de pièce officielle inexistante'); break;
}
$req = requeteInfogreffe($siren, $idCommande, $type, $vecteur, $option);
$firephp->log($req, 'Requete Infogreffe');
$success = true;
/** Par défaut les documents avec des liens vers les actes ne sont pas périsables **/
$perisable = false;
if ($option=='')
{
$fichier="$type-$siren.xml";
$perisable=true; // La liste des documents est périsable !
}
else
{
$fichier="$type-$siren-$option.xml";
}
// Pas déjà commandé et pas commande
if ($action!='commande' && !$dejaCommande)
{
if (// Le fichier n'existe pas en cache
!file_exists( PATH_DATA.'/infogreffe/xml/' . $fichier ) ||
// Le fichier existe en cache mais est périsable (liste)
(file_exists( PATH_DATA.'/infogreffe/xml/' . $fichier ) && $perisable && date('Ymd', filemtime( PATH_DATA.'/infogreffe/xml/' . $fichier ))<>date('Ymd')) ||
// Le fichier existe en cache, n'est pas périsable (acte) mais contient un message d'erreur
(file_exists( PATH_DATA.'/infogreffe/xml/' . $fichier ) && !$perisable && date('Ymd', filemtime( PATH_DATA.'/infogreffe/xml/' . $fichier ))<>date('Ymd') && filesize( PATH_DATA.'/infogreffe/xml/' . $fichier )<=200)
)
{
//Gestion du nom de fichier
switch($type)
{
case 'BI':
$fichierPdf = PATH_DATA.'/pdf/bilan-'.$siren.'-'.$option.'.pdf';
$firephp->info('Execution requete Infogreffe');
$xml = getInfogreffeXML($req);
$firephp->log($xml, 'XML');
break;
case 'AC':
case 'ST':
$fichierPdf = PATH_DATA.'/pdf/acte-'.$siren.'-'.$option.'.pdf';
$firephp->log(file_exists($fichierPdf), 'Test présence fichier '.$fichierPdf);
if ( !file_exists($fichierPdf) )
{
$firephp->info('Execution requete Infogreffe');
$xml = getInfogreffeXML($req);
$firephp->log($xml, 'XML');
}
break;
}
/** Enregistrement du fichier XML en provenance des greffes **/
if (strlen($xml)!=0) {
$fp=@fopen( PATH_DATA.'/infogreffe/xml/' . $fichier , 'w');
@fwrite($fp, $xml);
@fclose($fp);
}
}
else
{
// Lecture du fichier xml en cache
$xml = file_get_contents( PATH_DATA.'/infogreffe/xml/' . $fichier );
}
}
else
{
$xml = '';
}
// Erreur infogreffe
if (strlen($xml)<200)
{
$firephp->info('Erreur Infogreffe');
$tmp = explode('-', $xml);
$errNum = $tmp[0]*1;
$errMsg = $xml;
if ($message!='' && !$dejaCommande)
{
?>
PIECES OFFICIELLES
Numéro identifiant Siren
=substr($siren,0,3).' '.substr($siren,3,3).' '.substr($siren,6,3)?>
Raison Sociale
=$raisonSociale?>
Actes & Statuts
=$tabErrInfoGref[$errNum]?>
}
elseif ($dejaCommande)
{
?>
=$message2?>
}
?>
Date
Type
Décisions
getValueFromTag('date_acte');
$tabOptions=explode('-', $option);
$acte=array();
if (!isset($typeActes['a'.$tabOptions[0]]))
{
mail('ylenaour@scores-decisions.com',
"Type d'acte inconnu pour $siren",
"acte-$siren-$option.pdf");
} else
$acte['type']=$typeActes['a'.$tabOptions[0]];
$acte['depot_num']=$tabOptions[6];
$dateAff=WDate::dateT('Ymd','d/m/Y', $tabOptions[1]);
?>
=$dateAff?>
=$acte['type']?>
=$acte['type']?>
=$acte['decisions']; if (trim($acte['decisions'])<>'') echo ' ';?>Dépôt numéro =$acte['depot_num']?>
setLog('greffe_'.$vue, $siret, 0, $option);
}
// Log de la page
$O2 = $client->setLog('greffe_'.$vue, $siret, 0, "Erreur $errNum");
}
//Fin d'affichage des erreurs infogreffe
else
{
// Liste des "actes" Infogreffes ou détail acte infogreffe
//if ($output=='pdf') $type=$type.'-pdf';
if ($type=='AC' && $option=='')
{
// Liste des actes Infogreffe
$return = xmlArrayActes(PATH_DATA.'/infogreffe/xml/'.$fichier);
$tabActes = $return['Actes'];
$vecteurTinit = $return['vecteurTinit'];
$nbVecteurT = $return['nbVecteurT'];
$nbActes = $return['nbActes'];
if (!$vecteurTinit) {
$origine='G';
//include('inpi.php');
}
if ($vecteurTinit)
{
// Il y a au moins un acte en téléchargement
?>
PIÉCES OFFICIELLES
Numéro identifiant Siren
=substr($siren,0,3).' '.substr($siren,3,3).' '.substr($siren,6,3)?>
Raison Sociale
=$raisonSociale?>
Actes & Statuts
Date
Type
Décisions
$acte)
{
if($acte['num_depot']<0)
{
$acte_statut_a_jour = $tabActes[$date];
array_splice($tabActes, $offset,1);
$tabActes['99999999'] = $acte_statut_a_jour;
break;
}
$offset++;
}
krsort($tabActes);
foreach ($tabActes as $date => $acte)
{
if($acte['num_depot']>0)
{
$date = WDate::dateT('Y-m-d','d/m/Y', substr($date,0,10));
$dateRef = WDate::dateT('d/m/Y','Ymd', substr($date,0,10));
$optionUrl = $acte['type_acte']."-$dateRef-".$acte['num_gest_greffe'].'-'.$acte['num_gest_millesime'].'-'.$acte['num_gest_statut'].'-'.$acte['num_gest_chrono'].'-'.$acte['num_depot'].'-'.$acte['num_acte'];
}
else
{
$date = '';
$dateRef = date('Y').date('m').date('d');
$optionUrl = 'ST-'.$dateRef.'-'.$acte['num_gest_greffe'].'-'.$acte['num_gest_millesime'].'-'.$acte['num_gest_statut'].'-'.$acte['num_gest_chrono'];
}
?>
=$date?>
=$acte['type']?>
';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
echo $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.'';
}else{
echo $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour visualiser le document correspondant.">'.$tagContent.'';
}
if(hasModeEdition() && $lienCmdFactice)
{
echo 'Créer une commande factice. ';
}
}
elseif ($acte['vecteurC'])
{
if ( file_exists(PATH_DATA.'/pdf/acte-'.$siren.'-'.$optionUrl.'.pdf')
&& filesize(PATH_DATA.'/pdf/acte-'.$siren.'-'.$optionUrl.'.pdf')!=0)
{
$tag = '. ';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
echo $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.'';
}else{
echo $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour visualiser le document correspondant.">'.$tagContent.'';
}
}
else
{
$tag = '0){
$href = './?page=greffes&vue=actes&siret='.$siret.'&option='.$optionUrl.'&lib='.urlencode($acte['decisions']).'&vecteur=C';
}else{
$href = './?page=greffes&vue=statuts&siret='.$siret.'&option='.$optionUrl.'&lib='.urlencode($acte['decisions']).'&vecteur=C';
}
$title = 'Cliquez ici pour commander le document correspondant';
$tagContent = ' ';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
echo $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.' ';
}else{
echo $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour commander le document correspondant.">'.$tagContent.'';
}
if(hasModeEdition())
{
echo 'Créer une commande factice. ';
}
}
}
?>
0){
?>
=$acte['decisions']; if (trim($acte['decisions'])<>'') echo ' ';?>Dépôt numéro =$acte['depot_num']?> du =WDate::dateT('Y-m-d','d/m/Y', $acte['depot_date'])?>
Le dernier statut à jour
setLog('greffe_'.$vue, $siret, 0, $option);
/*if ($nbVecteurT<$nbActes) { // Tous les actes ne sont pas dispo en téléchargement, on propose donc l'accès INPI
/* $origine='G';
include('inpi.php');
?>
Tous les actes ne sont pas disponibles en téléchargement immédiat. Cliquez-ici pour les commander en téléchargement différé
}*/
?>
PIÉCES OFFICIELLES
Numéro identifiant Siren
=substr($siren,0,3).' '.substr($siren,3,3).' '.substr($siren,6,3)?>
Raison Sociale
=$raisonSociale?>
Actes & Statuts
Date
Type
Décisions
load(PATH_DATA.'/infogreffe/xml/'.$fichier);
$acte['type']=$dom_object->getValueFromTag('type_acte_libelle');
$date=$dom_object->getValueFromTag('date_acte');
$acte['depot_num']=$dom_object->getValueFromTag('num_depot');
$acte['depot_date']=$dom_object->getValueFromTag('date_depot');
$dateAff=WDate::dateT('Y-m-d','d/m/Y', substr($date,0,10));
$acte['url_acces']=$dom_object->getValueFromTag('url_acces');
if (substr($acte['url_acces'],0,5)=='null/') $acte['url_acces']='http://webservices.infogreffe.fr/'.substr($acte['url_acces'],5,strlen($acte['url_acces'])-5);
$nbPages=$dom_object->getValueFromTag('nbpages_acte')*1;
if ($nbPages>0) $acte['decisions']="$nbPages pages";
?>
=$dateAff?>
=$acte['type']?>
=$acte['decisions']; if (trim($acte['decisions'])<>'') echo ' ';?>Dépôt numéro =$acte['depot_num']?> du =WDate::dateT('Y-m-d','d/m/Y', $acte['depot_date'])?>
setLog('greffe_'.$vue, $siret, 0, $option);
//Affichage de la liste des bilans image ou saisit
}
elseif ($type=='BS' || $type=='BI')
{
?>
PIÉCES OFFICIELLES
Numéro identifiant Siren
=substr($siren,0,3).' '.substr($siren,3,3).' '.substr($siren,6,3)?>
Raison Sociale
=$raisonSociale?>
Comptes annuels
Date de clôture Type Décisions
log($fichier, 'fichier');
$return = xmlArrayBilans(PATH_DATA.'/infogreffe/xml/'.$fichier, $query);
$tabActes = $return['Actes'];
foreach ($tabActes as $typeMillesime => $bilan)
{
if ($type=='BS') $dateClot=WDate::dateT('Y-m-d','d/m/Y', $bilan['date_cloture']);
elseif ($type=='BI') $dateClot=$bilan['date_cloture'];
$dateRef = WDate::dateT('d/m/Y','Ymd', $dateClot);
$optionUrl = $bilan['millesime'].'_'.$bilan['type_comptes'].'-'.$dateRef.'-'.$bilan['num_gest_greffe'].'-'.$bilan['num_gest_millesime'].'-'.$bilan['num_gest_statut'].'-'.$bilan['num_gest_chrono'].'-'.$bilan['num_depot'];
?>
=$dateClot?>
'.print_r($page));
if (substr($page['body'],0,4)<>'%PDF') {
$page2 = parse_response($page['body']);
$body = $page2['body'];
} else
$body = $page['body'];
$fp = @fopen(PATH_DATA.'/pdf/'.'bilan-'.$siren.'-'.$option.'.pdf', 'w');
@fwrite($fp, $body);
@fclose($fp);
}
?>
Comptes =$bilan['type_comptes']?> millésime =$bilan['millesime']; if ($type=='BS') echo ' (liasse '.$bilan['liasse'].')';?>
Comptes =$bilan['type_comptes']?> millésime =$bilan['millesime'];
if ($type=='BS') echo ' (liasse '.$bilan['liasse'].')';?>
';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
print $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.'';
}else{
print $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour visualiser le document correspondant.">'.$tagContent.'';
}
}
elseif( $bilan['vecteurC'] )
{
if (file_exists(PATH_DATA.'/pdf/bilan-'.$siren.'-'.$optionUrl.'.pdf') && filesize(PATH_DATA.'/pdf/bilan-'.$siren.'-'.$optionUrl.'.pdf')!=0){
$tag = ' ';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
echo $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.'';
}else{
echo $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour visualiser le document correspondant.">'.$tagContent.'';
}
}else{
$tag = ' ';
if(preg_match('/\bACTES\b/i', $_SESSION['tabInfo']['droits'])){
echo $tag.' href="'.$href.'" title="'.$title.'">'.$tagContent.'';
}else{
echo $tag.' href="#" title="Vous n\'avez pas les droits nécessaires pour commander le document correspondant.">'.$tagContent.'';
}
}
}
elseif( hasModeEdition() )
{
$href = './?page=greffes&vue=bilans&siret='.$siret.'&option='.$optionUrl;
echo 'Forcer téléchargement. ';
}
}
?>
Dépôt numéro =$bilan['num_depot']?>.
setLog('greffe_'.$vue, $siret, 0, $option);
}
elseif (file_exists(PATH_DATA.'/infogreffe/xsl/'.$type.'.xsl'))
{
exec('/usr/bin/xsltproc '.PATH_DATA.'/infogreffe/xsl/'.$type.'.xsl '.PATH_DATA.'/infogreffe/xml/'.$fichier, $output);
$output=implode('', $output);
$output=str_replace('
Extrait RCS ','',$output);
$output=str_replace('','',$output);
$output=preg_replace_callback("/((?:[0-9]{9,9})|(?:[0-9]{3,3} [0-9]{3,3} [0-9]{3,3})|(?:[0-9]{3,3}\.[0-9]{3,3}\.[0-9]{3,3})|(?:[0-9]{3,3}-[0-9]{3,3}-[0-9]{3,3}))/", replace_siren, $output);
echo $output;
// LOG DE LA PAGE
$O2 = $client->setLog('greffe_'.$vue, $siret, 0, $option);
}else {
echo "
$xml ";
// LOG DE LA PAGE
$O2 = $client->setLog('greffe_'.$vue, $siret, 0, $option);
}
} //Fin liste des actes infogreffe ou détails
} //Fin hors Alsace DOM
?>