2012-03-29 13:07:10 +00:00
< ? php
require_once 'WsScore/WsScore.php' ;
require_once realpath ( dirname ( __FILE__ )) . '/Types.php' ;
class Interne extends WsScore
{
/**
* Retourne le détails des privilèges
* @ param string $siren
* @ param array $tabTypes
* @ return PrivilegesDetailReturn
*/
public function getPrivilegesDetail ( $siren , $tabTypes = array ( '03' , '04' ))
{
$this -> authenticate ();
//Initialisation
if ( empty ( $tabTypes )) $tabTypes = array ( '03' , '04' );
debugLog ( 'I' , " Liste des privilèges detail sur $siren " . print_r ( $tabTypes , true ), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iPriv = new MPrivileges ();
$ret = $iPriv -> getPrivilegesDetail ( $siren , $tabTypes ); //@todo : date
$tabRet = array ();
if ( count ( $tabRet ) > 0 ) {
foreach ( $ret as $item ) {
$privileges = new PrivilegesDetail ();
$privileges -> numDebiteur = $item [ 'numDebiteur' ];
$privileges -> greffe = $item [ 'greffe' ];
$privileges -> greffeLib = $item [ 'greffeLib' ];
$privileges -> dateEven = $item [ 'dateEven' ];
$privileges -> dateFraiche = $item [ 'dateFraiche' ];
$privileges -> dateSD = $item [ 'dateSD' ];
$privileges -> insType = $item [ 'insType' ];
$privileges -> insTypeLib = $item [ 'insTypeLib' ];
$privileges -> insNum = $item [ 'insNum' ];
$privileges -> insDate = $item [ 'insDate' ];
$privileges -> insDateEch = $item [ 'insDateEch' ];
$privileges -> insObjet = $item [ 'insObjet' ];
$privileges -> insMontant = $item [ 'insMontant' ];
$privileges -> insDev = $item [ 'insDev' ];
$privileges -> insDateFin = $item [ 'insDateFin' ];
$privileges -> radDate = $item [ 'radDate' ];
$privileges -> radMention = $item [ 'radMention' ];
$privileges -> radPartiel = $item [ 'radPartiel' ];
$privileges -> radPartMt = $item [ 'radPartMt' ];
$privileges -> radDev = $item [ 'radDev' ];
$privileges -> creNom = $item [ 'creNom' ];
$privileges -> creAdresse1 = $item [ 'creAdresse1' ];
$privileges -> creAdresse2 = $item [ 'creAdresse2' ];
$privileges -> creAdresse3 = $item [ 'creAdresse3' ];
$privileges -> creCP = $item [ 'creCP' ];
$privileges -> creVille = $item [ 'creVille' ];
$privileges -> crePays = $item [ 'crePays' ];
$privileges -> creAutres = $item [ 'creAutres' ];
$tabRet [] = $privileges ;
}
}
$this -> wsLog ( 'privdetail' , $siren , join ( ',' , $tabTypes ));
$output = new PrivilegesDetailReturn ();
$output -> result = $tabRet ;
return $output ;
}
/**
* Retourne les privilèges cumulés
* @ param string $siren
* @ param array $tabTypes
* @ return PrivilegesCumulReturn
*/
public function getPrivilegesCumul ( $siren , $tabTypes = array ( '03' , '04' ))
{
$this -> authenticate ();
//Initialisation
if ( empty ( $tabTypes )) $tabTypes = array ( '03' , '04' );
debugLog ( 'I' , " Liste des privilèges cumul sur $siren " . print_r ( $tabTypes , true ), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iPriv = new MPrivileges ();
$ret = $iPriv -> getPrivilegesCumul ( $siren , $tabTypes );
$tabRet = array ();
if ( isset ( $ret [ '03' ]) && count ( $ret [ '03' ] > 0 )){
$value = $ret [ '03' ];
$priv = new PrivilegesCumul ();
$priv -> insType = '03' ;
$priv -> nb = $value [ 'nb' ];
$priv -> insTypeLib = $value [ 'insTypeLib' ];
$priv -> dateFraiche = $value [ 'dateFraiche' ]; //@todo : date
$priv -> dateDerInsc = $value [ 'dateDerInsc' ]; //@todo : date
$priv -> nomDerCre = $value [ 'nomDerCre' ];
$priv -> numDebiteur = $value [ 'numDebiteur' ];
$priv -> greffeLib = $value [ 'greffeLib' ];
$priv -> dateMajSD = $value [ 'dateMajSD' ]; //@todo : date
$priv -> insCumul = $value [ 'insCumul' ];
$tabRet [] = $priv ;
}
if ( isset ( $ret [ '04' ]) && count ( $ret [ '04' ] > 0 )){
$value = $ret [ '04' ];
$priv = new PrivilegesCumul ();
$priv -> insType = '04' ;
$priv -> nb = $value [ 'nb' ];
$priv -> insTypeLib = $value [ 'insTypeLib' ];
$priv -> dateFraiche = $value [ 'dateFraiche' ]; //@todo : date
$priv -> dateDerInsc = $value [ 'dateDerInsc' ]; //@todo : date
$priv -> nomDerCre = $value [ 'nomDerCre' ];
$priv -> numDebiteur = $value [ 'numDebiteur' ];
$priv -> greffeLib = $value [ 'greffeLib' ];
$priv -> dateMajSD = $value [ 'dateMajSD' ]; //@todo : date
$priv -> insCumul = $value [ 'insCumul' ];
$tabRet [] = $priv ;
}
$this -> wsLog ( 'privcumul' , $siren , print_r ( $tabTypes , 1 ));
$output = new PrivilegesCumulReturn ();
$output -> result = $tabRet ;
return $output ;
}
/**
* Liste les mandataires correspondant à un nom donné
* @ param mixed $codeTribunal Identifiants BODACC du tribunal ou tableau d 'Identifiants numériques des cours d' appel
* @ param array $type Type de mandataire ( A ) dministrateur , ( M ) andataire , ( O ) ppositions , ( N ) otaires , a ( V ) ocat
* @ param int $cpDep Code postal ou département du mandataire
* @ return SearchMandatairesReturn
*/
public function searchMandataires ( $nom , $type = array ( 'A' , 'M' ), $cpDep = 0 )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $type )) $type = array ( 'A' , 'M' );
if ( empty ( $cpDep )) $cpDep = 0 ;
$tabRet = array ();
debugLog ( 'I' , " Recherche de Mandataires ' $nom ' (Dep= $cpDep ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iInsee = new MInsee ();
$tabTmp = $iInsee -> searchMandataires ( $nom , true , $type , $cpDep );
foreach ( $tabTmp as $i => $mand )
{
$mandataire = new SearchMandataire ();
$mandataire -> id = 'm' . $i ;
$mandataire -> mand = utf8_encode ( $mand );
$tabRet [] = $mandataire ;
}
$output = new SearchMandatairesReturn ();
$output -> result = $tabRet ;
return $output ;
}
/**
* Retourne la liste des tribunaux ou Compétences demandées
* @ param array | string $tabTypes Tableau des types de Compétences demandés 'C' : Commerce , 'I' : Instance , 'G' : TGI , 'A' : Préfectures , 'B' : Sous - préf , 'D' : Tribunal Administratif , 'H' : Prud 'hommes, ' L ': Cour d' Appel , 'M' : Tribunal Mixte , 'O' : CCI , 'V' : Cour Administrative d ' Appel
* @ return TribunauxReturn
**/
public function getTribunaux ( $tabTypes )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $tabTypes )) $tabTypes = array ();
if ( is_string ( $tabTypes )) $tabTypes = ( array ) $tabTypes ;
$iBodacc = new MBodacc ();
debugLog ( 'I' , " Liste des tribunaux demandées " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$tabTmp = $iBodacc -> getListeTribunaux ();
//@todo : Retourner liste en ordre alphabétique
$tabRet = array ();
if ( count ( $tabTypes ) == 0 ) {
foreach ( $tabTmp as $i => $tribunal ){
$tri = new Tribunal ();
$tri -> code = $i ;
$tri -> nom = $tribunal [ 'nom' ];
$tabRet [] = $tri ;
}
} else {
foreach ( $tabTmp as $i => $tribunal ){
$type = substr ( $i , - 1 );
if ( in_array ( $type , $tabTypes ) ){
$tri = new Tribunal ();
$tri -> code = $i ;
$tri -> nom = $tribunal [ 'nom' ];
$tabRet [] = $tri ;
}
}
}
$this -> wsLog ( 'tribunaux' , '' , print_r ( $tabTypes , 1 ));
$output = new TribunauxReturn ();
$output -> result = $tabRet ;
return $output ;
}
/**
* Enregistrement des informations saisie manuellement
* @ param string $siret
* @ param int $idEntreprise
* @ param SetInfosEntrepInfos $tabInfos
* @ return SetInfosEntrepReturn
*/
public function setInfosEntrep ( $siret , $idEntreprise , $tabInfos )
{
$this -> authenticate ();
//Initialisation
$tabRet = array ();
$iBodacc = new MBodacc ();
$iInsee = new MInsee ();
$result = false ;
2012-08-06 08:24:38 +00:00
if ( $this -> checkEdition ()) {
2012-03-29 13:07:10 +00:00
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
} else {
$siren = substr ( $siret , 0 , 9 );
$nic = substr ( $siret , 9 , 5 );
$iDb = new WDB ();
$tabIdentite = $tabInfos -> identite ;
$tabJugement = $tabInfos -> jugement ;
$tabActio = $tabInfos -> actionnaire ;
$tabParti = $tabInfos -> participation ;
$tabScores = $tabInfos -> score ;
// Mise à jour de l'identité
if ( trim ( strtolower ( $tabIdentite -> web )) == 'http://' ){
$web = '' ;
} else {
$web = trim ( $tabIdentite -> web );
}
$tabUpdate = array (
'isin' => trim ( $tabIdentite -> isin ),
'tel' => trim ( $tabIdentite -> tel ),
'fax' => trim ( $tabIdentite -> fax ),
'web' => $web ,
'mail' => trim ( $tabIdentite -> mail ),
'activite' => stripslashes ( trim ( $tabIdentite -> activite )),
'sirenDoublon' => substr ( str_replace ( ' ' , '' , strtr ( $tabIdentite -> sirenDoublon , '"\'./- ,\*#()' , ' ' )), 0 , 9 ),
'waldec' => trim ( str_replace ( ' ' , '' , strtr ( $tabIdentite -> waldec , '"\'./- ,\*#()' , ' ' ))),
);
/** @todo non traitées : [capital_mt] => 335400, [capital_dev] => EUR **/
if ( ! $iDb -> update ( 'infos_entrep' , $tabUpdate , " siren=' $siren ' " ) ){
if ( ! $iDb -> insert ( 'infos_entrep' , array_merge ( array ( 'siren' => $siren ), $tabUpdate ))){
$error -> errnum = 1 ;
$error -> errmsg = 'Mise a jour impossible' ;
$output = new SetInfosEntrepReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
exit ;
}
}
// Fin mise à jour identité
// Opposition INSEE
if ( $tabIdentite -> moisOppositionInsee > 0 &&
$tabIdentite -> moisOppositionInsee <= ( date ( 'Ym' ) * 1 ) ){
$iDb2 = new WDB ( 'insee' );
if ( ! $iDb2 -> insert ( 'insee_nondiff' , array ( 'siren' => $siren , 'insEVE' => 795 , 'mois' => $tabIdentite -> moisOppositionInsee )) ){
if ( $iDb2 -> getLastErrorNum () <> 1062 )
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ERREUR setInfosEntrep pour $siren " , " Erreur lors de l'inscription à la liste des oppositions de la sphère commerciale INSEE pour $siren au mois de " . $tabIdentite [ 'moisOppositionInsee' ] . " : " . EOL . print_r ( $tabIdentite , true ) . EOL . $iDb2 -> getLastError ());
}
}
// Fin opposition INSEE
// Refus d'inscription au RCS
2012-07-17 06:22:32 +00:00
if ( isset ( $tabIdentite -> moisRefusRCS ) && $tabIdentite -> moisRefusRCS > 0
2012-03-29 13:07:10 +00:00
&& $tabIdentite -> moisRefusRCS <= ( date ( 'Ym' ) * 1 )) {
$iInsee = new MInsee ();
$entrep = $iInsee -> getIdentiteLight ( $siren );
if ( $nic < 10 ) $nic = $entrep [ 'Nic' ];
$cj1 = substr ( $entrep [ 'FJ' ], 0 , 1 );
$iDb2 = new WDB ( 'insee' );
/** Insertion dans la tables des exclusions **/
2012-07-17 06:22:32 +00:00
$tabInsert = array (
2012-03-29 13:07:10 +00:00
'siren' => $siren ,
'nic' => $nic ,
'idSaisie' => $this -> tabInfoUser [ 'id' ],
'cj1' => $cj1 ,
'insEVE' => 'RCS' ,
'mois' => $tabIdentite -> moisRefusRCS ,
);
if ( ! $iDb2 -> insert ( 'insee_nondiff' , $tabInsert ))
if ( $iDb2 -> getLastErrorNum () <> 1062 )
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ERREUR setInfosEntrep pour $siren " , " Erreur lors de l'inscription à la liste des refus d'enregistrement A au RCS pour $siren au mois de " . $tabIdentite -> moisRefusRCS . " : " . EOL . print_r ( $tabInsert , true ) . EOL . print_r ( $tabIdentite , true ) . EOL . $iDb2 -> getLastError ());
/** Insertion dans la tables des évènements **/
2012-07-17 06:22:32 +00:00
$tabInsert = array (
2012-03-29 13:07:10 +00:00
'insSIREN' => $siren ,
'siretValide' => $iInsee -> valideSiren ( $siren , $nic ),
'insNIC' => $nic ,
'insEVE' => 'RCS' ,
'insDATEVE' => $tabIdentite -> moisRefusRCS . '28' ,
'insDATEMAJ' => date ( 'YmdHis' ),
'idFlux' => date ( 'Ymd' ));
if ( ! $iDb2 -> insert ( 'insee_even' , $tabInsert ))
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ERREUR setInfosEntrep pour $siren " , " Erreur lors de l'inscription à la liste des refus d'enregistrement B au RCS pour $siren au mois de " . $tabIdentite [ 'moisOppositionInsee' ] . " : " . EOL . print_r ( $tabInsert , true ) . EOL . print_r ( $tabIdentite , true ) . EOL . $iDb2 -> getLastError ());
}
2012-07-17 06:22:32 +00:00
// Fin refus d'inscription au RCS
2012-03-29 13:07:10 +00:00
// Domiciliataire
if ( ! empty ( $tabIdentite -> domiciliataire ) && $siren > 1000 ) {
if ( $tabIdentite -> domiciliataire == 'oui' || $tabIdentite -> domiciliataire == 'non' ) {
// L'entreprise et ces établissements seront mis à jour automatiquement ce soir
$iDb -> query ( " INSERT IGNORE INTO jo.tabAdrDom (siren,nic,siege, etActif, nom, sigle, enseigne, adrNum, adrBtq, adrTypVoie, adrLibVoie, ville, cp, depComEt, adrComp, cj, apen,apet, dateInsert)
SELECT siren , nic , siege , actif AS etActif , raisonSociale AS nom , sigle , enseigne , adr_num as adrNum , adr_btq AS adrBtq , adr_typeVoie AS adrTypVoie , adr_libVoie AS adrLibVoie , adr_ville AS ville , adr_cp AS cp , CONCAT ( adr_dep , adr_com ) AS depComEt , adr_comp AS adrComp , cj , ape_entrep AS apen , ape_etab AS apet , DATE ( NOW ()) as dateInsert
FROM jo . etablissements WHERE siren = $siren ; " , false);
}
// Si demande de suppression, on force l'indicateur ""
if ( $tabIdentite -> domiciliataire == 'non' ) {
$tabUpdate = array ( 'pasEntrepDom' => 1 );
if ( ! $iDb -> update ( 'tabAdrDom' , $tabUpdate , " siren= $siren " ))
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ERREUR setInfosEntrep pour $siren " , " Erreur lors de la suppression du marqueur de domiciliation pour $siren : " . EOL . print_r ( $tabUpdate , true ) . EOL . $iDb -> getLastError ());
}
}
// Fin domiciliataire
// Insertion des scores
$tabUpdate = array ();
$setScore = false ;
if ( $tabScores -> encours != '' || $tabScores -> encours != null ){
$tabUpdate [ 'encours' ] = $tabScores -> encours ;
$setScore = true ;
}
if ( $tabScores -> scoreSolv != '' ){
$tabUpdate [ 'scoreSolv' ] = $tabScores -> scoreSolv ;
$setScore = true ;
}
if ( $tabScores -> scoreDir != '' ){
$tabUpdate [ 'scoreDir' ] = $tabScores -> scoreDir ;
$setScore = true ;
}
if ( $tabScores -> scoreConf != '' ){
$tabUpdate [ 'scoreConf' ] = $tabScores -> scoreConf ;
$setScore = true ;
}
if ( $setScore ){
// Mise à jour des Cute Offs
if ( ! $iDb -> update ( 'scores_cutoff' , $tabUpdate , " siren= $siren " ) ){
if ( ! $iDb -> insert ( 'scores_cutoff' , array_merge ( array (
'siren' => $siren ,
'dateInsert' => date ( 'Ymd' )
), $tabUpdate )) ){
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ERREUR setInfosEntrep pour $siren " , print_r ( $tabScores , true ) . EOL . $iDb -> getLastError ());
}
}
}
// Fin insertion des scores
// Insertion du jugement
$tabEven = array ();
if ( is_array ( $tabJugement -> even -> item ) && count ( $tabJugement -> even -> item ) > 0 ){
foreach ( $tabJugement -> even -> item as $even ){
$tabEven [] = $even -> code ;
}
} elseif ( ! empty ( $tabJugement -> even -> item -> code )) {
2012-07-17 06:22:32 +00:00
$tabEven [] = $tabJugement -> even -> item -> code ;
2012-03-29 13:07:10 +00:00
}
$nic = $tabJugement -> nic * 1 ;
$entrep = $iInsee -> getIdentiteLight ( $siren , $nic );
if ( $nic > 0 && $tabEven [ 0 ] -> code == 6700 && $entrep [ 'Siege' ] == 0 ){
// Radiation d'un établissement
$tabEven [ 0 ] -> code = 6600 ;
}
if ( count ( $tabEven ) > 0 )
{
$idAdmin = str_replace ( 'm' , '' , trim ( $tabJugement -> admin ));
$idMand = str_replace ( 'm' , '' , trim ( $tabJugement -> mand ));
$idOppo = str_replace ( 'm' , '' , trim ( $tabJugement -> oppo ));
/** Nom et Identifiant de l'opérateur de saisie **/
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'utilisateurs' , 'id' , " login=' " . $this -> tabInfoUser [ 'login' ] . " ' " );
$idUser = $rep [ 0 ][ 0 ];
$tabSource = explode ( '_' , $tabJugement -> source );
$source =@ $tabSource [ 0 ];
$numJal =@ $tabSource [ 1 ];
$dateSource = WDate :: dateT ( 'd/m/Y' , 'Ymd' , trim ( $tabJugement -> dateParution )) * 1 ;
if ( $dateSource < 20000101 )
$dateSource = date ( 'YmdHis' );
$montant = trim ( preg_replace ( '/[^0-9]/' , '' , $tabJugement -> montant )) * 1 ;
$actionsMt = trim ( preg_replace ( '/[^0-9]/' , '' , $tabJugement -> actionsMt )) * 1 ;
$actionsNb = trim ( preg_replace ( '/[^0-9]/' , '' , $tabJugement -> actionsNb )) * 1 ;
if ( $montant > 0 && ( $actionsNb > 0 || $actionsMt > 0 )) {
if ( $actionsNb > 0 ) $actionsMt = $montant / $actionsNb ;
elseif ( $actionsMt > 0 ) $actionsNb = $montant / $actionsMt ;
}
//@todo : ça ne va pas marcher ici
$strDir = '' ;
$tabNouvDir = array ();
if ( is_array ( $tabJugement -> nouvDir -> item ) && count ( $tabJugement -> nouvDir -> item ) > 0 ){
$tabNouvDir = $tabJugement -> nouvDir -> item ;
} else {
2012-07-17 06:22:32 +00:00
$tabNouvDir [] = $tabJugement -> nouvDir ;
2012-03-29 13:07:10 +00:00
}
2012-07-17 06:22:32 +00:00
if ( count ( $tabNouvDir ) > 0 ) {
2012-03-29 13:07:10 +00:00
foreach ( $tabNouvDir as $dir ){
if ( intval ( $dir -> Fonc ) > 0 ){
$strDir .= $iBodacc -> getFctDir ( $dir -> Fonc ) . ' : ' .
$dir -> Genre . ' ' .
ucwords ( strtolower ( $dir -> Pre )) . ' ' .
strtoupper ( $dir -> Nom );
if ( ! empty ( $dir -> Dom )) {
$strDir .= ', domicilié à ' . $dir -> Dom . '. ' ;
}
}
}
}
if ( trim ( $tabJugement -> nouvAdrCp ) <> '' ){
$strAdr = stripslashes ( trim ( $tabJugement -> nouvAdr ) . ', ' .
trim ( $tabJugement -> nouvAdrCp ) . ' ' .
trim ( $tabJugement -> nouvAdrVille ));
} else {
$strAdr = '' ;
}
if ( count ( $tabEven ) > 1 ){
$strEven = implode ( ';' , array_slice ( $tabEven , 1 ));
} else {
$strEven = '' ;
}
$tabUpdate = array (
'strEven' => $strEven ,
'sirenValide' => $iInsee -> valideSiren ( $siren ),
2012-07-17 06:22:32 +00:00
'dateCessationPaiement' => empty ( $tabJugement -> datePaie ) ? '' :
2012-03-29 13:07:10 +00:00
WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabJugement -> datePaie )),
2012-07-17 06:22:32 +00:00
'dateEffetFinP' => empty ( $tabJugement -> dateFinPeriode ) ? '' :
2012-03-29 13:07:10 +00:00
WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabJugement -> dateFinPeriode )),
'tribunal' => trim ( $tabJugement -> tribunal ),
'montant' => $montant ,
'actionsNb' => $actionsNb ,
'inter1type' => 'A' ,
'inter1id' => $idAdmin ,
'inter1nom' => $iInsee -> getMandatairesParId ( $idAdmin ),
'inter2type' => 'M' ,
'inter2id' => $idMand ,
'inter2nom' => $iInsee -> getMandatairesParId ( $idMand ),
'inter3type' => 'O' ,
'inter3id' => $idOppo ,
'inter3nom' => $iInsee -> getMandatairesParId ( $idOppo ),
'complement' => stripslashes ( trim ( $tabJugement -> comp )),
'nouvActivite' => stripslashes ( trim ( $tabJugement -> nouvActivite )),
'nouvDir' => stripslashes ( trim ( $strDir )),
'nouvAdr' => $strAdr ,
'nouvFJ' => trim ( $tabJugement -> nouvFJ ),
'raisonSociale' => $entrep [ 'Nom' ],
'adresse' => $entrep [ 'Adresse' ],
'codePostal' => $entrep [ 'CP' ],
'ville' => $entrep [ 'Ville' ],
'source' => $source ,
'idSaisie' => $idUser ,
'parutionIdJal' => $numJal ,
'parutionNum' => $tabJugement -> numParution ,
);
$dateJuge = WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabJugement -> dateJuge ));
$tabInsert = array_merge ( $tabUpdate , array (
'siren' => $siren ,
'dateJugement' => $dateJuge ,
'typeEven' => $tabEven [ 0 ],
'dateSource' => $dateSource ,
));
if ( ! $iDb -> insert ( 'annonces' , array_merge ( $tabInsert , array ( 'dateInsert' => date ( 'YmdHis' ))), true ) ){
if ( ! $iDb -> update ( 'annonces' , $tabUpdate , " siren= $siren AND dateJugement=' $dateJuge ' AND typeEven= " . $tabEven [ 0 ], true )){
$error -> errnum = 1 ;
$error -> errmsg = 'Mise a jour impossible' ;
$output = new SetInfosEntrepReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
}
}
//Fin insertion jugement
// Insertion actionnaire
2012-07-17 06:22:32 +00:00
if ( trim ( $tabActio -> siren ) != '' )
{
2012-03-29 13:07:10 +00:00
$nom = $pays = $dateMAJ = '' ;
$ppPm = 'P' ;
$pct = trim ( str_replace ( ',' , '.' , $tabActio -> pct )) * 1 ;
$siren2 = preg_replace ( '/[^0-9]/' , '' , $tabActio -> siren );
$entrep2 = $iInsee -> getIdentiteEntreprise ( $siren );
$nom2 = $entrep2 [ 'Nom' ];
$pays2 = $entrep2 [ 'Pays' ];
if ( $pays2 == '' ) $pays2 = 'FRA' ;
if ( substr ( $entrep2 [ 'FJ' ], 0 , 1 ) * 1 <> 1 ) $ppPm = 'M' ;
$entrep = $iInsee -> getIdentiteEntreprise ( $siren2 );
$nom = $entrep [ 'Nom' ];
$pays = trim ( $entrep [ 'Pays' ]);
if ( $pays == '' ) $pays = 'FRA' ;
if ( trim ( $tabActio -> nom ) != '' ) $nom = $tabActio -> nom ;
if ( $tabActio -> pays != 'XXX' ) $pays = $tabActio -> pays ;
if ( trim ( $tabActio -> dateMAJ ) != 'JJ/MM/AAAA' && trim ( $tabActio -> dateMAJ ) != '' ){
$dateMAJ = WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabActio -> dateMAJ ));
}
if ( $tabActio -> majMin == 'maj' ) $majMin = '+' ;
elseif ( $tabActio -> majMin == 'min' ) $majMin = '-' ;
else $majMin = '' ;
$tabUpdate = array (
//'Siren1'=> $siren,
'Pmin' => $pct ,
'Pmax' => $pct ,
'MajMin' => $majMin ,
'PpPm' => $ppPm ,
//'Siren2'=> $siren2,
//'RaisonSociale'=> $nom,
//'Pays'=> $pays,
'dateLien' => $dateMAJ ,
);
$tabInsert1 = array_merge ( $tabUpdate , array ( 'ActionPart' => 1 ),
array (
'Siren1' => $siren ,
'Siren2' => $siren2 ,
'RaisonSociale' => $nom ,
'Pays' => $pays ,
'actif' => 1 ,
'source' => 1900 ,
'dateInsert' => date ( 'YmdHis' ))
2012-07-17 06:22:32 +00:00
); Zend_Registry :: get ( 'WsLogger' ) -> info ( 'INSERTION ACTIONNAIRE : ' . print_r ( $tabInsert1 , 1 ));
2012-03-29 13:07:10 +00:00
$res = $iDb -> select ( 'liens' , 'count(*)' ,
" Siren1= $siren AND (Siren2= $siren2 OR (RaisonSociale=' $nom ' AND Pays=' $pays ')) " );
if ( $res [ 0 ][ 0 ] > 0 ) {
if ( ! $iDb -> update ( 'liens' , array_merge (
$tabUpdate , array ( 'ActionPart' => 1 )),
" siren= $siren AND (Siren2= $siren2 OR (RaisonSociale=' $nom ' AND Pays=' $pays ')) " , true ))
$errMaj = 1016166 ;
} else {
if ( ! $iDb -> insert ( 'liens' , $tabInsert1 , true ))
$errMaj = 1016167 ;
}
$tabInsert2 = array_merge ( $tabUpdate , array ( 'ActionPart' => 2 ),
array ( 'Siren1' => $siren2 ,
'Siren2' => $siren ,
'RaisonSociale' => $nom2 ,
'Pays' => $pays2 ,
'actif' => 1 ,
'source' => 1900 ,
'dateInsert' => date ( 'YmdHis' ))
);
$res = $iDb -> select ( 'liens' , 'count(*)' , " Siren1= $siren2 AND (Siren2= $siren OR (RaisonSociale=' $nom2 ' AND Pays=' $pays2 ')) " );
if ( $res [ 0 ][ 0 ] > 0 ) {
if ( ! $iDb -> update ( 'liens' , array_merge ( $tabUpdate , array ( 'ActionPart' => 2 )), " siren= $siren2 AND (Siren2= $siren OR (RaisonSociale=' $nom2 ' AND Pays=' $pays2 ')) " , true ))
$errMaj = 1016168 ;
} else {
if ( ! $iDb -> insert ( 'liens' , $tabInsert2 , true ))
$errMaj = 1016169 ;
}
}
// Fin insertion actionnaire
//Insertion participation
if ( trim ( $tabParti -> siren ) <> '' ) {
$nom = $pays = $dateMAJ = '' ;
$ppPm = 'P' ;
$pct = trim ( str_replace ( ',' , '.' , $tabParti -> pct )) * 1 ;
$siren2 = preg_replace ( '/[^0-9]/' , '' , $tabParti -> siren );
$entrep2 = $iInsee -> getIdentiteEntreprise ( $siren );
$nom2 = $entrep2 [ 'Nom' ];
$pays2 = $entrep2 [ 'Pays' ];
if ( $pays2 == '' ) $pays2 = 'FRA' ;
if ( substr ( $entrep2 [ 'FJ' ], 0 , 1 ) * 1 <> 1 ) $ppPm = 'M' ;
$entrep = $iInsee -> getIdentiteEntreprise ( $siren2 );
$nom = $entrep [ 'Nom' ];
$pays = trim ( $entrep [ 'Pays' ]);
if ( $pays == '' ) $pays = 'FRA' ;
if ( trim ( $tabParti -> nom ) <> '' ) $nom = $tabParti -> nom ;
if ( $tabParti -> pays <> 'XXX' ) $pays = $tabParti -> pays ;
if ( trim ( $tabParti -> dateMAJ ) <> 'JJ/MM/AAAA' && trim ( $tabParti -> dateMAJ ) <> '' )
$dateMAJ = WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabParti -> dateMAJ ));
if ( $tabParti -> majMin == 'maj' ) $majMin = '+' ;
elseif ( $tabParti -> majMin == 'min' ) $majMin = '-' ;
else $majMin = '' ;
$tabUpdate = array (
'Pmin' => $pct ,
'Pmax' => $pct ,
'MajMin' => $majMin ,
'PpPm' => $ppPm ,
'dateLien' => $dateMAJ ,
);
$tabInsert1 = array_merge ( $tabUpdate , array ( 'ActionPart' => 2 ),
array ( 'Siren1' => $siren ,
'Siren2' => $siren2 ,
'RaisonSociale' => $nom ,
'Pays' => $pays ,
'actif' => 1 ,
'source' => 1900 ,
'dateInsert' => date ( 'YmdHis' ))
);
$res = $iDb -> select ( 'liens' , 'count(*)' , " Siren1= $siren AND (Siren2= $siren2 OR (RaisonSociale=' $nom ' AND Pays=' $pays ')) " );
if ( $res [ 0 ][ 0 ] > 0 ) {
if ( ! $iDb -> update ( 'liens' , array_merge ( $tabUpdate , array ( 'ActionPart' => 2 )), " siren= $siren AND (Siren2= $siren2 OR (RaisonSociale=' $nom ' AND Pays=' $pays ')) " , true ))
$errMaj = 10168 ;
} else {
if ( ! $iDb -> insert ( 'liens' , $tabInsert1 , true ))
$errMaj = 10169 ;
}
$tabInsert2 = array_merge ( $tabUpdate , array ( 'ActionPart' => 1 ),
array ( 'Siren1' => $siren2 ,
'Siren2' => $siren ,
'RaisonSociale' => $nom2 ,
'Pays' => $pays2 ,
'actif' => 1 ,
'source' => 1900 ,
'dateInsert' => date ( 'YmdHis' ))
);
$res = $iDb -> select ( 'liens' , 'count(*)' , " Siren1= $siren2 AND (Siren2= $siren OR (RaisonSociale=' $nom2 ' AND Pays=' $pays2 ')) " );
if ( $res [ 0 ][ 0 ] > 0 ) {
if ( ! $iDb -> update ( 'liens' , array_merge ( $tabUpdate , array ( 'ActionPart' => 1 )), " siren= $siren2 AND (Siren2= $siren OR (RaisonSociale=' $nom2 ' AND Pays=' $pays2 ')) " , true ))
$errMaj = 10170 ;
} else {
if ( ! $iDb -> insert ( 'liens' , $tabInsert2 , true ))
$errMaj = 10171 ;
}
}
// Fin insertion participation
if ( $errMaj > 0 ){
$error -> errnum = 1 ;
$error -> errmsg = 'Mise a jour impossible' ;
} else {
$result = true ;
}
}
$output = new SetInfosEntrepReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Commande de bilan
* @ param InfoCommandeBilan $infoCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdBilanReturn
*/
public function setCmdBilan ( InfoCommandeBilan $infoCommande , InfosDemandeur $infosDemandeur )
{
}
/**
* Renvoi des informations sur une commande de bilan
* @ param string $reference
* @ return CmdBilanReturn
*/
public function getCmdBilan ( $reference )
{
}
/**
* Commande d ' acte
* @ param InfoCommandeActe $infoCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdActeReturn
*/
public function setCmdActe ( $infoCommande , $infosDemandeur )
{
}
/**
* Renvoi des informations sur une commande d ' acte
* @ param string $reference
* @ return CmdActeReturn
*/
public function getCmdActe ( $reference ){}
/**
* Commande de kbis
* @ param InfoCommandeKbis $infoCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdKbisReturn
*/
public function setCmdKbis ( InfoCommandeKbis $infoCommande , InfosDemandeur $infosDemandeur )
{
$this -> authenticate ();
$error = new ErrorType ();
$ref = new RefCommande ();
//Vérifier les informations
switch ( $infoCommande -> mode )
{
case 'courrier' : break ;
case 'mail' : break ;
default :
exit ; break ;
}
if ( empty ( $infoCommande -> siren ))
{
$error -> errnum = 0 ;
$error -> errmsg = 'Erreur SIREN invalide' ;
}
else
{
$login = $_SERVER [ 'PHP_AUTH_USER' ];
// Insertion des données commande
$dataCommandes = array (
'user_login' => $login ,
'user_email' => $this -> tabInfoUser [ 'email' ],
'type' => 'kbis' ,
'demandeurReference' => $infosDemandeur -> reference ,
'demandeurEmail' => $infosDemandeur -> email ,
'demandeurTel' => $infosDemandeur -> tel ,
'demandeurNom' => $infosDemandeur -> nom ,
'demandeurService' => $infosDemandeur -> service ,
'demandeurSociete' => $infosDemandeur -> societe ,
'demandeurAdresse' => $infosDemandeur -> adresse ,
'demandeurCp' => $infosDemandeur -> cp ,
'demandeurVille' => $infosDemandeur -> ville ,
'infoCommande' => serialize ( $infoCommande )
);
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$commande = new Application_Model_Commandes ();
$commande_id = $commande -> insert ( $dataCommandes );
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
if ( $commande_id )
{
//Enregistrement des détails de commande
$dataCommandesKbis = array (
'commande_id' => $commande_id ,
'siren' => $infoCommande -> siren ,
'raisonSociale' => '' ,
'fichier' => '' ,
'partenaireRequete' => '' ,
'partenaireReponse' => '' ,
);
try {
$commandeKbisTable = new Application_Model_CommandesPieces ();
$commandeKbisTable -> insert ( $dataCommandesKbis );
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
try {
$row = $commande -> find ( $commande_id );
$data = $row -> current ();
$ref -> reference = $data -> id ;
$ref -> dateCommande = $data -> date_added ;
$ref -> dateMaj = $data -> date_updated ;
$ref -> dateReception = $data -> date_closed ;
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
$error -> errnum = 0 ;
$error -> errmsg = " Commande Introuvable " ;
}
}
else
{
$error -> errnum = 0 ;
$error -> errmsg = " Erreur enregistrement commande " ;
}
}
$output = new CmdKbisReturn ();
$cmd = new CmdKbisDetail ();
$cmd -> infoCommande = $infoCommande ;
$cmd -> infosDemandeur = $infosDemandeur ;
$cmd -> refCommande = $ref ;
$output -> commande = $cmd ;
$output -> error = $error ;
return $output ;
}
/**
* Renvoi des informations sur une commande de Kbis
* @ param string $reference
* @ return CmdKbisReturn
*/
public function getCmdKbis ( $reference ){}
/**
* Commande de privilèges et nantissements par email
* @ param InfoCommandePieces $infoCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdPiecesReturn
*/
public function setCmdPieces ( $infoCommande , $infosDemandeur )
{
$this -> authenticate ();
$error = new ErrorType ();
$ref = new RefCommande ();
if ( ! empty ( $infoCommande -> siren )){
//Vérification SIREN
// Insertion des données commande
$dataCommandes = array (
'user_login' => $this -> tabInfoUser [ 'login' ],
'user_email' => $this -> tabInfoUser [ 'email' ],
'type' => 'pieces' ,
'demandeurReference' => $infosDemandeur -> reference ,
'demandeurEmail' => $infosDemandeur -> email ,
'demandeurTel' => $infosDemandeur -> tel ,
'demandeurNom' => $infosDemandeur -> nom ,
'demandeurService' => $infosDemandeur -> service ,
'demandeurSociete' => $infosDemandeur -> societe ,
'demandeurAdresse' => $infosDemandeur -> adresse ,
'demandeurCp' => $infosDemandeur -> cp ,
'demandeurVille' => $infosDemandeur -> ville ,
'infoCommande' => serialize ( $infoCommande )
);
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$commande = new Application_Model_Commandes ();
$commande_id = $commande -> insert ( $dataCommandes );
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
if ( $commande_id ){
//Enregistrement des détails de commande
$dataCommandesPieces = array (
'commande_id' => $commande_id ,
'siren' => $infoCommande -> siren ,
'raisonSociale' => '' ,
'fichier' => '' ,
);
try {
$commandePieces = new Application_Model_CommandesPieces ();
$commandePieces -> insert ( $dataCommandesPieces );
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
try {
$row = $commande -> find ( $commande_id );
$data = $row -> current ();
$ref -> reference = $data -> id ;
$ref -> dateCommande = $data -> date_added ;
$ref -> dateMaj = $data -> date_updated ;
$ref -> dateReception = $data -> date_closed ;
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
$error -> errnum = 0 ;
$error -> errmsg = " Commande Introuvable " ;
}
} else {
$error -> errnum = 0 ;
$error -> errmsg = " Erreur enregistrement commande " ;
}
} else {
$error -> errnum = 0 ;
$error -> errmsg = 'Erreur SIREN invalide' ;
}
$output = new CmdPiecesReturn ();
$cmd = new CmdPiecesDetail ();
$cmd -> infoCommande = $infoCommande ;
$cmd -> infosDemandeur = $infosDemandeur ;
$cmd -> refCommande = $ref ;
$output -> error = $error ;
return $output ;
}
/**
* Renvoi des informations sur une commande pièces
* @ param string $reference
* @ return CmdPiecesReturn
*/
public function getCmdPieces ( $reference )
{
list ( $typeCommande , $idCommande ) = explode ( '-' , $reference );
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$commandeTable = new Application_Model_Commandes ();
$select = $commandeTable -> select ()
-> where ( 'type = ?' , 'pieces' )
-> where ( 'id = ?' , $idCommande );
$commandeRowset = $commandeTable -> fetchAll ( $select );
}
catch ( Zend_Db_Adapter_Exception $e )
{
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
$error = new ErrorType ();
$ref = new RefCommande ();
$infoCommande = new InfoCommandePieces ();
$infosDemandeur = new InfosDemandeur ();
if ( $commandeRowset -> count () > 0 )
{
$commande = $commandeRowset -> current ();
$selectEven = $commandeTable -> select ()
-> order ( 'date_added DESC' ) -> limit ( 1 );
$evenRowset = $commande -> findDependentRowset (
'Application_Model_CommandesEven' , null , $selectEven );
$info = '' ;
if ( $evenRowset -> count () > 0 ){
$even = $evenRowset -> current ();
$info = $even -> commentaire ;
}
$ref -> reference = strtoupper ( $commande -> type ) . '-' . $commande -> id ;
$ref -> dateCommande = $commande -> date_added ;
$ref -> dateMaj = $commande -> date_updated ;
$ref -> dateReception = $commande -> date_closed ;
$ref -> info = $info ;
$ref -> fichier = '' ; // @todo : Détecter le fichier
$ref -> login = $commande -> user_login ;
$infoCommande = unserialize ( $commande -> infoCommande );
$infosDemandeur -> reference = $commande -> demandeurReference ;
$infosDemandeur -> email = $commande -> demandeurEmail ;
$infosDemandeur -> tel = $commande -> demandeurTel ;
$infosDemandeur -> nom = $commande -> demandeurNom ;
$infosDemandeur -> service = $commande -> demandeurService ;
$infosDemandeur -> societe = $commande -> demandeurSociete ;
$infosDemandeur -> adresse = $commande -> demandeurAdresse ;
$infosDemandeur -> cp = $commande -> demandeurCp ;
$infosDemandeur -> ville = $commande -> demandeurVille ;
}
else
{
$error -> errnum = 0 ;
$error -> errmsg = 'Référence inconnue' ;
}
$output = new CmdPiecesReturn ();
$cmd = new CmdPiecesDetail ();
$cmd -> refCommande = $ref ;
$cmd -> infoCommande = $infoCommande ;
$cmd -> infosDemandeur = $infosDemandeur ;
$output -> commande = $cmd ;
$output -> error = $error ;
return $output ;
}
/**
* Retourne la liste des commandes de pièces ainsi que leur détails
* @ param CmdFiltrePieces $filtre
* @ param int $position
* @ param int $nbRep
* @ return ListeCmdPiecesReturn
*/
public function getListeCmdPieces ( $filtre , $position = 0 , $nbRep = 20 )
{
$error = new ErrorType ();
//Traitements des filtres pour générer la requête SQL
//Selection
$nbCommandes = 0 ;
try
{
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$commandeTable = new Application_Model_Commandes ();
$select = $commandeTable -> select () -> where ( 'type = ?' , 'pieces' );
$countRowset = $commandeTable -> fetchAll ( $select );
$nbCommandes = $countRowset -> count ();
$select -> order ( 'date_added DESC' ) -> limit ( $nbRep , $position );
$commandeRowset = $commandeTable -> fetchAll ( $select );
}
catch ( Zend_Db_Adapter_Exception $e )
{
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
$error -> errnum = 1 ;
$error -> errmsg = 'Erreur' ;
}
if ( $commandeRowset -> count () > 0 )
{
$liste = array ();
foreach ( $commandeRowset as $commande )
{
$selectEven = $commandeTable -> select ()
-> order ( 'date_added DESC' ) -> limit ( 1 );
$evenRowset = $commande -> findDependentRowset (
'Application_Model_CommandesEven' , null , $selectEven );
$info = '' ;
if ( $evenRowset -> count () > 0 ){
$even = $evenRowset -> current ();
$info = $even -> commentaire ;
}
$ref = new RefCommande ();
$ref -> reference = strtoupper ( $commande -> type ) . '-' . $commande -> id ;
$ref -> dateCommande = $commande -> date_added ;
$ref -> dateMaj = $commande -> date_updated ;
$ref -> dateReception = $commande -> date_closed ;
$ref -> info = $info ;
$ref -> fichier = '' ; // @todo : Détecter le fichier
$ref -> login = $commande -> user_login ;
$infoCommande = new InfoCommandePieces ();
$infoCommande = unserialize ( $commande -> infoCommande );
$infosDemandeur = new InfosDemandeur ();
$infosDemandeur -> reference = $commande -> demandeurReference ;
$infosDemandeur -> email = $commande -> demandeurEmail ;
$infosDemandeur -> tel = $commande -> demandeurTel ;
$infosDemandeur -> nom = $commande -> demandeurNom ;
$infosDemandeur -> service = $commande -> demandeurService ;
$infosDemandeur -> societe = $commande -> demandeurSociete ;
$infosDemandeur -> adresse = $commande -> demandeurAdresse ;
$infosDemandeur -> cp = $commande -> demandeurCp ;
$infosDemandeur -> ville = $commande -> demandeurVille ;
$cmd = new CmdPiecesDetail ();
$cmd -> refCommande = $ref ;
$cmd -> infoCommande = $infoCommande ;
$cmd -> infosDemandeur = $infosDemandeur ;
$liste [] = $cmd ;
}
}
$output = new ListeCmdPiecesReturn ();
$output -> error = $error ;
$output -> nbCommandes = $nbCommandes ;
$output -> liste = $liste ;
return $output ;
}
/**
* Retourne la liste des statuts de commande
* @ param string $type
* @ return CmdStatut []
*/
public function getListeCmdStatut ( $type )
{
Zend_Registry :: get ( 'WsLogger' ) -> info ( " getListeStatut - " . $type );
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$dbStatut = new Application_Model_CommandesStatut ();
$result = $dbStatut -> fetchAll ( array ( " commande_type = ' $type ' " ));
}
catch ( Zend_Db_Adapter_Exception $e )
{
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
$listeStatut = array ();
if ( count ( $result ) > 0 )
{
foreach ( $result as $r )
{
$statut = new CmdStatut ();
$statut -> code = $r [ 'code' ];
$statut -> lib = $r [ 'libelle' ];
$listeStatut [] = $statut ;
}
}
return $listeStatut ;
}
/**
* Spécifier un état défini pour une commande
* ( avec déclenchement d ' une action )
* @ param int $reference
* @ param int $statutCode
* @ return bool
*/
public function setCmdStatut ( $reference , $statutCode )
{
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$dbStatut = new Application_Model_CommandesStatut ();
$row = $dbStatut -> fetchRow ( array ( " code = ' $statutCode ' " ));
if ( count ( $row ) > 0 && $this -> setCommandeEven ( $reference , $row [ 'lib' ]) )
{
if ( ! empty ( $row [ 'action' ])){
switch ( $row [ 'action' ]){
case 'CLOSE' :
//date_closed
break ;
}
}
return true ;
} else {
return false ;
}
}
/**
* Spécifier un état pour une commande
* @ param int $reference
* @ param string $comment
* @ return bool
*/
public function setCmdEven ( $reference , $comment )
{
$this -> authenticate ();
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
try {
//Vérifier que la commande existe avec la référence fournie
$commandeTable = new Application_Model_Commandes ();
$commandeRowset = $commandeTable -> find ( $reference );
if ( $commandeRowset -> count () > 0 )
{
$commande = $commandeRowset -> current ();
//Enregistrer l'événement
$commandeEvenTable = new Application_Model_CommandesEven ();
$insert = $commandeEvenTable -> createRow ();
$insert -> commande_id = $commande -> id ;
$insert -> commentaire = $comment ;
$insert -> user_login = $this -> tabInfoUser [ 'login' ];
$insert -> save ();
//Mettre à jour la commande
$commande -> date_updated = date ( 'Y-m-d H:i:s' );
$commande -> save ();
return true ;
} else {
return false ;
}
}
catch ( Zend_Db_Adapter_Exception $e )
{
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
return false ;
}
}
/**
* Ajout du nom de fichier liée à la commande
* @ param int $reference
* @ param string $filename
* @ return bool
*/
public function setCmdDocument ( $reference , $filename )
{
$this -> authenticate ();
$db = Zend_Db :: factory ( $this -> dbConfig -> Commandes );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
try {
//Vérifier que la commande existe avec la référence fournie
$commandeTable = new Application_Model_Commandes ();
$commandeRowset = $commandeTable -> find ( $reference );
if ( $commandeRowset -> count () > 0 )
{
$commande = $commandeRowset -> current ();
switch ( $commande -> type )
{
case 'pieces' :
$infoCommandePieces = $commande -> findDependentRowset ( 'Application_Model_CommandesPieces' );
if ( $infoCommandePieces -> count () > 0 )
{
//Update informations pieces
$commandePieces = $infoCommandePieces -> current ();
$commandePieces -> fichier = $filename ;
$commandePieces -> save ();
//Mettre à jour la commande
$commande -> date_updated = date ( 'Y-m-d H:i:s' );
$commande -> save ();
//Mettre à jour les évenements de commande
//@todo
return true ;
}
break ;
case 'default' :
return false ;
break ;
}
} else {
return false ;
}
}
catch ( Zend_Db_Adapter_Exception $e )
{
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
return false ;
}
}
/**
* Enregistre une action utilisateur pour la facturation
* @ param string $page
* @ param string $siret
* @ param int $id
* @ param string $ref
* @ return void
*/
public function setLog ( $page , $siret , $id = 0 , $ref = '' )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $id )) $id = 0 ;
if ( empty ( $ref )) $ref = '' ;
if ( $id != 0 ) {
$ref2 = '' . $id . '/' . $ref ;
} else {
$ref2 = $ref ;
}
$this -> wsLog ( $page , $siret , $ref2 );
debugLog ( 'I' , " Insertion d'un log pour la page $page $siret $ref2 " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
}
/**
* Met a jour les informations sur un mandataire
* @ param SetInfosMandataire $infos Informations sur le mandataire à créer ou à ajouter ( ajout si id absent )
* @ return SetMandataireReturn
**/
public function setMandataire ( SetInfosMandataire $infos )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$result = true ;
$iDb = new WDB ();
/** Nom et Identifiant de l'opérateur de saisie **/
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'utilisateurs' , 'id' , " login=' " . $this -> tabInfoUser [ 'login' ] . " ' " );
$idUser = $rep [ 0 ][ 0 ];
//$infos = serialize($tabInfos);
debugLog ( 'I' , " Ajout/MAJ de mandaitaire " . print_r ( $infos , 1 ) . " demandée " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$type = substr ( strtoupper ( $infos -> type ), 0 , 1 );
$stag = substr ( strtoupper ( $infos -> type ), 1 , 1 );
if ( $stag == 'S' ) { $stag = 1 ; } else { $stag = 0 ; }
if ( $type == 'A' || $type == 'H' || $type == 'M' || $type == 'V' ||
$type == 'N' || $type == 'T' )
{
$tabUpdate = array (
'sirenGrp' => substr ( $infos -> sirenGrp , 0 , 9 ) * 1 ,
'nicGrp' => substr ( $infos -> sirenGrp , 9 , 5 ) * 1 ,
'sirenMand' => substr ( $infos -> sirenMand , 0 , 9 ) * 1 ,
'nicMand' => substr ( $infos -> sirenMand , 9 , 5 ) * 1 ,
'Nom' => ucwords ( strtolower ( $infos -> Nom )),
'Prenom' => ucwords ( strtolower ( $infos -> Prenom )),
'type' => $type ,
'stagiaire' => $stag ,
'coursAppel' => intval ( $infos -> coursAppel ),
'coursAppel2' => intval ( $infos -> coursAppel2 ),
'tribunal' => $infos -> tribunal ,
'Statut' => strtoupper ( $infos -> Statut ),
'adresse' => ucwords ( $infos -> adresse ),
'adresseComp' => strtoupper ( $infos -> adresseComp ),
'cp' => intval ( $infos -> cp ),
'ville' => strtoupper ( $infos -> ville ),
'tel' => $infos -> tel ,
'fax' => $infos -> fax ,
'email' => $infos -> email ,
'web' => $infos -> web ,
'contact' => $infos -> contact ,
'idUser' => $idUser ,
);
}
$id = str_replace ( 'm' , '' , '' . $infos -> id ) * 1 ;
if ( intval ( $id ) != 0 ) {
// MAJ
if ( ! $iDb -> update ( 'tabMandataires' , $tabUpdate , " id= $id " , true )) {
$error -> errnum = 1 ;
$error -> errmsg = 'Mise a jour impossible' ;
$result = false ;
}
} else {
// Insertion
if ( ! $iDb -> insert ( 'tabMandataires' , array_merge ( $tabUpdate , array ( 'dateInsert' => date ( 'YmdHis' ))), true )) {
$error -> errnum = 1 ;
$error -> errmsg = 'Insertion impossible' ;
$result = false ;
}
}
$output = new SetMandataireReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Récupère le mandataire par son id
* @ param int $idMand Identifiant du mandataire
* @ return MandataireReturn
*/
public function getMandataire ( $idMand )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
debugLog ( 'I' , " Donne le Mandataires correspondant à $idMand " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iInsee = new classMInsee ();
$tabRet = $iInsee -> getMandataire ( $idMand );
$mandataire = new MandataireDetail ();
$mandataire -> Nom = $tabRet [ 'Nom' ];
$mandataire -> Prenom = $tabRet [ 'Prenom' ];
$mandataire -> tribunal = $tabRet [ 'tribunal' ];
$mandataire -> adresse = $tabRet [ 'adresse' ];
$mandataire -> adresseComp = $tabRet [ 'adresseComp' ];
$mandataire -> ville = $tabRet [ 'ville' ];
$mandataire -> email = $tabRet [ 'email' ];
$mandataire -> web = $tabRet [ 'web' ];
$mandataire -> contact = $tabRet [ 'contact' ];
$output = new MandataireReturn ();
$output -> error = $error ;
$output -> result = $mandataire ;
return $output ;
}
/**
* Liste les mandataires compétentes pour une cours d ' appel donnée
* @ param mixed $codeTribunal Identifiants BODACC du tribunal ou tableau d 'Identifiants numériques des cours d' appel
* @ param array $type Type de mandataire ( A ) dministrateur , ( M ) andataire , ( O ) ppositions , ( N ) otaires , a ( V ) ocat
* @ return MandatairesReturn
*/
public function getMandataires ( $codeTribunal = 0 , $type = array ( 'A' , 'M' ))
{
$this -> authenticate ();
//Initialisation
$iInsee = new MInsee ();
$error = new ErrorType ();
$trib = serialize ( $codeTribunal );
debugLog ( 'I' , " Liste des Mandaitaires ou Administrateur du Tribunal/Cours d'Appel $trib demandé " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( ! is_array ( $codeTribunal ) && strlen ( $codeTribunal ) > 3 && $codeTribunal * 1 == 0 )
{
// $codeTribunal est un identifiant de tribunal
$iBodacc = new MBodacc ();
$tabTmp = $iInsee -> getMandataires ( array ( $iBodacc -> getTribunalIdCA ( $codeTribunal )), true , $type );
}
elseif ( $codeTribunal * 1 == 0 )
{
// On veut tous les mandataires
$tabTmp = $iInsee -> getMandataires ( array (), true , $type );
}
elseif ( is_array ( $codeTribunal ))
{
// On veut les mandataires d'une CA
$tabTmp = $iInsee -> getMandataires ( $codeTribunal , true , $type );
}
$tabRet = array ();
foreach ( $tabTmp as $i => $mand ){
$mandataire = new Mandataire ();
$mandataire -> id = 'm' . $i ;
$mandataire -> mand = $mand ;
$tabRet [] = $mandataire ;
}
$output = new MandatairesReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
2012-07-17 06:22:32 +00:00
}
2012-03-29 13:07:10 +00:00
/**
* Retourne la liste des conventions
* @ param string $siren
* @ return ListeConventionsReturn
*/
public function getListeConventions ( $siren )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$tabRet = array ();
debugLog ( 'I' , " Liste des conventions demandée pour le siren $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( strlen ( $siren ) <> 9 ){
debugLog ( 'W' , " Siren/Siret $siren incorrect " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 102 ;
$error -> errmsg = 'Siren Siret inexistant' ;
} elseif ( $siren * 1 == 0 ){
debugLog ( 'W' , " Siren $siren inexistant " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 102 ;
$error -> errmsg = 'Siren inexistant' ;
} else {
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteEntreprise ( $siren );
if ( empty ( $tabIdentite ) && isset ( $tabIdentite [ 'erreur' ]) &&
$tabIdentite [ 'erreur' ] <> '' ){
debugLog ( 'W' , " Siren $siren non présent en base " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 102 ;
$error -> errmsg = 'Siren inexistant' ;
} else {
$naf = $tabIdentite [ 'NafEnt' ];
$trancheEffectif = $tabIdentite [ 'EffEnTr' ];
$effectif = $tabIdentite [ 'Effectif' ];
$fj = $tabIdentite [ 'entreprise' ][ 'FJCodeEntrep' ];
$isolv = new MSolvabilite ( $siren , $naf , $trancheEffectif ,
$effectif , $tabIdentite [ 'CP' ], $fj , $tabIdentite [ 'Capital' ],
$tabIdentite [ 'CapitalDev' ], $tabIdentite [ 'DateCreaEn' ],
$tabIdentite [ 'DateCreaEt' ]
);
$noteStructure = $isolv -> getSolvabilite ();
$naf4 = $isolv -> getNaf4 ( $naf );
$tabTmp = $iInsee -> listeConventions ( $naf4 , $tabIdentite [ 'Dept' ]);
foreach ( $tabTmp as $conv )
{
$convention = new Convention ();
$convention -> idCC = $conv [ 'id CC' ];
$convention -> nomCC = $conv [ 'nom CC' ];
$convention -> infoCC = $conv [ 'infoCC' ];
$convention -> editorCC = $conv [ 'editeur CC' ];
$convention -> nbPageCC = $conv [ 'nb page CC' ];
$convention -> isbnCC = $conv [ 'isbn CC' ];
$convention -> dateCC = $conv [ 'date edition CC' ];
$convention -> joCCmaj = $conv [ 'joCCmaj' ];
$tabRet [] = $convention ;
}
$this -> wsLog ( 'conventions' , $siren );
}
}
$output = new ListeConventionsReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* Donne la cours d 'appel d' un tribunal par son code
* @ param string $codeTribunal Code BODACC sur 6 caractères du tribunal
* @ return int
**/
public function getIdCoursAppel ( $codeTribunal )
{
$this -> authenticate ();
$iBodacc = new MBodacc ();
return $iBodacc -> getTribunalIdCA ( $codeTribunal );
}
/**
* Récupère le contenu d ' une annonce issue de la collecte
* @ param string $idAnn
* @ param string $siret
* @ return AnnonceCollecteReturn
*/
public function getAnnonceCollecte ( $idAnn , $siret )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$annonceCollecte = new AnnonceCollecte ();
$siren = substr ( $siret , 0 , 9 ) * 1 ;
2012-08-06 08:24:38 +00:00
if ( $this -> checkEdition ()) {
2012-03-29 13:07:10 +00:00
$error -> errnum = 0 ;
$error -> errmsg = 'Code Client Incorrect' ;
} else {
$iDb = new WDB ();
debugLog ( 'I' , " Lecture de l'annonce collectée n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$idAnn = preg_replace ( '/^0\./' , '' , '' . $idAnn ) * 1 ;
if ( $idAnn > 0 )
{
$res = $iDb -> select ( 'annonces' ,
'id, siren, sirenValide, typeEven, strEven, raisonSociale, adresse, codePostal, ville, dateJugement, dateCessationPaiement, dateEffetFinP, numero, inter1type, inter1id, inter1nom, inter2type, inter2id, inter2nom, inter3type, inter3id, inter3nom, inter4type, inter4id, inter4nom, tribunal, montant, actionsNb, complement, infosBrutes, nouvActivite, nouvDir, nouvAdr, nouvFJ, annonce, source, parutionIdJal, parutionNum, dateSource, idSaisie, idAnnonce, dateInsert' ,
" id= $idAnn " , false , MYSQL_ASSOC
);
if ( count ( $res ) > 0 )
{
$ann = $res [ 0 ];
$annonceCollecte -> id = $ann [ 'id' ];
$annonceCollecte -> siren = $ann [ 'siren' ];
$annonceCollecte -> raisonSociale = $ann [ 'raisonSociale' ];
$annonceCollecte -> adresse = $ann [ 'adresse' ];
$annonceCollecte -> codePostal = $ann [ 'codePostal' ];
$annonceCollecte -> ville = $ann [ 'ville' ];
$annonceCollecte -> dateJugement = $ann [ 'dateJugement' ];
//@todo : Les libellées ne sont pas présent LibEven
$tabEven = array ();
$annonceEvenement = new AnnonceEvenement ();
$annonceEvenement -> CodeEven = $ann [ 'typeEven' ];
$annonceEvenement -> LibEven = '' ;
$tabEven [] = $annonceEvenement ;
if ( ! empty ( $ann [ 'strEven' ])){
foreach ( explode ( ';' , $ann [ 'strEven' ]) as $code )
{
$annonceEvenement = new AnnonceEvenement ();
$annonceEvenement -> CodeEven = $code ;
$annonceEvenement -> LibEven = '' ;
$tabEven [] = $annonceEvenement ;
}
}
$annonceCollecte -> even = $tabEven ;
$annonceCollecte -> dateSource = $ann [ 'dateSource' ];
$annonceCollecte -> dateCessationPaiement = $ann [ 'dateCessationPaiement' ];
$annonceCollecte -> dateEffetFinP = $ann [ 'dateEffetFinP' ];
$annonceCollecte -> tribunal = $ann [ 'tribunal' ];
$annonceCollecte -> numero = $ann [ 'numero' ];
$annonceCollecte -> montant = $ann [ 'montant' ];
$annonceCollecte -> actionsNb = $ann [ 'actionsNb' ];
$annonceCollecte -> inter1type = $ann [ 'inter1type' ];
$annonceCollecte -> inter1id = $ann [ 'inter1id' ];
$annonceCollecte -> inter1nom = $ann [ 'inter1nom' ];
$annonceCollecte -> inter2type = $ann [ 'inter2type' ];
$annonceCollecte -> inter2id = $ann [ 'inter2id' ];
$annonceCollecte -> inter2nom = $ann [ 'inter2nom' ];
$annonceCollecte -> inter3type = $ann [ 'inter3type' ];
$annonceCollecte -> inter3id = $ann [ 'inter3id' ];
$annonceCollecte -> inter3nom = $ann [ 'inter3nom' ];
$annonceCollecte -> complement = $ann [ 'complement' ];
$annonceCollecte -> nouvActivite = $ann [ 'nouvActivite' ];
$annonceCollecte -> nouvDir = $ann [ 'nouvDir' ];
$annonceCollecte -> nouvAdr = $ann [ 'nouvAdr' ];
$annonceCollecte -> nouvFJ = $ann [ 'nouvFJ' ];
$annonceCollecte -> source = $ann [ 'source' ];
debugLog ( 'I' , " Lecture de l'annonce collectée n° $idAnn ( $siret ) : " . $ann [ 'raisonSociale' ], __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
} else {
$error -> errnum = 1 ;
$error -> errmsg = 'Edition impossible' ;
}
}
else
{
$error -> errnum = 745741 ;
$error -> errmsg = 'Selection impossible' ;
}
}
$output = new AnnonceCollecteReturn ();
$output -> error = $error ;
$output -> result = $annonceCollecte ;
return $output ;
}
/**
* getDevises
* @ param string $codeIsoDevise
* @ return DevisesReturn
*/
public function getDevises ( $codeIsoDevise = '' )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( empty ( $codeIsoDevise )) $codeIsoDevise = '' ;
debugLog ( 'I' , " Liste des devises ou devise $codeIsoDevise demandée " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iInsee = new MInsee ();
$tabTmp = $iInsee -> getDevises ( $codeIsoDevise );
$tabRet = array ();
foreach ( $tabTmp as $i => $dev )
{
if ( $i != '' ){
$devise = new Devise ();
$devise -> devIso = $i ;
$devise -> devNom = $dev ;
$tabRet [] = $devise ;
}
}
$output = new DevisesReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* Retourne la liste des codes devises , libellés , date et valeur
* ( toutes les devises ou une seule )
* @ param string $devise Devise sur 3 lettres ( facultatif )
* @ return DevisesCoursReturn
*/
public function getDeviseCours ( $devise = false )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$iDb = new WDB ( 'sdv1' );
if ( $devise ) $strDevise = " AND c.devise=' $devise ' " ;
else $strDevise = '' ;
$tabRet = array ();
$res = $iDb -> select ( 'devise_cours c, devise_liste l' , 'c.devise, l.devNom, max(c.date) as dateChange, c.valeur' , " c.devise=l.devIso $strDevise GROUP BY c.devise ORDER BY c.devise ASC " , false , MYSQL_ASSOC );
foreach ( $res as $tabDev )
{
$devise = new DevisesCours ();
$devise -> codeDevise = $tabDev [ 'devise' ];
$devise -> nomDevise = $tabDev [ 'devNom' ];
$devise -> dateChange = $tabDev [ 'dateChange' ];
$devise -> valeurDevise = $tabDev [ 'valeur' ];
$tabRet [] = $devise ;
}
$output = new DevisesCoursReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* getMarques
* @ param string $siren
* @ param int $idDepot
* @ return MarquesReturn
*/
public function getMarques ( $siren , $idDepot = 0 )
{
$this -> authenticate ();
$this -> permission ( 'marques' );
debugLog ( 'I' , " Liste des marques déposées pour le siren $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( empty ( $idDepot )) $idDepot = 0 ;
$error = new ErrorType ();
$marques = array ();
require_once 'Metier/partenaires/classMMarques.php' ;
$iMarque = new MMarques ();
$ret = $iMarque -> getMarques ( $siren , $idDepot );
foreach ( $ret as $item ) {
if ( trim ( $item [ 'imgLink' ]) <> '' ) $idLien = $item [ 'numeroMarque' ];
else $idLien = '' ;
if ( $idDepot == $item [ 'numeroMarque' ]) {
$marque = new Marque ();
$marque -> Marques = $item [ 'nomMarque' ];
$marque -> Date = $item [ 'dateDepot' ];
$marque -> Depot = $item [ 'numeroMarque' ];
$marque -> IdLien = $idLien ;
$marque -> UrlLien = $item [ 'UrlLien' ];
$marque -> PdfDispo = $item [ 'pdfLink' ];
$marque -> Classes = $item [ 'classesMarque' ];
$marque -> Perimetre = $item [ 'periMarque' ];
$marque -> DateExpir = $item [ 'dateExpir' ];
$marques = array ();
$marques [] = $marque ;
break ;
} else {
$marque = new Marque ();
$marque -> Marques = $item [ 'nomMarque' ];
$marque -> Date = $item [ 'dateDepot' ];
$marque -> Depot = $item [ 'numeroMarque' ];
$marque -> IdLien = $idLien ;
$marque -> UrlLien = $item [ 'UrlLien' ];
$marque -> PdfDispo = $item [ 'pdfLink' ];
$marques [] = $marque ;
}
}
Zend_Registry :: get ( 'WsLogger' ) -> info ( __FUNCTION__ . ' : ' .
print_r ( $marques , 1 ));
$this -> wsLog ( 'marques' , $siren );
$output = new MarquesReturn ();
$output -> error = $error ;
$output -> result = $marques ;
return $output ;
}
/**
* Enter description here ...
* @ param string $siren
* @ param string $piece
* @ param string $type
* @ param integer $visu
* @ param integer $courrier
* @ param string $ref
* @ return PieceReturn
*/
public function getPiece ( $siren , $piece = 'kbis' , $type = '' , $visu = 1 , $courrier = 0 , $ref = '' )
{
$this -> authenticate ();
$this -> permission ( 'kbis' );
set_time_limit ( 400 );
if ( empty ( $piece )) $piece = 'kbis' ;
if ( empty ( $type )) $type = '' ;
if ( empty ( $visu )) $visu = 1 ;
if ( empty ( $courrier )) $courrier = 1 ;
if ( empty ( $ref )) $ref = '' ;
$error = new ErrorType ();
$erreur = false ;
$kbisLocalPDF = DOC_WEB_LOCAL . " kbis/ $piece - $siren .pdf " ;
if ( file_exists ( $kbisLocalPDF )
&& date ( 'Ymd' , filemtime ( $kbisLocalPDF )) == date ( 'Ymd' )
&& filesize ( $kbisLocalPDF ) > 0 ) {
$size = filesize ( $kbisLocalPDF );
$erreur = false ;
$tabNom = array ();
$ficDist = '' ;
$cache = 1 ;
} else {
exec ( " php " . APPLICATION_PATH . " /../batch/getPieces.php $siren $piece > /dev/null & " );
$ficDist = '' ;
$size = $cache = 0 ;
}
// On supprimer l'ancien kbis si trop vieux ou vide
if ( date ( 'Ymd' , filemtime ( $kbisLocalPDF )) <> date ( 'Ymd' )
|| filesize ( $kbisLocalPDF ) == 0 ) {
unlink ( $kbisLocalPDF );
}
$result = new PieceResult ();
$result -> Siren = $siren ;
//@todo : Envoyer vers controlleur
$hostname = 'http://' . $_SERVER [ 'SERVER_NAME' ];
if ( $_SERVER [ 'SERVER_PORT' ] != '80' ){
$hostname .= ':' . $_SERVER [ 'SERVER_PORT' ];
}
$result -> Url = $hostname . '/data/kbis/' . $piece . '-' . $siren . '.pdf' ;
$result -> Taille = $size ;
$result -> Cache = $cache ;
$result -> fichier = $ficDist ;
$this -> wsLog ( 'kbis' , $siren , " $cache / $visu / $courrier / $type / $ref " );
$output = new PieceReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Enregistrement de document actes ou status d ' association
* @ param string $siren Numéro Siren
* @ param string $waldec Numéro waldec
* @ param string $type Type d ' acte
* @ param string $libelle Libellé de l ' acte
* @ param string $date Date des l ' acte au format
* @ param int $nbPages Nombre de pages dans le fichier
* return boolean
*/
public function setActeAsso ( $siren , $waldec , $type , $libelle , $date , $nbPages )
{
$this -> authenticate ();
2012-08-06 08:24:38 +00:00
if ( $this -> checkEdition ()) {
2012-03-29 13:07:10 +00:00
$this -> sendError ( '0902' );
}
( $type == 'ST' ) ? $type_acte = 'ST' : $type_acte = '' ;
$data = array (
'siren' => $siren ,
'waldec' => waldec ,
'pdfLink' => '' ,
'pdfSize' => '' ,
'pdfVer' => '' ,
'pdfPage' => '' ,
'date_acte' => WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , $date ),
'type_acte' => $type_acte ,
'type_acte_libelle' => $libelle ,
'nbpages_acte' => $nbPages ,
);
try {
$db = Zend_Db :: factory ( $this -> dbConfig -> Webservice );
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
$doc = new Application_Model_AssoActes ();
$doc_id = $doc -> insert ( $data );
} catch ( Zend_Exception $e ) {
Zend_Registry :: get ( 'WsLogger' )
-> err ( __FUNCTION__ . ' - ' . $e -> getMessage ());
}
if ( $commande_id )
{
return true ;
}
return false ;
}
/**
* Commande de statut association
* @ param InfoCmdAsso $infosCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdAssoReturn
*/
public function setCmdAsso ( $infosCommande , $infosDemandeur )
{
$this -> authenticate ();
$this -> permission ( 'actes' );
//Initialisation
$error = new ErrorType ();
$iDb = new WDB ();
$siren = $infosCommande -> siren ;
$idEntreprise = intval ( $infosCommande -> idEntreprise );
$assoNom = $infosCommande -> raisonSociale ;
debugLog ( 'I' , " commandeAsso pour $assoNom ( $siren ) début " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $siren , 0 , $idEntreprise );
$assoSigle = $tabIdentite [ 'Sigle' ];
$assoAdresse = $tabIdentite [ 'Adresse' ] . EOL . $tabIdentite [ 'Adresse2' ];
$assoCP = $tabIdentite [ 'CP' ];
$assoVille = $tabIdentite [ 'Ville' ];
$mail = trim ( $infosDemandeur -> email );
if ( $mail == '' ) $mail = $this -> tabInfoUser [ 'email' ];
$tabInsert = array (
'idUser' => $this -> tabInfoUser [ 'id' ],
'source' => 'asso' ,
'login' => $this -> tabInfoUser [ 'login' ],
'emailCommande' => $mail ,
'siren' => $siren ,
'refUtilisateur' => $infosDemandeur -> reference ,
'refDocument' => serialize ( $infosDemandeur ),
'refCommande' => serialize ( $infosCommande ),
'dateCommande' => DATETIME ,
);
2012-04-24 07:04:54 +00:00
$iDbCrm = new WDB ( 'sdv1' );
$ret = $iDbCrm -> insert ( 'commandes' , $tabInsert , true );
if ( $ret != 0 ) {
sendMail ( 'production@scores-decisions.com' , 'asso@scores-decisions.com' ,
" Commande de statuts association pour $assoNom ( $siren ) " ,
" Association : " . EOL . print_r ( $infosCommande , true ) . EOL . EOL .
" Demandeur: " . EOL . print_r ( $infosDemandeur , true ) . EOL . EOL .
" Ref : i " . $ret
2012-03-29 13:07:10 +00:00
);
2012-04-24 07:04:54 +00:00
$result = new CmdAssoDetail ();
$result -> siren = $siren ;
$result -> emailCommande = $mail ;
$result -> dateCommande = DATETIME ;
$result -> refCmd = 'i' . $ret ;
2012-07-17 06:22:32 +00:00
sendMail ( 'production@scores-decisions.com' , $mail ,
" Votre commande de statuts association sur $assoNom ( $siren ) " ,
2012-04-24 07:04:54 +00:00
" Votre demande de statuts sur l'association $assoNom a été prise en compte sous la référence i $ret - " . DATETIME );
$this -> wsLog ( 'commandeAsso' , $siren , 'i' . $ret . '-' . DATETIME );
2012-07-17 06:22:32 +00:00
debugLog ( 'I' , " commandeAsso pour $assoNom ( $siren ) fin " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
2012-04-24 07:04:54 +00:00
2012-03-29 13:07:10 +00:00
} else {
$error -> errnum = 1 ;
2012-04-24 07:04:54 +00:00
$error -> errmsg = 'Erreur' ;
2012-03-29 13:07:10 +00:00
}
2012-04-24 07:04:54 +00:00
2012-03-29 13:07:10 +00:00
$output = new CmdAssoReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Renvoi des informations sur une commande association
* @ param string $reference
* @ return CmdAssoReturn
*/
public function getCmdAsso ( $reference ){}
/**
* Commande d 'une enquête sur une entreprise en France ou à l' Internationale
* @ param InfosCmdEnquete $infosCommande
* @ param InfosDemandeur $infosDemandeur
* @ return CmdEnqueteReturn
**/
public function setCmdEnquete ( $infosCommande , $infosDemandeur )
{
$this -> authenticate ();
$this -> permission ( 'enquetec' );
//Initialisation
$error = new ErrorType ();
$siren = $infosCommande -> siren ;
$mail = trim ( $infosDemandeur -> email );
if ( $mail == '' ) $mail = $this -> tabInfoUser [ 'email' ];
$tabInsert = array (
'idUser' => $this -> tabInfoUser [ 'id' ],
'source' => 'intersud' , // 'greffes', 'asso', 'graydon'
'login' => $this -> tabInfoUser [ 'login' ],
'emailCommande' => $mail ,
'siren' => $siren ,
'refDocument' => serialize ( $infosDemandeur ),
'refCommande' => serialize ( $infosCommande ),
'dateCommande' => DATETIME ,
);
debugLog ( 'I' , " Intersud, début sur $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$messageInfo = print_r ( $infosCommande , 1 ) . EOL . print_r ( $infosDemandeur , 1 ) . EOL ;
$idClient = $this -> tabInfoUser [ 'idClient' ];
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'clients' , ' nom, racineLogin, InterSudLogin, InterSudPass' , " id=' $idClient ' " , false , MYSQL_ASSOC );
$login = trim ( $rep [ 0 ][ 'InterSudLogin' ]);
$pass = trim ( $rep [ 0 ][ 'InterSudPass' ]);
$nomClient = trim ( strtoupper ( $rep [ 0 ][ 'nom' ]));
$strInfoCommande = " NOM et Prénom du client demandeur : " . $infoDemandeur -> nom . EOL ;
$strInfoCommande .= " Email du client demandeur : $mail " . EOL ;
$strInfoCommande .= " Tel/Fax du demandeur : " . $infosDemandeur -> tel . ' / ' . $infosDemandeur -> fax . EOL ;
$strInfoCommande .= " Profil du demandeur : " . trim ( $infosDemandeur -> service ) . EOL ;
$typeEnqLog = 'enqueteDemNF' ;
if ( $login == '' || $pass == '' ) {
/** Il ne s'agit pas d'un client final, on anonymise la commande **/
$login = 'YLENA' ; // Demandes en test
$pass = 'WYLFE' ;
$nomClient = $strInfoCommande = '' ;
$typeEnqLog = 'enqueteDem' ;
/* ENQUETES EN PROD
$login = 'FACTURE' ;
$pass = 'AWKROM' ;
*/
}
$url = 'http://www.intersud.fr/espace_client/espace_client.php' ;
$cookie = $referer = '' ;
$tabPost = array ( 'login' => $login , 'pwd' => $pass );
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , $tabPost , $referer , false , '' , '' , 7 );
if ( $page [ 'code' ] <> 200 ) {
$tabRet = array ();
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ATTENTION : Commande d'enquete sur $siren " , " Connexion impossible à la plateforme Intersud " . EOL . $strInfoCommande );
// wsLog($typeEnqLog, $siren, 'i'.$ret.'-'.DATETIME);
//@todo
return array ( 'error' => array ( 'errnum' => 4563456 , 'errmsg' => 'Connexion impossible à la plateforme d\'enquetes' ), 'results' => $tabRet );
}
$tfin = microtime ( true );
$duree = $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
$cookie = $page [ 'header' ][ 'Set-Cookie' ];
/** Connexion à l ' Extranet Intersud
**/
$url = 'http://intersud.fr/espace_client/demande_enquete.php' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , '' , $referer , false , '' , '' , 7 );
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
2012-07-17 06:22:32 +00:00
$fp =@ fopen ( LOG_PATH . " /intersud.log " , " a " );
2012-03-29 13:07:10 +00:00
@ fwrite ( $fp , print_r ( $page , true ));
@ fclose ( $fp );
$tabInterSud = array ();
if ( preg_match_all ( '/<input(?:.*)name="(.*)"(?:.*)value="(.*)"/Uim' , $body , $matches )) {
foreach ( $matches [ 1 ] as $i => $field ) {
$tmp = explode ( '"' , $matches [ 2 ][ $i ]);
$tabInterSud [ $field ] = $tmp [ 0 ];
}
}
if ( preg_match_all ( '/<input(?:.*)value="(.*)"(?:.*)name="(.*)"/Uim' , $body , $matches )) {
foreach ( $matches [ 2 ] as $i => $field ) {
$tmp = explode ( '"' , $matches [ 1 ][ $i ]);
$tabInterSud [ $field ] = $tmp [ 0 ];
}
}
$ref_exp = $tabInterSud [ 'ref_exp' ];
$email_exp = $tabInterSud [ 'email_exp' ];
$tel_exp = $tabInterSud [ 'tel_exp' ];
debugLog ( 'I' , " Intersud, formulaire enquête ref $ref_exp , $email_exp , $tel_exp " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
2012-07-17 06:22:32 +00:00
$fp =@ fopen ( LOG_PATH . " /intersud.log " , " a " );
2012-03-29 13:07:10 +00:00
@ fwrite ( $fp , print_r ( $matches , true ));
@ fwrite ( $fp , print_r ( $tabInterSud , true ));
@ fclose ( $fp );
/** Insertion de la commande en base
**/
$ret = $iDbCrm -> insert ( 'commandes' , $tabInsert , true );
$comment = " Référence de la commande chez Scores et Décisions : i $ret - " .
DATETIME . " \n " .
" Date et heure de la commande : " . date ( 'd/m/Y - H:i' ) . " \n " .
" Origine de la commande : $nomClient " .
" $strInfoCommande " . " \n \n " .
" CA : " . $infosCommande -> PrecisionsMontantCA . " \n " .
" Motif de la demande : " . trim ( $infosCommande -> PrecisionsMotif . ' ' . $infosCommande -> PrecisionsAutre ) . " \n " .
" Type de la demande : " . $infosCommande -> PrecisionsType . " \n " .
" Anciennete de la relation : " . $infosCommande -> Anciennete . ' ' . $infosCommande -> AncienneteDuree . " \n " .
" Observations : " . $infosCommande -> Observation . EOL ;
if ( $infosCommande -> ImpayeesChoix <> 'non' )
$comment .= " Impayé(s) : " . $infosCommande -> ImpayeesNombre . " impayé(s) pour un montant de " . $infosCommande -> ImpayeesMontant . " en date du " . $infosCommande -> ImpayeesDate . EOL ;
if ( $infosCommande -> RetardPaiementChoix <> 'non' )
$comment .= " Retard(s) de paiement : " . $infosCommande -> RetardPaiementNombre . " retard(s) pour un montant de " . $infosCommande -> RetardPaiementMontant . " en date du " . $infosCommande -> RetardPaiementDate . EOL ;
if ( $infosCommande -> LitigeChoix <> 'non' )
$comment .= " Présence de litige(s) : " . $infosCommande -> LitigePrecisions . EOL ;
$enqType = 0 ;
$enqDelai = 7 ;
switch ( strtolower ( $infosCommande -> Type )) {
case 'premier' : $enqType = 0 ; $enqDelai = 6 ; break ;
case 'gold' : $enqType = 1 ; break ;
case 'distrimat' : $enqType = 2 ; break ;
case 'star' : $enqType = 3 ; break ;
case 'avis_bancaire' : $enqType = 4 ; break ;
case 'autre' : $enqType = 5 ; break ;
}
/** Ajout du RIB si communiqué **/
if ( @ trim ( implode ( ' ' , $infosCommande -> RIB )) <> '' )
$iDbCrm -> insert ( 'banques' , array (
'siren' => $siren ,
'libBanqueGuichet' => '' ,
'precis' => 1 ,
'codeBanque' => $infosCommande -> RIB -> banque ,
'codeGuichet' => $infosCommande -> RIB -> guichet ,
'numCompte' => $infosCommande -> RIB -> compte . $infosCommande -> RIB -> cle ,
'dateSource' => DATETIME ,
), true );
/** Remplissage du formulaire d'enquête pour soumission à Intersud **/
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $siren );
$tabPost = array (
'soc' => $tabIdentite [ 'Nom' ],
'cible_enk' => 9 , // 9
'siret' => $siren ,
'acti' => '' ,
'soc_exp' => $tabInterSud [ 'soc_exp' ],
'type_enk' => $enqType , // 0=Premier, 1=Gold, 2=Distrimat, 3=Star, 4=Avis bancaire, 5=Autre
'nom_diri' => '' ,
'adr' => $tabIdentite [ 'Adresse' ],
'ref_exp' => $tabInterSud [ 'ref_exp' ],
'autre_type_enk' => '' , // Texte libre
'adr2' => $tabIdentite [ 'Adresse2' ],
'delai_enk' => $enqDelai , // 6=24h, 7=72h, 8=+de5jours
'ville' => $tabIdentite [ 'Ville' ],
'cp' => $tabIdentite [ 'CP' ],
'pays' => '' , // International ?
'nom_exp' => $tabInterSud [ 'nom_exp' ],
'tel' => $tabIdentite [ 'Tel' ],
'port' => $infosCommande -> AutreTel ,
'tel_exp' => $tabInterSud [ 'tel_exp' ],
'bank' => trim ( implode ( ' ' , $infosCommande -> RIB )),
'int_enk' => $tabInterSud [ 'int_enk' ], // International ?
'encours' => $infosCommande -> Encours ,
'nb_ech' => $infosCommande -> NbEcheances ,
'delai2_enk' => $tabInterSud [ 'delai2_enk' ], // International ?
'email_exp' => $tabInterSud [ 'email_exp' ],
'cred' => '' ,
'comment' => urlencode ( $comment ),
'val_ret' => $tabInterSud [ 'val_ret' ],
);
$url = 'http://intersud.fr/espace_client/demande_enquete.php' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , $tabPost , $referer , false , '' , '' , 7 );
if ( $page [ 'code' ] <> 200 ) {
$tabRet = array ();
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ATTENTION : Commande d'enquete sur $siren " , " Validation impossible du formulaire d'enquête Intersud " . EOL . $strInfoCommande );
//@todo
return array ( 'error' => array ( 'errnum' => 456345 , 'errmsg' => 'Connexion impossible à la plateforme d\'enquetes 3' ), 'results' => $tabRet );
}
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
$result = new CmdEnquete ();
$result -> siren = $siren ;
$result -> emailCommande = $mail ;
$result -> dateCommande = DATETIME ;
$result -> refCmd = 'i' . $ret ;
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " Commande d'enquete sur $siren " , $comment . EOL . EOL . '---------------------------------' . EOL . $messageInfo . EOL . EOL . '---------------------------------' . EOL . $body );
@ sendMail ( 'production@scores-decisions.com' , $mail , " Votre demande d'enquete sur " . $tabIdentite [ 'Nom' ] . " ( $siren ) " , " Votre demande d'enquête sur la société " . $tabIdentite [ 'Nom' ] . " a été prise en compte sous la référence i $ret - " . DATETIME );
$this -> wsLog ( $typeEnqLog , $siren , 'i' . $ret . '-' . DATETIME );
/** Gestion de la déconnexion **/
$url = 'http://intersud.fr/espace_client/index.php?code_ret=9' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , '' , $referer , false , '' , '' , 7 );
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$ret = $iDbCrm -> update ( 'commandes' , array ( 'dureeCommande' => round ( $duree , 3 )), " idCommande= $ret " );
$output = new CmdEnqueteReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Récupération d ' un kbis
* @ param string $siren
* @ param int $visu
* @ param int $courrier
* @ param string $mail
* @ param string $ref
* @ return PieceReturn
*/
public function getKbis ( $siren , $visu = 1 , $courrier = 0 , $mail = '' , $ref = '' )
{
return $this -> getPiece ( $siren , 'kbis' , '' , $visu , $courrier , $ref );
}
/**
* getStatsUtilisateurs
* @ param string $login
* @ param string $mois
* @ param string $type
* @ param boolean $payants
* @ return array
*/
public function getStatsUtilisateurs ( $login , $mois , $type = 'jour' , $payants = false )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( $payants )
{
$strPayant = " AND (page LIKE 'greffe_%' OR page LIKE 'inpi_%' OR page='kbis') AND params<>'' AND (params NOT LIKE '%erreur%' OR params LIKE '%erreur 17%') " ;
}
else {
$strPayant = '' ;
}
$iDbCrm = new WDB ( 'sdv1' );
if ( $type == 'jour' ) {
$rep = $iDbCrm -> select ( 'logs' ,
'date(dateHeure) as jours, count(*) as nb' ,
" 1 $strPayant AND login=' $login ' AND dateHeure BETWEEN ' $mois -01' AND ' $mois -31' GROUP BY jours " ,
false , MYSQL_ASSOC );
} elseif ( $type == 'heure' ) {
$rep = $iDbCrm -> select ( 'logs' ,
'HOUR(dateHeure) as heures, count(*) as nb' ,
" 1 $strPayant AND login=' $login ' AND dateHeure BETWEEN ' $mois -01' AND ' $mois -31' GROUP BY heures " ,
false , MYSQL_ASSOC );
}
$tabRet = $rep ;
return array ( 'error' => array ( 'errnum' => 0 , 'errmsg' => '' ), 'results' => $tabRet );
}
/**
* getPortefeuilleCsv
* @ param string $login
* @ param int $idClient
* @ return ListeSurveillancesCsvReturn
*/
public function getPortefeuilleCsv ( $login = '' , $idClient = 0 )
{
return $this -> getListeSurveillancesCsv ( 'portefeuille' , $login , $idClient );
}
/**
* getPortefeuille
* @ param PortefeuilleFiltre $filtre
* @ param int $deb
* @ param int $nbRet
* @ return PortefeuilleReturn
*/
public function getPortefeuille ( $filtre , $deb = 0 , $nbRet = 100 )
{
$this -> authenticate ();
// Initialisation
$error = new ErrorType ();
if ( empty ( $deb )) { $deb = 0 ; }
if ( empty ( $nbRet )) { $nbRet = 100 ; }
$tri = strtolower ( trim ( $filtre -> tri ));
switch ( $tri ) {
case 'ref' : $orderBy = 'ORDER BY ref' ; break ;
case 'dateAjout' : $orderBy = 'ORDER BY dateAjout' ; break ;
case 'dateDerEnvoi' : $orderBy = 'ORDER BY dateDerEnvoi' ; break ;
case 'rs' : $orderBy = 'ORDER BY rs' ; break ;
case 'cp' : $orderBy = 'ORDER BY cp' ; break ;
case 'ville' : $orderBy = 'ORDER BY ville' ; break ;
case 'indiScore' : $orderBy = 'ORDER BY indiScore' ; break ;
case 'encours' : $orderBy = 'ORDER BY encours' ; break ;
default : $orderBy = 'ORDER BY siren' ; break ; // siren ou vide ou autre
}
$tabRet = array ();
$siren = substr ( $filtre -> siret , 0 , 9 );
$nic = substr ( $filtre -> siret , 9 , 5 );
$iDb = new WDB ();
$login = $this -> tabInfoUser [ 'login' ];
$strSelect = 's.email, s.siren, s.nic, s.ref, s.dateAjout, s.rs, s.cp, s.ville, s.dateDerEnvoi, s.encoursClient, c.actif, c.procol, c.indiScore, c.indiScore20, c.encours, c.indiScoreDate, c.dateBilan, c.indiScorePre, c.indiScore20Pre, c.encoursPre, c.indiScoreDatePre, c.sourceModif, c.scoreSolv, c.scoreSolvPre, c.scoreDir, c.scoreDirPre, c.scoreConf, c.scoreConfPre, c.scoreZ, c.scoreZPre, c.scoreCH, c.scoreCHPre, c.scoreAfdcc2, c.scoreAfdcc2Pre, c.situFi, c.situFiPre, c.infoNote, c.infoNotePre, c.noteStruct, c.noteStructPre, c.noteFin, c.noteFinPre, c.tendance, c.tendancePre, c.dateUpdate' ;
$strFiltre = '' ;
if ( intval ( $siren ) > 0 ) $strFiltre .= " AND s.siren= $siren " ;
if ( ! empty ( $filtre -> ref )) $strFiltre .= " AND s.ref LIKE '% $filtre->ref %' " ;
if ( ! empty ( $filtre -> rs )) $strFiltre .= " AND s.rs LIKE '% $filtre->rs %' " ;
// Il faut compter le nombre de siren au total
$tabTmp = $iDb -> select ( 'surveillances_site s' , 'count(*) as nb' , " s.login=' $login ' AND s.source='score' AND s.dateSuppr=0 $strFiltre " , false , MYSQL_ASSOC );
$nbRepTot = $tabTmp [ 0 ][ 'nb' ];
$tabTmp = $iDb -> select ( 'surveillances_site s, scores_surveillance c' , $strSelect , " s.login=' $login ' AND s.source='score' AND s.dateSuppr=0 AND s.siren=c.siren $strFiltre $orderBy LIMIT $deb , $nbRet " , false , MYSQL_ASSOC );
foreach ( $tabTmp as $i => $tabSurv ) {
if ( trim ( $tabSurv [ 'rs' ]) <> '' ) {
$rs = $tabSurv [ 'rs' ];
$cp = $tabSurv [ 'cp' ];
$ville = $tabSurv [ 'ville' ];
} else {
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $tabSurv [ 'siren' ], $tabSurv [ 'nic' ]);
$rs = $tabIdentite [ 'Nom' ];
$cp = $tabIdentite [ 'CP' ];
$ville = $tabIdentite [ 'Ville' ];
$iDb -> update ( 'surveillances_site' , array (
'rs' => $rs ,
'cp' => $cp ,
'ville' => $ville ),
" login=' $login ' AND source='score' AND dateSuppr=0 AND siren= " . $tabSurv [ 'siren' ] . " AND nic= " . $tabSurv [ 'nic' ],
false
);
}
$portefeuille = new Portefeuille ();
$portefeuille -> email = $tabSurv [ 'email' ];
$portefeuille -> siren = $tabSurv [ 'siren' ];
$portefeuille -> nic = $tabSurv [ 'nic' ];
$portefeuille -> ref = $tabSurv [ 'ref' ];
$portefeuille -> dateAjout = $tabSurv [ 'dateAjout' ];
$portefeuille -> rs = $rs ;
$portefeuille -> cp = $cp ;
$portefeuille -> ville = $ville ;
// Entreprise
$portefeuille -> actif = $tabSurv [ 'actif' ];
$portefeuille -> procol = $tabSurv [ 'procol' ];
$portefeuille -> indiScore = $tabSurv [ 'indiScore' ];
$portefeuille -> indiScore20 = $tabSurv [ 'indiScore20' ];
$portefeuille -> indiScorePre = $tabSurv [ 'indiScorePre' ];
$portefeuille -> indiScore20Pre = $tabSurv [ 'indiScore20Pre' ];
$portefeuille -> encours = $tabSurv [ 'encours' ];
$portefeuille -> encoursPre = $tabSurv [ 'encoursPre' ];
$portefeuille -> indiScoreDate = $tabSurv [ 'indiScoreDate' ];
$portefeuille -> indiScoreDatePre = $tabSurv [ 'indiScoreDatePre' ];
$portefeuille -> encoursClient = $tabSurv [ 'encoursClient' ];
$portefeuille -> dateBilan = $tabSurv [ 'dateBilan' ];
$portefeuille -> sourceModif = $tabSurv [ 'sourceModif' ];
//, c.scoreSolv, c.scoreSolvPre, c.scoreDir, c.scoreDirPre, c.scoreConf, c.scoreConfPre, c.scoreZ, c.scoreZPre, c.scoreCH, c.scoreCHPre, c.scoreAfdcc2, c.scoreAfdcc2Pre, c.situFi, c.situFiPre, c.infoNote, c.infoNotePre, c.noteStruct, c.noteStructPre, c.noteFin, c.noteFinPre, c.tendance, c.tendancePre, c.dateUpdate';
$portefeuille -> dateDerEnvoi = $tabSurv [ 'dateDerEnvoi' ];
$tabRet [] = $portefeuille ;
}
$output = new PortefeuilleReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
$output -> nbReponses = count ( $tabRet );
$output -> nbReponsesTotal = $nbRepTot ;
return $output ;
}
/**
* rechercheHisto
* @ param string $recherche
* @ param string $annee
* @ param string $typeBod
* @ param int $deb
* @ param int $nbRep
* @ param int $maxRep
* @ param bool $pertinence
* @ return RechercheHistoReturn
*/
public function rechercheHisto ( $recherche , $annee = '' , $typeBod = '' , $deb = 0 , $nbRep = 20 , $maxRep = 200 , $pertinence = false )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( empty ( $annee )) $annee = '' ;
if ( empty ( $typeBod )) $typeBod = '' ;
if ( empty ( $deb )) $deb = 0 ;
if ( empty ( $nbRep )) $nbRep = 20 ;
if ( empty ( $maxRep )) $maxRep = 200 ;
if ( empty ( $annee )) $pertinence = false ;
$liste = array ();
$index = 'histo' ;
debugLog ( 'I' , " rechercheHisto de $recherche ( $annee ) (Max Rep= $nbRep ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$tabFiltres = array ();
if ( $annee <> '' && $annee * 1 >= 1953 && $annee * 1 <= date ( 'Y' ) * 1 )
$tabFiltres = array ( 'annee1' => $annee );
/*
require_once 'Metier/sphinx/recherche2.php' ;
$ret = search2 ( 'histo' , " $recherche " , $tabFiltresAnnee , $deb , $nbRep , $maxRep , $pertinence );
*/
if ( SPHINX_HISTO_VERSION == 1 ){
require_once 'sphinxapi/sphinxapi-0.9.9.php' ;
} elseif ( SPHINX_HISTO_VERSION == 2 ){
2012-07-17 06:22:32 +00:00
require_once 'sphinxapi/sphinxapi-2.0.2.php' ;
2012-03-29 13:07:10 +00:00
}
$cl = new SphinxClient ();
$cl -> SetServer ( SPHINX_HISTO_HOST , SPHINX_HISTO_PORT );
$cl -> SetConnectTimeout ( 1 );
$cl -> SetLimits ( $deb , $nbRep , $maxRep );
$cl -> SetMatchMode ( SPH_MATCH_EXTENDED );
foreach ( $tabFiltres as $nomFiltre => $valFiltre )
$cl -> SetFilter ( $nomFiltre , array ( 0 => $valFiltre ));
$cl -> SetRankingMode ( SPH_RANK_PROXIMITY_BM25 );
$res = $cl -> Query ( $recherche , $index );
if ( $res === false ) {
debugLog ( 'I' , " Search Sphinx : Pas de réponse pour $recherche avec " . implode ( ',' , $tabFiltres ) . ' (' . $cl -> GetLastError () . ')' , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$criteres = new RechercheHistoCriteres ();
$criteres -> recherche = $recherche ;
$criteres -> annee = $annee ;
$output = new RechercheHistoReturn ();
$output -> criteres = $criteres ;
$output -> nbReponses = 0 ;
$output -> nbReponsesTotal = 0 ;
$output -> duree = $res [ time ];
$output -> mots = array ();
$output -> reponses = array ();
return $output ;
2012-07-17 06:22:32 +00:00
}
2012-03-29 13:07:10 +00:00
// Le moteur est opérationel
if ( $cl -> GetLastWarning () ) {
debugLog ( 'I' , " Search Sphinx : Warning pour $recherche - " . $cl -> GetLastWarning (), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
//print "WARNING: " . $cl->GetLastWarning() . "\n\n";
}
debugLog ( 'I' , " 'Search Sphinx dans $index de $recherche (Filtre= " . implode ( ',' , $tabFiltres ) . " ), Deb= $deb , nbRep= $nbRep , max= $max , any= $any " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$tabRet = array ();
if ( is_array ( $res [ 'matches' ])) {
$iDb = new WDB ();
2012-07-17 06:22:32 +00:00
foreach ( $res [ 'matches' ] as $doc => $docinfo )
2012-03-29 13:07:10 +00:00
{
$listeEtab = $iDb -> select ( 'histobodacc.bodacc_ocr' ,
" 'Histo' as Loc, id, nomFichier, annee1, bod, texte " ,
" id= $doc " );
$etab = $listeEtab [ 0 ];
$tabRet [] = array (
'Localisation' => $etab [ 'Loc' ],
'id' => $doc ,
'Pertinence' => $docinfo [ 'weight' ],
'Fichier' => $etab [ 'nomFichier' ],
'Annee' => $etab [ 'annee1' ],
'Code' => $etab [ 'bod' ],
'Texte' => $etab [ 'texte' ],
);
}
}
debugLog ( 'I' , 'Search Sphinx : Retourne ' . $res [ total ] . '/' . $res [ total_found ] . ' en ' . $res [ time ] . 'secondes' , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$liste = $tabRet ;
$nbTot = $res [ total_found ];
$duree = $res [ time ];
$tabMots = $res [ 'words' ];
$tabRet = array ();
$k = 0 ;
if ( count ( $liste ) > 0 ) {
require_once 'i18n/cleanchar.php' ;
foreach ( $liste as $n => $etab ) {
2012-07-17 06:22:32 +00:00
$texte = cleanutf8 ( $etab [ 'Texte' ]);
2012-03-29 13:07:10 +00:00
$pattern = '/[^a-zA-Z0-9\/]+/ ' ;
$texte = preg_replace ( $pattern , ' ' , $texte );
$posMin = 100000 ;
$hitMin = 1000000 ;
foreach ( $tabMots as $mot => $tabMot ) {
if ( $tabMot [ 'hits' ] < $hitMin ) {
$hitMin = $tabMot [ 'hits' ];
$motSignificatif = $mot ;
}
}
$posMin = stripos ( $texte , '' . $motSignificatif );
if ( $posMin < 150 ) $posMin = 150 ;
$texte2 = substr ( $texte , $posMin - 150 , 250 );
$reponse = new RechercheHistoReponses ();
$reponse -> id = $etab [ 'id' ];
$reponse -> Pertinence = $etab [ 'Pertinence' ];
2012-07-17 06:22:32 +00:00
//@todo : gestion du lien pour le téléchargement des fichiers bodacc
$file = strtr ( $etab [ 'Fichier' ], array (
'.txt' => '.pdf' ,
'/mnt/bodacc/' => '' ));
2012-03-29 13:07:10 +00:00
$vieuxWS = false ;
if ( $vieuxWS ) {
2012-07-17 06:22:32 +00:00
$reponse -> Fichier = 'http://tville.scores-decisions.com/bodacc/' . $file ;
} else {
2012-03-29 13:07:10 +00:00
$hostname = 'http://' . $_SERVER [ 'SERVER_NAME' ];
if ( $_SERVER [ 'SERVER_PORT' ] != '80' ){
$hostname .= ':' . $_SERVER [ 'SERVER_PORT' ];
}
2012-07-17 06:22:32 +00:00
$url = '/fichier/bodacc/q/' . base64_encode ( $file );
2012-03-29 13:07:10 +00:00
$reponse -> Fichier = $hostname . $url ;
}
$reponse -> Annee = $etab [ 'Annee' ];
$reponse -> Code = $etab [ 'Code' ];
2012-07-17 06:22:32 +00:00
$reponse -> Texte = $texte2 ;
2012-03-29 13:07:10 +00:00
$tabRet [] = $reponse ;
$k ++ ;
}
}
$criteres = new RechercheHistoCriteres ();
$criteres -> recherche = $recherche ;
$criteres -> annee = $annee ;
$output = new RechercheHistoReturn ();
$output -> criteres = $criteres ;
$output -> nbReponses = count ( $tabRet );
$output -> nbReponsesTotal = $nbTot ;
$output -> duree = $duree ;
$output -> mots = array_keys ( $tabMots );
$output -> reponses = $tabRet ;
return $output ;
}
/**
* getListeSurveillanceCsv
* @ param string $source
* @ param string $login
* @ param int $idClient
* @ return ListeSurveillancesCsvReturn
*/
public function getListeSurveillancesCsv ( $source = '' , $login = '' , $idClient = 0 )
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
if ( empty ( $source )) $source = '' ;
if ( empty ( $idClient )) $idClient = 0 ;
debugLog ( 'I' , " getListeSurveillancesCsv Début $source $login $idClient " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$tabRet = array ();
$iDb = new WDB ();
$strClient = $strLogin = '' ;
$exportPtf = false ;
switch ( $source )
{
case 'insee' :
case 'annonces' :
case 'bilans' :
case 'score' :
case 'actes' :
case 'privileges' :
case 'dirigeants' :
break ;
case 'portefeuille' :
$source = 'score' ;
$exportPtf = true ;
break ;
default :
$source = '' ;
break ;
}
if ( $source <> '' ) $strSource = " AND source=' $source ' " ;
else $strSource = '' ;
// Control idClient
if ( $idClient == 0 || ( $idClient != $this -> tabInfoUser [ 'idClient' ] && $this -> tabInfoUser [ 'profil' ] != 'SuperAdministrateur' ) ){
$idClient = $this -> tabInfoUser [ 'idClient' ];
}
$strClient = " AND u.idClient= $idClient " ;
if ( $this -> tabInfoUser [ 'profil' ] == 'SuperAdministrateur' || $this -> tabInfoUser [ 'profil' ] == 'Administrateur' ) {
// Surveillances de tous les utilisateurs du client
if ( empty ( $login )) {
$login = '' ;
//Surveillances de l'utilisateur
} else {
$strLogin = " AND s.login=' $login ' " ;
}
} else {
//Par défaut préselection de l'utilisateur
$login = $this -> tabInfoUser [ 'login' ];
$strLogin = " AND s.login=' $login ' " ;
}
$fichierCsv = DOC_WEB_LOCAL . " csv/listesurv- $source - $login - $idClient .csv " ;
if ( file_exists ( $fichierCsv ) &&
date ( 'Ymd' , filemtime ( $fichierCsv )) == date ( 'Ymd' ) &&
filesize ( $fichierCsv ) > 60 ) {
$size = filesize ( $fichierCsv );
$erreur = false ;
$tabNom = array ();
$cache = 1 ;
} else {
unlink ( $fichierCsv );
if ( $source == 'score' ){
if ( $tabInfoUser [ 'typeScore' ] == 20 ) {
$strScore = 'v.indiScore20 AS indiScore20' ;
$strScorePre = 'v.indiScore20Pre AS indiScore20Pre' ;
} else {
$strScore = 'v.indiScore AS indiScore100' ;
$strScorePre = 'v.indiScorePre AS indiScore100Pre' ;
}
/* v . scoreZ , v . scoreZPre , v . scoreCH , v . scoreCHPre ,
v . scoreAfdcc2 , v . scoreAfdcc2Pre , v . situFi , v . situFiPre , v . infoNote , v . infoNotePre ,
v . noteStruct , v . noteStructPre , v . noteFin , v . noteFinPre , v . tendance , v . tendancePre , */
$sql = " SELECT LOWER(s.login) as loginUti, s.source, s.email, s.siren, s.nic, s.ref, s.dateAjout,
s . rs , s . cp , s . ville , s . dateDerEnvoi ,
s . encoursClient , v . actif , v . procol , $strScore , v . encours , v . indiScoreDate , v . dateBilan ,
$strScorePre , v . encoursPre , v . indiScoreDatePre , v . sourceModif , v . scoreSolv , v . scoreSolvPre , v . scoreDir ,
v . scoreDirPre , v . scoreConf , v . scoreConfPre ,
e . cj , e . capital , e . capitalDev , e . ape_entrep , e . tca , e . teff_entrep ,
v . dateUpdate
FROM surveillances_site s , sdv1 . utilisateurs u , sdv1 . clients c , scores_surveillance v , etablissements e
WHERE s . source = 'score' $strClient $strLogin AND dateSuppr = 0 AND s . login = u . login AND u . idClient = c . id AND s . siren = v . siren AND s . siren = e . siren
GROUP BY loginUti , s . siren , s . nic , s . source , s . ref
ORDER BY loginUti ASC , s . siren ASC , s . nic ASC , s . source ASC , s . ref ASC " ;
//@sendMail('production@scores-decisions.com', 'ylenaour@scores-decisions.com', "getListeSurveillancesCsv($source, $login, $idClient)", $sql);
} else {
$sql = " SELECT LOWER(s.login) as loginUti, s.source, s.email, s.siren, s.nic, s.ref, s.dateAjout,
s . rs , s . cp , s . ville , s . dateDerEnvoi
FROM surveillances_site s , sdv1 . utilisateurs u , sdv1 . clients c
WHERE 1 $strSource $strClient $strLogin AND dateSuppr = 0 AND s . login = u . login AND u . idClient = c . id
ORDER BY loginUti ASC , s . siren ASC , s . nic ASC , s . source ASC , s . ref ASC " ;
}
debugLog ( 'I' , " getListeSurveillancesCsv SQL $sql " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$fp = fopen ( DOC_WEB_LOCAL . " csv/listesurv- $source - $login - $idClient .sql " , 'w' );
fwrite ( $fp , $sql . EOL );
fclose ( $fp );
exec ( " php " . APPLICATION_PATH . " /../batch/sql2csv.php jo " . DOC_WEB_LOCAL . " csv/listesurv- $source - $login - $idClient .sql $fichierCsv > /dev/null & " );
$size = $cache = 0 ;
}
$hostname = 'http://' . $_SERVER [ 'SERVER_NAME' ];
if ( $_SERVER [ 'SERVER_PORT' ] != '80' ){
$hostname .= ':' . $_SERVER [ 'SERVER_PORT' ];
}
$result = new ListeSurveillancesCsv ();
$result -> Url = $hostname . DOC_WEB_URL . " csv/listesurv- $source - $login - $idClient .csv " ;
$result -> Taille = $size ;
$result -> Cache = $cache ;
debugLog ( 'I' , 'getListeSurveillancesCsv Url=' . $hostname . DOC_WEB_URL . " csv/listesurv- $source - $login - $idClient .csv, Taille= $size , Cache= $cache " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$output = new ListeSurveillancesCsvReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* getListeJalCollecte
* @ return ListeJalCollecteReturn
*/
public function getListeJalCollecte ()
{
$this -> authenticate ();
//Initialisation
$error = new ErrorType ();
$iBodacc = new MBodacc ();
$tabJal = $iBodacc -> getListeJalCollecte ();
foreach ( $tabJal as $i => $jal )
{
$jalCollecte = new JalCollecte ();
$jalCollecte -> id = $i ;
$jalCollecte -> nom = $jal ;
$tabRet [] = $jalCollecte ;
}
$output = new ListeJalCollecteReturn ();
$output -> error = $error ;
$output -> result = $tabRet ;
return $output ;
}
/**
* getListeFichierSurv
* @ param string $login
* @ param string $ref
* @ param string $nomFic
* @ return ListeFichierSurvReturn
*/
public function getListeFichierSurv ( $login , $ref = '*' , $nomFic = '' )
{
$this -> authenticate ();
if ( empty ( $ref )) $ref = '*' ;
if ( empty ( $nomFic )) $nomFic = '' ;
$error = new ErrorType ();
//debugLog('I',"getListeFichierSurv pour $login, $ref, $nomFic",__LINE__,__FILE__, __FUNCTION__, __CLASS__);
$tabFichier = $tabDates = array ();
$numAbo = substr ( $ref , 0 , 5 );
if ( strtolower ( $login ) == 'vwbank' ) {
2012-07-17 06:22:32 +00:00
$repClient = 'volkswagen bank' ;
2012-03-29 13:07:10 +00:00
$ficClient = 'surveillanceBodacc_SURBODPRDCFTVWBANK' ;
$numAbo = $ref = '19300' ;
} elseif ( substr ( $login , 0 , 6 ) == 'apicil' ) {
$repClient = 'apicil' ;
$ficClient = 'surveillanceBodacc_SURBODPRDCFTAPICIL' ;
$numAbo = $ref = '' ;
} elseif ( strtolower ( $login ) == 'omni04' ) {
$repClient = 'aggm mederic ' ;
$ficClient = 'surveillanceBodacc_SURBODPRDFTSOMNIREP' ;
$numAbo = $ref = '' ;
} elseif ( strtolower ( $login ) == 'bodacca3m' ) {
$repClient = 'aggm mederic ' ;
$ficClient = 'surveillanceBodacc_SURBODPRDFTSMEDERIC' ;
$numAbo = $ref = '' ;
} elseif ( strtolower ( $login ) == 'bodaccomni' ) {
$repClient = 'aggm mederic ' ;
$ficClient = 'surveillanceBodacc_SURBODPRDFTSOMNIREP' ;
$numAbo = $ref = '' ;
} elseif ( strtolower ( $login ) == 'bodacccrr' ) {
$repClient = 'aggm mederic ' ;
$ficClient = 'surveillanceBodacc_SURBODPRDFTSCRR' ;
$numAbo = $ref = '' ;
} elseif ( strtolower ( $login ) == 'cpcambr13' || strtolower ( $login ) == 'cpcambr14' ) {
$repClient = 'cpcam des bouches du rhône' ;
$ficClient = 'diffusionBodacc_DIFBODPRDMAICPCAM13' ;
$numAbo = $ref = '' ;
} else {
2012-07-17 06:22:32 +00:00
$repClient = 'cnasea' ;
2012-03-29 13:07:10 +00:00
$ficClient = 'surveillanceBodacc_SURBODTSTFTSCNASEA' ;
}
$dh = opendir ( DOC_WEB_LOCAL . " clients/ $repClient / " );
if ( ! $dh ) {
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " getListeFichierSurv pour $login , $ref , $nomFic " , " Impossible d'ouvrir le dossier '/home/data/clients/ $repClient /' " );
$error -> errnum = 1 ;
$error -> errmsg = " Impossible d'ouvrir le dossier client " ;
} else {
while ( false !== ( $filename = readdir ( $dh ))) {
if ( $filename <> '.' && $filename <> '..' && substr ( $filename , - 4 ) == '.csv' && substr ( $filename , 0 , 42 ) == $ficClient . $numAbo ) {
$tabFichier [] = $filename ;
$tabDates [] = substr ( $filename , 43 , 8 );
$tabClients [] = substr ( $filename , 0 , 42 );
}
elseif ( $ref == '*' && $filename <> '.' && $filename <> '..' && substr ( $filename , - 4 ) == '.csv' && substr ( $filename , 0 , 37 ) == $ficClient && substr ( $filename , 37 , 1 ) <> '_' ) {
$tabFichier [] = $filename ;
$tabDates [] = substr ( $filename , 43 , 8 );
$tabClients [] = substr ( $filename , 0 , 42 );
}
elseif ( $filename <> '.' && $filename <> '..' && substr ( $filename , - 4 ) == '.csv' && substr ( $filename , 0 , 37 ) == $ficClient && substr ( $filename , 37 , 1 ) == '_' && $repClient == 'apicil' ) {
$tabFichier [] = $filename ;
$tabDates [] = substr ( $filename , 38 , 8 );
$tabClients [] = substr ( $filename , 0 , 37 );
}
elseif ( $filename <> '.' && $filename <> '..' && substr ( $filename , - 4 ) == '.csv' && substr ( $filename , 0 , 38 ) == $ficClient && substr ( $filename , 38 , 1 ) == '_' && $repClient == 'aggm mederic ' ) {
$tabFichier [] = $filename ;
$tabDates [] = substr ( $filename , 39 , 8 );
$tabClients [] = substr ( $filename , 0 , 38 );
}
//@sendMail('production@scores-decisions.com', 'ylenaour@scores-decisions.com', "getListeFichierSurv pour $login, $ref, $nomFic : fichier lu '$filename'", "Fichier lu '$filename'");
}
/** Tableau des noms de fichier **/
sort ( $tabFichier );
/** Tableau des dates de livraisons **/
$tabDates = array_unique ( $tabDates );
sort ( $tabDates );
/** Tableau des Clients **/
$tabClients = array_unique ( $tabClients );
sort ( $tabClients );
//return array('error'=>array('errnum'=>0, 'errmsg'=>''), 'results'=>$tabDates);
/*@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " getListeFichierSurv pour $login , $ref , $nomFic " ,
" Fichiers : " . EOL .
print_r ( $tabFichier , true ) .
" Dates: " . EOL .
print_r ( $tabDates , true ) .
" Clients : " . EOL .
print_r ( $tabClients , true )
); */
if ( $ref == '*' ) {
$tabFichier = array ();
// Boucle sur les dates de livraison
foreach ( $tabDates as $dateFic ) {
if ( strlen ( $dateFic ) <> 8 ) continue ;
if ( ! file_exists ( DOC_WEB_LOCAL . " clients/ $repClient / $ficClient " . '_' . " $dateFic .csv " ) ||
filesize ( DOC_WEB_LOCAL . " clients/ $repClient / $ficClient " . '_' . " $dateFic .csv " ) == 0 ) {
$fpW = fopen ( DOC_WEB_LOCAL . " clients/ $repClient / $ficClient " . '_' . " $dateFic .csv " , 'w' );
$entete = true ;
// Boucle afin de vérifier si on est sur le bon client
foreach ( $tabClients as $nomClient ) {
$dh = opendir ( DOC_WEB_LOCAL . " clients/ $repClient / " );
while ( false !== ( $filename = readdir ( $dh ))) {
if ( substr ( $filename , 0 , 51 ) == $nomClient . '_' . $dateFic && substr ( $filename , - 4 ) == '.csv' ) {
$fichier = $filename ;
//break;
}
}
$fpR = fopen ( DOC_WEB_LOCAL . " clients/ $repClient / $fichier " , 'r' );
//return array('error'=>array('errnum'=>0, 'errmsg'=>''), 'results'=>array(($fichier)));//die;
if ( $fpR ) {
while ( ! feof ( $fpR )) {
$ligne = trim ( fgets ( $fpR ));
if ( substr ( $ligne , 0 , 5 ) == 'Siren' && $entete == true ) {
fwrite ( $fpW , 'SITE;' . $ligne . EOL );
$entete = false ;
}
elseif ( substr ( $ligne , 0 , 5 ) <> 'Siren' && trim ( $ligne ) <> '' ) {
fwrite ( $fpW , strtr ( $nomClient , array ( 'surveillanceBodacc_SURBODTSTFTS' => '' ,
'surveillanceBodacc_SURBODPRDCFT' => '' )) . ';' . $ligne . EOL );
}
}
fclose ( $fpR );
}
}
fclose ( $fpW );
}
if ( strlen ( $dateFic ) == 8 )
$tabFichier [] = $ficClient . '_' . $dateFic . '.csv' ;
}
}
rsort ( $tabFichier );
if ( $nomFic <> '' ) {
//@sendMail('production@scores-decisions.com', 'ylenaour@scores-decisions.com', "getListeFichierSurv pour $login, $ref, /home/data/clients/$repClient/$nomFic", 'Avant BZ2');
if ( ! file_exists ( DOC_WEB_LOCAL . " /csv/ $nomFic .bz2 " ) ||
filesize ( DOC_WEB_LOCAL . " /csv/ $nomFic .bz2 " ) <= 14 ) {
$string = file_get_contents ( " /home/data/clients/ $repClient / $nomFic " );
if ( $string === false ) {
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " getListeFichierSurv pour $login , $ref , $nomFic " , " Ouverture impossible du fichier '/home/data/clients/ $repClient / $nomFic ' " );
}
$bz = bzopen ( DOC_WEB_LOCAL . " /csv/ $nomFic .bz2 " , 'w' );
if ( $bz ) {
bzwrite ( $bz , $string , strlen ( $string ));
bzclose ( $bz );
}
} /* else
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " getListeFichierSurv pour $login , $ref , /home/data/clients/ $repClient / $nomFic " , 'Sans BZ2' );
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " getListeFichierSurv pour $login , $ref , /home/data/clients/ $repClient / $nomFic " , 'Après BZ2' );
*/
}
debugLog ( 'I' , " getListeFichierSurv pour $login , $ref , $nomFic : nb fichiers= " . count ( $tabFichier ), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$hostname = 'http://' . $_SERVER [ 'SERVER_NAME' ];
if ( $_SERVER [ 'SERVER_PORT' ] != '80' ){
$hostname .= ':' . $_SERVER [ 'SERVER_PORT' ];
}
$result = array ();
foreach ( $tabFichier as $fichier ){
$retFichier = new ListeFichierSurv ();
$retFichier -> UrlFichier = $hostname . '/data/csv/' . $fichier ;
$result [] = $retFichier ;
}
}
$output = new ListeFichierSurvReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Geocodage d ' une adresse
* @ param string $adresse
* @ param string $cp
* @ param string $ville
* @ param string $pays
* @ return GeoCodeReturn
*/
public function geoCode ( $adresse , $cp , $ville , $pays = 'France' )
{
$this -> authenticate ();
$ligne = date ( 'YmdHis' ) . " ; $siren ;MMap AVANT " ;
$fp = fopen ( LOG_PATH . '/accesDistant.log' , 'a' );
fwrite ( $fp , $ligne . EOL );
fclose ( $fp );
$mMap = new MMap ( $adresse , $cp , $ville , $pays );
$ligne = date ( 'YmdHis' ) . " ; $siren ;MMap APRES " ;
$fp = fopen ( LOG_PATH . '/accesDistant.log' , 'a' );
fwrite ( $fp , $ligne . EOL );
fclose ( $fp );
$geocode = new GeoCode ();
$geocode -> latitude = $mMap -> latitudeDec ;
$geocode -> longitude = $mMap -> longitudeDec ;
$geocode -> precis = $mMap -> precision ;
$geocode -> adresseValidee = $mMap -> adresseValidee ;
$geocode -> latitudeDeg = $mMap -> latitudeDeg ;
$geocode -> longitudeDeg = $mMap -> longitudeDeg ;
$output = new GeoCodeReturn ();
$output -> error = $error ;
$output -> result = $geocode ;
}
/**
* Recherche d ' entreprise par leur actionnaire
* @ param string $nom Raison sociale / Nom de l ' actionnaire ( obligatoire )
* @ param string $cpVille CP , Ville
* @ param string $siren Siren de l ' actionnaire
* @ param string $pays Pays de l ' actionnaire
* @ param string $pctMin Niveau de détention Minimam de l ' actionnaire
* @ param string $pctMax Niveau de détention Maximum de l ' actionnaire
* @ param integer $deb Position du curseur dans la liste des réponses ( 0 par défaut )
* @ param integer $nbRep Nombre de réponses retournées au maximum par cette requete ( 20 par défaut )
* @ param integer $maxRep Nombre de réponses recherchées au maximum ( 200 par défaut )
* @ param boolean $pertinence Recherche orthographique stricte sur les noms et prénoms ( si true )
* @ return SearchActReturn
*/
2012-07-17 06:22:32 +00:00
public function searchAct ( $nom , $cpVille = '' , $siren = 0 , $pays = '' , $pctMin = 0 , $pctMax = 100 , $deb = 0 , $nbRep = 20 , $maxRep = 200 , $pertinence = false )
2012-03-29 13:07:10 +00:00
{
debugLog ( 'I' , " Recherche Actionnaire de $nom , $cpVille (Max Rep= $nbRep ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( ! empty ( $pays )){
$wdb = new WDB ( 'jo' );
$result = $wdb -> select ( 'tabPays' , 'codPays3' , " libPays LIKE ' " . $pays );
if ( count ( $result > 0 )){
$pays = $result [ 0 ][ 'codPays3' ];
} else {
$pays = '' ;
}
}
if ( empty ( $cpVille )) $cpVille = '' ;
if ( empty ( $siren )) $siren = '' ;
if ( empty ( $pctMin )) $pctMin = 0 ;
if ( empty ( $pctMax )) $pctMax = 100 ;
if ( empty ( $deb )) $deb = 0 ;
if ( empty ( $nbRep )) $nbRep = 20 ;
if ( empty ( $maxRep )) $maxRep = 200 ;
if ( empty ( $pertinence )) $pertinence = false ;
$mLiens = new MLiens ( '' );
// rechercheActionnaire($nom, $cpVille, $siren, $pays, $pctMin, $pctMax, $deb, $nbRep, $maxRep, $pertinence)
$etabs = $mLiens -> rechercheActionnaire ( $nom , $cpVille , $siren , $pays , $pctMin , $pctMax , $deb , $nbRep , $maxRep , $pertinence );
$iInsee = new MInsee ();
$tabRet = array ();
foreach ( $etabs [ 'reponses' ] as $etab ) {
$act = new EntrepriseActItem ();
$act -> id = $etab [ 'id' ];
$act -> Pertinence = $etab [ 'Pertinence' ];
$act -> Siret = $etab [ 'Siret' ];
$act -> Siege = $etab [ 'Siege' ];
$act -> Nom = prepareString ( strtr ( $etab [ 'Nom' ], '/*' , ' ' ));
$act -> Nom2 = prepareString ( $etab [ 'Nom2' ]);
$act -> Sigle = prepareString ( $etab [ 'Sigle' ]);
$act -> Enseigne = prepareString ( $etab [ 'Enseigne' ]);
$act -> Adresse = prepareString ( $etab [ 'Adresse' ]);
$act -> Adresse2 = prepareString ( $etab [ 'Adresse2' ]);
$act -> CP = $etab [ 'CP' ];
$act -> Ville = prepareString ( $etab [ 'Ville' ]);
$act -> Tel = $etab [ 'Tel' ];
$act -> Fax = $etab [ 'Fax' ];
$act -> FJ = $etab [ 'FJ' ];
$act -> FJLib = prepareString ( $iInsee -> getLibelleFJ ( $etab [ 'FJ' ]));
$act -> Siren = $etab [ 'Siren' ];
$act -> Nic = $etab [ 'Nic' ];
$act -> Actif = $etab [ 'Actif' ];
$act -> NafEtab = $etab [ 'NafEtab' ]; // Etablissement
$act -> NafEtabLib = prepareString ( $iInsee -> getLibelleNaf ( $etab [ 'NafEtab' ])); // Etablissement
$act -> NafEnt = $etab [ 'NafEnt' ]; // Entreprise
$act -> NafEntLib = prepareString ( $iInsee -> getLibelleNaf ( $etab [ 'NafEnt' ]));
$act -> ActNomRs = $etab [ 'ActNomRs' ];
$act -> ActPays = $etab [ 'ActPays' ];
$act -> ActDateLien = $etab [ 'ActDateLien' ];
$act -> ActActif = $etab [ 'ActActif' ];
2012-07-17 06:22:32 +00:00
$act -> ActPmin = $etab [ 'ActPmin' ];
2012-03-29 13:07:10 +00:00
$tabRet [] = $act ;
}
$output = new SearchActReturn ();
$output -> nbReponses = $etabs [ 'nbReponses' ];
$output -> nbReponsesTotal = $etabs [ 'nbReponsesTotal' ];
2012-07-17 06:22:32 +00:00
$output -> result = $tabRet ;
2012-03-29 13:07:10 +00:00
if ( $tabRet [ 'nbReponses' ] == 0 ) {
debugLog ( 'W' , " Aucun résultat pour cette recherche ! " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
}
return $output ;
}
/**
* Commande d 'une enquête sur une entreprise en France ou à l' Internationale
* @ param string $siren
* @ param string $infoEnq Informations pour la demande d ' enquête < br />
* InfoEnq [ Entrep ][ Tel ] < br />
* InfoEnq [ Entrep ][ Fax ] < br />
* InfoEnq [ Entrep ][ AutreTel ] < br />
* InfoEnq [ Entrep ][ Mail ] < br />
* InfoEnq [ Entrep ][ AutreMail ] < br />
* InfoEnq [ Entrep ][ Web ] < br />
* InfoEnq [ Entrep ][ Rib ][ Banque ] < br />
* InfoEnq [ Entrep ][ Rib ][ Guichet ] < br />
* InfoEnq [ Entrep ][ Rib ][ Compte ] < br />
* InfoEnq [ Entrep ][ Rib ][ Cle ] < br />
* InfoEnq [ Encours ] < br />
* InfoEnq [ NbEcheances ] < br />
* InfoEnq [ AvisAssureur ] < br />
* InfoEnq [ Type ] < br />
* InfoEnq [ Delai ] < br />
* InfoEnq [ PrecisionsChoix ] < br />
* InfoEnq [ Precisions ][ MontantCA ] < br />
* InfoEnq [ Precisions ][ Motif ] < br />
* InfoEnq [ Precisions ][ Autre ] < br />
* InfoEnq [ Anciennete ] < br />
* InfoEnq [ AncienneteDuree ] < br />
* InfoEnq [ ImpayeesChoix ] < br />
* InfoEnq [ Impayees ][ Montant ] < br />
* InfoEnq [ Impayees ][ Nombre ] < br />
* InfoEnq [ Impayees ][ Date ] < br />
* InfoEnq [ RetardPaiementChoix ] < br />
* InfoEnq [ RetardPaiement ][ Montant ] < br />
* InfoEnq [ RetardPaiement ][ Nombre ] < br />
* InfoEnq [ RetardPaiement ][ Date ] < br />
* InfoEnq [ LitigeChoix ] < br />
* InfoEnq [ Litige ][ Precisions ] < br />
* InfoEnq [ Observation ] < br />
* @ param string $infoDemande Informations sur l ' utilisateur < br />
* InfoUser [ Profil ] < br />
* InfoUser [ ProfilAutre ] < br />
* InfoUser [ Identite ] < br />
* InfoUser [ Tel ] < br />
* InfoUser [ Fax ] < br />
* InfoUser [ Email ] < br />
* InfoUser [ Ref ] < br />
* @ return CommandeEnqueteReturn
*/
2012-07-17 06:22:32 +00:00
public function commandeEnquete ( $siren , $infoEnq , $infoDemande )
2012-03-29 13:07:10 +00:00
{
$this -> authenticate ();
//Initialisation
$infoEnq = json_decode ( $infoEnq );
$infoDemande = json_decode ( $infoDemande );
$mail = trim ( $infoDemande [ 'Email' ]);
2012-07-17 06:22:32 +00:00
if ( $mail == '' ) {
2012-03-29 13:07:10 +00:00
$mail = $this -> tabInfoUser [ 'email' ];
}
$tabInsert = array (
'idUser' => $this -> tabInfoUser [ 'id' ],
'source' => 'intersud' , // 'greffes', 'asso', 'graydon'
'login' => $tabInfoUser [ 'login' ],
'emailCommande' => $mail ,
'siren' => $siren ,
'refDocument' => serialize ( $infoDemande ),
'refCommande' => serialize ( $infoEnq ),
'dateCommande' => DATETIME ,
// 'idClient'=> $tabInfoUser['idClient'],
);
debugLog ( 'I' , " Intersud, début commande sur $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$messageInfo = print_r ( $infoEnq , 1 ) . EOL . print_r ( $infoDemande , 1 ) . EOL ;
$idClient = $this -> tabInfoUser [ 'idClient' ];
$iDbCrm = new WDB ( 'sdv1' );
$rep = $iDbCrm -> select ( 'clients' , ' nom, racineLogin, InterSudLogin, InterSudPass' , " id=' $idClient ' " , false , MYSQL_ASSOC );
$login = trim ( $rep [ 0 ][ 'InterSudLogin' ]);
$pass = trim ( $rep [ 0 ][ 'InterSudPass' ]);
$nomClient = trim ( strtoupper ( $rep [ 0 ][ 'nom' ]));
$strInfoCommande = " NOM et Prénom du client demandeur : " . $infoDemande [ 'Identite' ] . EOL ;
$strInfoCommande .= " Email du client demandeur : $mail " . EOL ;
$strInfoCommande .= " Tel/Fax du demandeur : " . $infoDemande [ 'Tel' ] . ' / ' . $infoDemande [ 'Fax' ] . EOL ;
$strInfoCommande .= " Profil du demandeur : " . trim ( $infoDemande [ 'Profil' ] . ' ' . $infoDemande [ 'ProfilAutre' ]) . EOL ;
$typeEnqLog = 'enqueteDemNF' ;
if ( $login == '' || $pass == '' ) {
/** Il ne s'agit pas d'un client final, on anonymise la commande **/
$login = 'YLENA' ; // Demandes en test
$pass = 'WYLFE' ;
$nomClient = $strInfoCommande = '' ;
$typeEnqLog = 'enqueteDem' ;
/* ENQUETES EN PROD
$login = 'FACTURE' ;
$pass = 'AWKROM' ;
*/
}
/** Connexion à l'Extranet Intersud **/
$url = 'http://www.intersud.fr/espace_client/espace_client.php' ;
$cookie = $referer = '' ;
$tabPost = array (
'login' => $login ,
'pwd' => $pass ,
);
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , $tabPost , $referer , false , '' , '' , 7 );
if ( $page [ 'code' ] <> 200 ) {
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ATTENTION : Commande d'enquete sur $siren " , " Connexion impossible à la plateforme Intersud " . EOL . $strInfoCommande );
//wsLog($typeEnqLog, $siren, 'i'.$ret.'-'.DATETIME);
throw new SoapFault ( '1' , " Connexion impossible à la plateforme d'enquêtes " );
}
$tfin = microtime ( true );
$duree = $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
$cookie = $page [ 'header' ][ 'Set-Cookie' ];
$intersudNomPrenom = $intersudRaisonSociale = '' ;
if ( preg_match ( '/<td colspan="5" class="txt_blanc" background="images_ec\/1erpageespaceclient_14\.jpg" width="274" height="22">(.*)<\/td>/Uis' , $body , $matches ))
$intersudNomPrenom = trim ( $matches [ 1 ]);
if ( preg_match ( '/<td class="txt_blanc" colspan="7" rowspan="2" valign="middle" background="images_ec\/1erpageespaceclient_17\.jpg">(.*)<\/td>/Uis' , $body , $matches ))
2012-07-17 06:22:32 +00:00
$intersudRaisonSociale = trim ( $matches [ 1 ]);
2012-03-29 13:07:10 +00:00
debugLog ( 'I' , " Intersud, connexion via $login pour $intersudRaisonSociale ( $intersudNomPrenom , cookie= $cookie ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
2012-07-17 06:22:32 +00:00
/*
2012-03-29 13:07:10 +00:00
$fp =@ fopen ( LOG_PATH . " /intersud.log " , " a " );
@ fwrite ( $fp , EOL . DATETIME . EOL . print_r ( $page , true ) . '=========================================================================================================' . EOL . EOL );
@ fclose ( $fp );
die ();
*/
/** Page formulaire de demande d'enquête **/
$url = 'http://intersud.fr/espace_client/demande_enquete.php' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , '' , $referer , false , '' , '' , 7 );
if ( $page [ 'code' ] <> 200 ) {
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ATTENTION : Commande d'enquete sur $siren " , " Connexion impossible au formulaire d'enquête Intersud " . EOL . $strInfoCommande );
throw new SoapFault ( '2' , " Connexion impossible à la plateforme d'enquêtes " );
}
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
$fp =@ fopen ( LOG_PATH . '/intersud.log' , " a " );
@ fwrite ( $fp , print_r ( $page , true ));
@ fclose ( $fp );
$tabInterSud = array ();
if ( preg_match_all ( '/<input(?:.*)name="(.*)"(?:.*)value="(.*)"/Uim' , $body , $matches )) {
foreach ( $matches [ 1 ] as $i => $field ) {
$tmp = explode ( '"' , $matches [ 2 ][ $i ]);
$tabInterSud [ $field ] = $tmp [ 0 ];
}
}
if ( preg_match_all ( '/<input(?:.*)value="(.*)"(?:.*)name="(.*)"/Uim' , $body , $matches )) {
foreach ( $matches [ 2 ] as $i => $field ) {
$tmp = explode ( '"' , $matches [ 1 ][ $i ]);
$tabInterSud [ $field ] = $tmp [ 0 ];
}
}
$ref_exp = $tabInterSud [ 'ref_exp' ];
$email_exp = $tabInterSud [ 'email_exp' ];
$tel_exp = $tabInterSud [ 'tel_exp' ];
debugLog ( 'I' , " Intersud, formulaire enquête ref $ref_exp , $email_exp , $tel_exp " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$fp =@ fopen ( LOG_PATH . '/intersud.log' , " a " );
@ fwrite ( $fp , print_r ( $matches , true ));
@ fwrite ( $fp , print_r ( $tabInterSud , true ));
@ fclose ( $fp );
/** Insertion de la commande en base **/
$ret = $iDbCrm -> insert ( 'commandes' , $tabInsert , true );
$comment = " Référence de la commande chez Scores et Décisions : i $ret - " . DATETIME . "
Date et heure de la commande : " .date('d/m/Y - H:i'). "
Origine de la commande : $nomClient
$strInfoCommande
CA : " . $infoEnq['Precisions'] ['MontantCA']. "
Motif de la demande : " .trim( $infoEnq['Precisions'] ['Motif'].' '. $infoEnq['Precisions'] ['Autre']). "
Type de la demande : " . $infoEnq['Precisions'] ['Type']. "
Anciennete de la relation : " . $infoEnq['Anciennete'] .' '. $infoEnq['AncienneteDuree'] . "
Observations : " . $infoEnq['Observation'] .EOL;
if ( $infoEnq [ 'ImpayeesChoix' ] <> 'non' )
$comment .= " Impayé(s) : " . $infoEnq [ 'Impayees' ][ 'Nombre' ] . " impayé(s) pour un montant de " . $infoEnq [ 'Impayees' ][ 'Montant' ] . " en date du " . $infoEnq [ 'Impayees' ][ 'Date' ] . EOL ;
if ( $infoEnq [ 'RetardPaiementChoix' ] <> 'non' )
$comment .= " Retard(s) de paiement : " . $infoEnq [ 'RetardPaiement' ][ 'Nombre' ] . " retard(s) pour un montant de " . $infoEnq [ 'RetardPaiement' ][ 'Montant' ] . " en date du " . $infoEnq [ 'RetardPaiement' ][ 'Date' ] . EOL ;
if ( $infoEnq [ 'LitigeChoix' ] <> 'non' )
$comment .= " Présence de litige(s) : " . $infoEnq [ 'Litige' ][ 'Precisions' ] . EOL ;
$enqType = 0 ;
$enqDelai = 7 ;
switch ( strtolower ( $infoEnq [ 'Type' ])) {
case 'premier' : $enqType = 0 ; $enqDelai = 6 ; break ;
case 'gold' : $enqType = 1 ; break ;
case 'distrimat' : $enqType = 2 ; break ;
case 'star' : $enqType = 3 ; break ;
case 'avis_bancaire' : $enqType = 4 ; break ;
case 'autre' : $enqType = 5 ; break ;
}
/** Ajout du RIB si communiqué **/
if ( @ trim ( implode ( ' ' , $infoEnq [ 'Entrep' ][ 'Rib' ])) <> '' ){
$iDbCrm -> insert ( 'banques' , array (
'siren' => $siren ,
'libBanqueGuichet' => '' ,
'precis' => 1 ,
'codeBanque' => $infoEnq [ 'Entrep' ][ 'Rib' ][ 'Banque' ],
'codeGuichet' => $infoEnq [ 'Entrep' ][ 'Rib' ][ 'Guichet' ],
'numCompte' => $infoEnq [ 'Entrep' ][ 'Rib' ][ 'Compte' ] . $infoEnq [ 'Entrep' ][ 'Rib' ][ 'Cle' ],
'dateSource' => DATETIME ,
), true );
}
/** Remplissage du formulaire d'enquête pour soumission à Intersud **/
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $siren );
2012-07-17 06:22:32 +00:00
$tabPost = array (
2012-03-29 13:07:10 +00:00
'soc' => $tabIdentite [ 'Nom' ],
'cible_enk' => 9 , // 9
'siret' => $siren ,
'acti' => '' ,
'soc_exp' => $tabInterSud [ 'soc_exp' ],
'type_enk' => $enqType , // 0=Premier, 1=Gold, 2=Distrimat, 3=Star, 4=Avis bancaire, 5=Autre
'nom_diri' => '' ,
'adr' => $tabIdentite [ 'Adresse' ],
'ref_exp' => $tabInterSud [ 'ref_exp' ],
'autre_type_enk' => '' , // Texte libre
'adr2' => $tabIdentite [ 'Adresse2' ],
'delai_enk' => $enqDelai , // 6=24h, 7=72h, 8=+de5jours
'ville' => $tabIdentite [ 'Ville' ],
'cp' => $tabIdentite [ 'CP' ],
'pays' => '' , // International ?
'nom_exp' => $tabInterSud [ 'nom_exp' ],
'tel' => $tabIdentite [ 'Tel' ],
'port' => $infoEnq [ 'Entrep' ][ 'AutreTel' ],
'tel_exp' => $tabInterSud [ 'tel_exp' ],
'bank' => trim ( implode ( ' ' , $infoEnq [ 'Entrep' ][ 'Rib' ])),
'int_enk' => $tabInterSud [ 'int_enk' ], // International ?
'encours' => $infoEnq [ 'Encours' ],
'nb_ech' => $infoEnq [ 'NbEcheances' ],
'delai2_enk' => $tabInterSud [ 'delai2_enk' ], // International ?
'email_exp' => $tabInterSud [ 'email_exp' ],
'cred' => '' ,
'comment' => urlencode ( $comment ),
'val_ret' => $tabInterSud [ 'val_ret' ],
);
$url = 'http://intersud.fr/espace_client/demande_enquete.php' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , $tabPost , $referer , false , '' , '' , 7 );
if ( $page [ 'code' ] <> 200 ) {
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " ATTENTION : Commande d'enquete sur $siren " , " Validation impossible du formulaire d'enquête Intersud " . EOL . $strInfoCommande );
throw new SoapFault ( '3' , " Connexion impossible à la plateforme d'enquêtes " );
}
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$referer = $url ;
$body = $page [ 'body' ];
$output = new CommandeEnqueteReturn ();
$output -> siren = $siren ;
$output -> emailCommande = $mail ;
$output -> dateCommande = DATETIME ;
$output -> refCmde = 'i' . $ret ;
//$strInfoCommande $mail
@ sendMail ( 'production@scores-decisions.com' , 'ylenaour@scores-decisions.com' , " Commande d'enquete sur $siren " , $comment . EOL . EOL . '---------------------------------' . EOL . $messageInfo . EOL . EOL . '---------------------------------' . EOL . $body );
@ sendMail ( 'production@scores-decisions.com' , $mail , " Votre demande d'enquete sur " . $tabIdentite [ 'Nom' ] . " ( $siren ) " , " Votre demande d'enquête sur la société " . $tabIdentite [ 'Nom' ] . " a été prise en compte sous la référence i $ret - " . DATETIME );
wsLog ( $typeEnqLog , $siren , 'i' . $ret . '-' . DATETIME );
/** Gestion de la déconnexion **/
$url = 'http://intersud.fr/espace_client/index.php?code_ret=9' ;
$tdeb = microtime ( true );
$page = getUrl ( $url , $cookie , '' , $referer , false , '' , '' , 7 );
$tfin = microtime ( true );
$duree += $tfin - $tdeb ;
$ret = $iDbCrm -> update ( 'commandes' , array ( 'dureeCommande' => round ( $duree , 3 )), " idCommande= $ret " );
return $output ;
}
2012-07-17 06:22:32 +00:00
/**
2012-03-29 13:07:10 +00:00
* Retourne l 'ensemble des informations des dirigeants opérationnels (non statutaires) de l' entreprise
* @ param string $siren Siren de l ' entreprise
* @ return DirigeantOp []
*/
2012-07-17 06:22:32 +00:00
public function getDirigeantsOp ( $siren )
2012-03-29 13:07:10 +00:00
{
$this -> authenticate ();
debugLog ( 'I' , " Dirigeants opérationnels demandés pour $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( strlen ( $siren ) > 9 || ( substr ( $siren , 0 , 9 ) * 1 ) < 100 ){
debugLog ( 'W' , " Siren $siren incorrect " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> sendError ( '1010' );
}
$iInsee = new MInsee ();
$dirs = $iInsee -> getDirigeantsOp ( $siren );
2012-07-17 06:22:32 +00:00
$tabRet = array ();
if ( count ( $dirs ) > 0 ){
2012-03-29 13:07:10 +00:00
foreach ( $dirs as $nb => $dir ) {
$objet = new DirigeantOp ();
$objet -> Code = $dir [ 'Fonction' ];
$objet -> Titre = prepareString ( $dir [ 'Titre' ]);
$objet -> Societe = prepareString ( $dir [ 'Societe' ]);
$objet -> Civilite = prepareString ( $dir [ 'Civilite' ]);
$objet -> Nom = prepareString ( $dir [ 'Nom' ]);
$objet -> Prenom = prepareString ( $dir [ 'Prenom' ]);
$objet -> NomUsage = prepareString ( $dir [ 'NomUsage' ]);
$objet -> NaissDate = $dir [ 'NaissDate' ]; // 07/09/1961
$objet -> NaissVille = prepareString ( $dir [ 'NaissVille' ]); // LE RUSSEY
$objet -> NaissDepPays = prepareString ( $dir [ 'NaissDepPays' ]); // LE RUSSEY
$objet -> Ancien = $dir [ 'Ancien' ];
$objet -> DateFct = $dir [ 'DateFct' ];
$tabRet [] = $objet ;
}
}
$this -> wsLog ( 'dirigeantsOp' , $siren );
debugLog ( 'I' , 'Nb Dirigeants Op retournés = ' . count ( $dirs ), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
return $tabRet ;
}
2012-07-17 06:22:32 +00:00
/**
2012-03-29 13:07:10 +00:00
* Liste de tous les dépôts enregistrés à l ' INPI pour une entreprise
* @ param string $siren Siren de l ' entreprise
* @ return Depot []
*/
2012-07-17 06:22:32 +00:00
public function getListeDepots ( $siren )
2012-03-29 13:07:10 +00:00
{
$this -> authenticate ();
debugLog ( 'I' , " Liste des dépots INPI pour $siren " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
if ( strlen ( $siren ) > 9 || ( substr ( $siren , 0 , 9 ) * 1 ) < 100 ){
debugLog ( 'W' , " Siren $siren incorrect " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> sendError ( '1010' );
}
$iRncs = new MRncs ();
$evens = $iRncs -> getListeDepots ( $siren );
$tabRet = array ();
if ( count ( $evens ) > 0 ){
foreach ( $evens as $nb => $even ){
$objet = new Depot ();
$objet -> CodeDepot = $even [ 'codDepot' ];
$objet -> LibDepot = prepareString ( $even [ 'libDepot' ]);
$objet -> DateDepot = $even [ 'datDepot' ];
$objet -> RefDepot = $even [ 'refDepot' ];
$objet -> DateRncs = $even [ 'datRncs' ];
$objet -> DateMAJ = $even [ 'datSed' ];
2012-07-17 06:22:32 +00:00
$tabRet [] = $objet ;
2012-03-29 13:07:10 +00:00
}
}
debugLog ( 'I' , 'Nb dépôts retournés = ' . count ( $tabRet ), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
return $tabRet ;
}
/**
* Enter description here ...
* @ param string $siret
* @ param integer $id
* @ return IdentiteLight
*/
public function getIdentiteLight ( $siret , $id = 0 )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $id )) {
$id = 0 ;
}
$siret = trim ( $siret );
$len = strlen ( $siret );
$siren = substr ( $siret , 0 , 9 );
if ( $len == 14 ) {
$nic = substr ( $siret , 9 , 5 ) * 1 ;
} elseif ( $len == 9 ) {
$nic = 0 ;
}
if ( $siren * 1 == 0 && $id == 0 ) {
$this -> sendError ( '1010' );
}
if ( $len != 14 && $len != 9 ) {
$this -> sendError ( '1020' );
}
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $siren , $nic , $id );
$output = new IdentiteLight ();
$output -> id = $tabIdentite [ 'id' ];
$output -> Siret = $tabIdentite [ 'Siret' ];
$output -> Siege = $tabIdentite [ 'Siege' ];
$output -> Nom = $tabIdentite [ 'Nom' ];
$output -> Tribunal = $tabIdentite [ 'Tribunal' ];
$output -> Sigle = $tabIdentite [ 'Sigle' ];
$output -> Enseigne = $tabIdentite [ 'Enseigne' ];
$output -> Adresse = $tabIdentite [ 'Adresse' ];
$output -> Adresse2 = $tabIdentite [ 'Adresse2' ];
$output -> AdresseNum = $tabIdentite [ 'AdresseNum' ];
$output -> AdresseBtq = $tabIdentite [ 'AdresseBtq' ];
$output -> AdresseVoie = $tabIdentite [ 'AdresseVoie' ];
$output -> AdresseRue = $tabIdentite [ 'AdresseRue' ];
$output -> CP = $tabIdentite [ 'CP' ];
$output -> Ville = $tabIdentite [ 'Ville' ];
$output -> Tel = $tabIdentite [ 'Tel' ];
$output -> Fax = $tabIdentite [ 'Fax' ];
$output -> FJ = $tabIdentite [ 'FJ' ];
$output -> FJ_Lib = $tabIdentite [ 'FJ_lib' ];
$output -> Siren = $tabIdentite [ 'Siren' ];
$output -> Nic = $tabIdentite [ 'Nic' ];
$output -> Actif = $tabIdentite [ 'Actif' ];
$output -> NafEtab = $tabIdentite [ 'NafEtab' ];
$output -> NafEnt = $tabIdentite [ 'NafEnt' ];
$output -> NafEntLib = $tabIdentite [ 'NafEntLib' ];
$output -> NafEtabLib = $tabIdentite [ 'NafEtabLib' ];
$output -> AutreId = $tabIdentite [ 'AutreId' ];
$output -> Source = $tabIdentite [ 'Source' ];
$output -> SourceId = $tabIdentite [ 'SourceId' ];
$output -> Dept = $tabIdentite [ 'Dept' ];
$output -> codeCommune = $tabIdentite [ 'codeCommune' ];
$output -> Capital = $tabIdentite [ 'Capital' ];
$output -> CapitalDev = $tabIdentite [ 'CapitalDev' ];
$output -> TrancheCA = $tabIdentite [ 'TrancheCA' ];
$output -> TrancheCALib = $tabIdentite [ 'TrancheCALib' ];
$output -> EffEnTr = $tabIdentite [ 'EffEnTr' ];
$output -> EffEnTrLib = $tabIdentite [ 'EffEnTrLib' ];
$output -> EffEtTr = $tabIdentite [ 'EffEtTr' ];
$output -> EffEtTrLib = $tabIdentite [ 'EffEtTrLib' ];
return $output ;
}
/**
* Retourne les éléments du groupes
* @ param string $siren
* @ param int $pctMin ( 33 , 40 , 50 )
* @ param int $nbNiveaux
* @ return string
*/
public function getGroupesArbo ( $siren , $pctMin = 33 , $nbNiveaux = 10 )
{
$this -> authenticate ();
if ( empty ( $pctMin ) || ! in_array ( $pctMin , array ( 33 , 40 , 50 )) ) { $pctMin = 33 ; }
if ( empty ( $nbNiveaux ) ) { $nbNiveaux = 10 ; }
if ( strlen ( $siren ) != 9 || intval ( $siren ) < 100 ){
debugLog ( 'W' , " Siren $siren incorrect " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> sendError ( '1010' );
}
require_once 'Metier/partenaires/classMLiens.php' ;
$liens = new MLiens ( $siren );
$retour = $liens -> getArborescence ( $siren , $pctMin , $nbNiveaux );
2012-04-03 12:52:29 +00:00
$this -> wsLog ( 'groupesarbo' , $siren );
2012-07-17 06:22:32 +00:00
return json_encode ( $retour );
2012-03-29 13:07:10 +00:00
}
/**
* Retourne les information du groupe , tête de pont
* @ param string $siren
* @ return GroupeInfos
*/
public function getGroupeInfos ( $siren )
2012-07-17 06:22:32 +00:00
{
2012-03-29 13:07:10 +00:00
$this -> authenticate ();
if ( strlen ( $siren ) != 9 || intval ( $siren ) < 100 ){
debugLog ( 'W' , " Siren $siren incorrect " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> sendError ( '1010' );
}
2012-07-17 06:22:32 +00:00
$iDb = new WDB ( 'jo' );
2012-03-29 13:07:10 +00:00
$tmp = $iDb -> select ( 'etablissements_act' ,
'raisonSociale, enseigne, sigle, identite_pre, adr_num, adr_btq, adr_typeVoie, adr_libVoie, adr_comp, adr_cp, adr_ville, adr_dep, adr_com, tel, fax, siren, sirenGrp' ,
" siren=(SELECT distinct sirenGrp FROM etablissements_act WHERE siren= $siren AND siege=1) LIMIT 0,1 " , false , MYSQL_ASSOC );
2012-03-29 14:15:54 +00:00
$tabEnt = $tmp [ 0 ];
2012-03-29 13:07:10 +00:00
$sirenGrp = $tabEnt [ 'siren' ];
if ( $sirenGrp < 1000 ) {
throw new SoapFault ( 'Error' , 'Aucun siren de groupe' );
}
/** Table des Nafs5 => Secteurs **/
$tmp = $iDb -> select ( 'tabNaf5' , 'codNaf2, codNaf1' , '1 GROUP BY codNAf2' , false , MYSQL_ASSOC );
$tabNAf2 = array ();
foreach ( $tmp as $tmp2 ) {
$tabNAf2 [ $tmp2 [ 'codNaf2' ]] = $tmp2 [ 'codNaf1' ];
}
2012-07-17 06:22:32 +00:00
$tabNaf2Lib = array (
2012-03-29 13:07:10 +00:00
'A' => 'Agriculture, sylviculture et pêche' ,
'B' => 'Industries extractives' ,
'C' => 'Industrie manufacturière' ,
'D' => 'Production et distribution d\'électricité, de gaz, de vapeur et d\'air conditionné' ,
'E' => 'Production et distribution d\'eau ; assainissement, gestion des déchets et dépollution' ,
'F' => 'Construction' ,
'G' => 'Commerce ; réparation d\'automobiles et de motocycles' ,
'H' => 'Transports et entreposage' ,
'I' => 'Hébergement et restauration' ,
'J' => 'Information et communication' ,
'K' => 'Activités financières et d\'assurance' ,
'L' => 'Activités immobilières' ,
'M' => 'Activités spécialisées, scientifiques et techniques' ,
'N' => 'Activités de services administratifs et de soutien' ,
'O' => 'Administration publique' ,
'P' => 'Enseignement' ,
'Q' => 'Santé humaine et action sociale' ,
'R' => 'Arts, spectacles et activités récréatives' ,
'S' => 'Autres activités de services' ,
'T' => 'Activités des ménages en tant qu\'employeurs ; activités indifférenciées des ménages en tant que producteurs de biens et services pour usage propre' ,
'U' => 'Activités extra-territoriales' ,
);
2012-07-17 06:22:32 +00:00
$iInsee = new MInsee ();
2012-03-29 13:07:10 +00:00
$tabId = $iInsee -> getIdentiteEntreprise ( $sirenGrp );
//Chargement retour
$output = new GroupeInfos ();
$output -> grpNom = $tabEnt [ 'raisonSociale' ];
$output -> grpEnseigne = $tabEnt [ 'enseigne' ];
$output -> grpSigle = $tabEnt [ 'sigle' ];
$output -> grpAdrNum = $tabEnt [ 'adr_num' ];
$output -> grpAdrBtq = $tabEnt [ 'adr_btq' ];
$output -> grpAdrTypeVoie = $tabEnt [ 'adr_typeVoie' ];
$output -> grpadrLibVoie = $tabEnt [ 'adr_libVoie' ];
$output -> grpAdrComp = $tabEnt [ 'adr_comp' ];
$output -> grpAdrCP = $tabEnt [ 'adr_cp' ];
$output -> grpAdrVille = $tabEnt [ 'adr_ville' ];
$output -> grpAdrDep = $tabEnt [ 'adr_dep' ];
$output -> grpAdrCom = $tabEnt [ 'adr_com' ];
$output -> grpTel = $tabEnt [ 'tel' ];
$output -> grpFax = $tabEnt [ 'fax' ];
$output -> grpSiren = $tabEnt [ 'siren' ];
$output -> grpTva = $tabId [ 'TvaNumero' ];
$output -> grpIsin = $tabId [ 'Isin' ];
$output -> grpNumRC = $tabId [ 'numRC' ];
$output -> grpTribunal = $tabId [ 'TribunalLib' ];
$output -> grpWeb = $tabId [ 'Web' ];
$grpNbEnt = $grpEffectif = $grpCAExp = $grpCA = $nbProcol = 0 ;
$grpDateCrea = $grpDateImmat = date ( 'Ymd' );
$tmp = $iDb -> select ( 'jo.etablissements_act e' ,
'e.siren, e.eff_entrep, e.dateCrea_ent AS dateCrea, e.dateImmat*1 AS dateImmat, e.bilFK, e.bilFL, e.bilYP, e.ape_entrep, e.avisCs, e.procolHisto' ,
2012-07-17 06:22:32 +00:00
" e.sirenGrp= $sirenGrp AND e.siege=1 " , false , MYSQL_ASSOC );
2012-03-29 13:07:10 +00:00
$tabSirenGrp = array ();
$tabSecteur = array ();
$tabAvis = array ();
if ( count ( $tmp ) > 0 ) {
2012-07-17 06:22:32 +00:00
foreach ( $tmp as $tabEnt )
2012-03-29 13:07:10 +00:00
{
$tabSirenGrp [] = $tabEnt [ 'siren' ];
$grpNbEnt ++ ;
2012-07-17 06:22:32 +00:00
if ( $tabEnt [ 'bilYP' ] > $tabEnt [ 'eff_entrep' ])
2012-03-29 13:07:10 +00:00
$grpEffectif += $tabEnt [ 'bilYP' ];
2012-07-17 06:22:32 +00:00
else
2012-03-29 13:07:10 +00:00
$grpEffectif += $tabEnt [ 'eff_entrep' ];
if ( $tabEnt [ 'procolHisto' ] * 1 == 1 ) $nbProcol ++ ;
2012-07-17 06:22:32 +00:00
if ( $grpDateCrea > $tabEnt [ 'dateCrea' ] && $tabEnt [ 'dateCrea' ] >= 19000101 )
2012-03-29 13:07:10 +00:00
$grpDateCrea = $tabEnt [ 'dateCrea' ];
2012-07-17 06:22:32 +00:00
if ( $grpDateImmat > $tabEnt [ 'dateImmat' ] && $tabEnt [ 'dateImmat' ] >= 19000101 )
2012-03-29 13:07:10 +00:00
$grpDateImmat = $tabEnt [ 'dateImmat' ];
$grpCAExp += $tabEnt [ 'bilFK' ];
$grpCA += $tabEnt [ 'bilFL' ];
$tabSecteur [ $tabNAf2 [ '' . substr ( $tabEnt [ 'ape_entrep' ], 0 , 2 )]][ 'nb' ] ++ ;
$tabSecteur [ $tabNAf2 [ '' . substr ( $tabEnt [ 'ape_entrep' ], 0 , 2 )]][ 'ca' ] += $tabEnt [ 'bilFL' ];
$tabSecteur [ $tabNAf2 [ '' . substr ( $tabEnt [ 'ape_entrep' ], 0 , 2 )]][ 'eff' ] += $tabEnt [ 'eff_entrep' ];
$tabAvis [ $tabEnt [ 'avisCs' ]] ++ ;
}
}
$output -> grpNbProcolHisto = $nbProcol ;
$output -> grpCAExport = $grpCAExp ;
$output -> grpCA = $grpCA ;
if ( $grpCA >= 500000000 )
$output -> grpGrandGroupeFr = 1 ;
else
$output -> grpGrandGroupeFr = 0 ;
$output -> grpNbEntrep = $grpNbEnt ;
$output -> grpEffectif = $grpEffectif ;
$output -> grpAnneCreation = '' ;
if ( $grpDateCrea < $grpDateImmat )
$output -> grpAnneCreation = substr ( $grpDateCrea , 0 , 4 );
else
$output -> grpAnneCreation = substr ( $grpDateImmat , 0 , 4 );
//@todo : transformer le tableau
2012-07-17 06:22:32 +00:00
$output -> avisCs = json_encode ( $tabAvis ); // Vérifier les procol
2012-03-29 13:07:10 +00:00
$tabSecteur2 = array ();
if ( count ( $tabSecteur ) > 0 ) {
foreach ( $tabSecteur as $secteur => $tmp ) {
$info = new GroupeInfosSecteur ();
$info -> code = $secteur ;
$info -> lib = $tabNaf2Lib [ $secteur ];
$info -> entrepNb = $tmp [ 'nb' ];
$info -> entrepTx = round ( $tmp [ 'nb' ] * 100 / $grpNbEnt , 2 );
$info -> caNb = $tmp [ 'ca' ];
$info -> caTx = round ( $tmp [ 'ca' ] * 100 / $grpCA , 2 );
$info -> effNb = $tmp [ 'eff' ];
$info -> effTx = round ( $tmp [ 'eff' ] * 100 / $grpEffectif , 2 );
$tabSecteur2 [] = $info ;
}
}
2012-04-03 12:52:29 +00:00
$output -> secteur = $tabSecteur2 ; //@todo : transformer le tableau
$this -> wsLog ( 'groupeinfos' , $siren );
2012-07-17 06:22:32 +00:00
return $output ;
2012-03-29 13:07:10 +00:00
}
}