2013-11-05 11:18:30 +00:00
< ? php
2014-09-12 14:57:26 +00:00
require_once 'framework/fwk.php' ;
require_once 'framework/mail/sendMail.php' ;
require_once 'Metier/insee/classMInsee.php' ;
require_once 'Metier/insee/classMSirene.php' ;
require_once 'Metier/partenaires/classMBilans.php' ;
require_once 'Metier/partenaires/classMBourse.php' ;
require_once 'Metier/partenaires/classMTva.php' ;
require_once 'Metier/partenaires/classMMap.php' ;
require_once 'Metier/partenaires/classMGreffes.php' ;
require_once 'Metier/partenaires/classMPrivileges.php' ;
require_once 'Metier/scores/classMFinancier.php' ;
require_once 'Metier/scores/classMSolvabilite.php' ;
2014-05-24 16:57:17 +00:00
require_once __DIR__ . '/Types.php' ;
2013-11-05 11:18:30 +00:00
2014-05-24 16:57:17 +00:00
class Saisie extends Scores_Ws_Server
2013-11-05 11:18:30 +00:00
{
/**
* 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 ;
}
/**
* Enregistrement des informations saisie manuellement
* @ param string $siret
* @ param int $idEntreprise
* @ param string $infos
* @ return SetInfosEntrepReturn
*/
public function setInfosEntrep ( $siret , $idEntreprise , $infos )
{
$this -> authenticate ();
//Initialisation
$tabRet = array ();
$iBodacc = new MBodacc ();
$iInsee = new MInsee ();
$result = false ;
if ( ! $this -> checkEdition ()) {
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
} else {
$siren = substr ( $siret , 0 , 9 );
$nic = substr ( $siret , 9 , 5 );
$iDb = new WDB ();
$tabInfos = json_decode ( $infos , true );
$tabIdentite = $tabInfos [ 'identite' ];
$tabJugement = $tabInfos [ 'jugement' ];
$tabActio = $tabInfos [ 'actionnaire' ];
$tabParti = $tabInfos [ 'participation' ];
$tabScores = $tabInfos [ 'score' ];
2014-07-11 11:57:45 +00:00
//Valider le code Isin
if ( strlen ( trim ( $tabIdentite [ 'isin' ]))) {
$iBourse = new MBourse ();
if ( ! $iBourse -> isIsin ( $tabIdentite [ 'isin' ])) {
$error -> errnum = 1 ;
$error -> errmsg = 'Code Isin incorrect.' ;
$output = new SetInfosEntrepReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
}
2013-11-05 11:18:30 +00:00
// 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' ], '"\'./- ,\*#()' , ' ' ))),
);
2014-10-08 10:10:31 +00:00
$db = Zend_Db_Table_Abstract :: getDefaultAdapter ();
2014-10-31 13:02:24 +00:00
$sql = $db -> select () -> from ( 'infos_entrep' , array ( 'siren' ), 'jo' ) -> where ( 'siren=?' , $siren );
$result = $db -> fetchAll ( $sql );
2014-10-14 14:28:25 +00:00
if ( count ( $result ) == 0 ) {
2014-10-08 10:10:31 +00:00
try {
$isInserted = $db -> insert ( 'jo.infos_entrep' , array_merge ( array ( 'siren' => $siren ), $tabUpdate ));
} catch ( Zend_Db_Exception $e ) {
2014-10-14 14:28:25 +00:00
file_put_contents ( 'insert.log' , " INSERT = " . $e -> getMessage ());
2014-10-08 10:10:31 +00:00
}
2014-10-14 14:28:25 +00:00
} else {
try {
$isUpdated = $db -> update ( 'jo.infos_entrep' , $tabUpdate , " siren= $siren " );
} catch ( Zend_Db_Exception $e ) {
file_put_contents ( 'update.log' , " INSERT = " . $e -> getMessage ());
2014-10-08 10:10:31 +00:00
}
}
2013-11-05 11:18:30 +00:00
// 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
if ( isset ( $tabIdentite [ 'moisRefusRCS' ]) && $tabIdentite [ 'moisRefusRCS' ] > 0
&& $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 **/
$tabInsert = array (
'siren' => $siren ,
'nic' => $nic ,
2014-08-06 20:27:01 +00:00
'idSaisie' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'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 **/
$tabInsert = array (
'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 ());
}
// Fin refus d'inscription au RCS
// 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 = $tabJugement [ 'even' ];
$nic = $tabJugement [ 'nic' ] * 1 ;
$entrep = $iInsee -> getIdentiteLight ( $siren , $nic );
if ( $nic > 0 && $tabEven [ 0 ] == 6700 && $entrep [ 'Siege' ] == 0 ){
// Radiation d'un établissement
$tabEven [ 0 ] = 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' ]));
$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 = '' ;
if ( count ( $tabJugement [ 'nouvDir' ]) > 0 ) {
foreach ( $tabJugement [ 'nouvDir' ] 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 ),
'dateCessationPaiement' => empty ( $tabJugement [ 'datePaie' ]) ? '' :
WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabJugement [ 'datePaie' ])),
'dateEffetFinP' => empty ( $tabJugement [ 'dateFinPeriode' ]) ? '' :
WDate :: dateT ( 'd/m/Y' , 'Y-m-d' , trim ( $tabJugement [ 'dateFinPeriode' ])),
'tribunal' => trim ( $tabJugement [ 'tribunal' ]),
'montant' => $montant ,
'actionsNb' => $actionsNb ,
'inter1type' => 'A' ,
'inter1id' => $idAdmin ,
2014-04-09 13:41:26 +00:00
'inter1nom' => $iInsee -> getMandatairesParId ( $idAdmin ),
2013-11-05 11:18:30 +00:00
'inter2type' => 'M' ,
'inter2id' => $idMand ,
2014-04-09 13:41:26 +00:00
'inter2nom' => $iInsee -> getMandatairesParId ( $idMand ),
2013-11-05 11:18:30 +00:00
'inter3type' => 'O' ,
'inter3id' => $idOppo ,
2014-04-09 13:41:26 +00:00
'inter3nom' => $iInsee -> getMandatairesParId ( $idOppo ),
2013-11-05 11:18:30 +00:00
'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 ,
2014-08-06 20:27:01 +00:00
'idSaisie' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'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 ;
}
}
}
// Insertion actionnaire
if ( trim ( $tabActio [ 'siren' ]) != '' ) {
$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' ))
);
$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 ;
}
/**
2014-06-19 12:03:15 +00:00
* Informations Mandataires
2013-11-05 11:18:30 +00:00
* @ param SetInfosMandataire $infos Informations sur le mandataire à créer ou à ajouter ( ajout si id absent )
2014-06-19 12:03:15 +00:00
* @ return boolean
2013-11-05 11:18:30 +00:00
*/
2014-06-19 12:03:15 +00:00
public function setMandataire ( $infos )
2013-11-05 11:18:30 +00:00
{
$this -> authenticate ();
//Initialisation
2014-06-19 12:03:15 +00:00
$result = false ;
2013-11-05 11:18:30 +00:00
$type = substr ( strtoupper ( $infos -> type ), 0 , 1 );
$stag = substr ( strtoupper ( $infos -> type ), 1 , 1 );
2014-06-19 12:03:15 +00:00
if ( $stag == 'S' ) {
$stag = 1 ;
2013-11-05 11:18:30 +00:00
} else {
2014-06-19 12:03:15 +00:00
$stag = 0 ;
2013-11-05 11:18:30 +00:00
}
2014-06-19 12:03:15 +00:00
if ( in_array ( $type , array ( 'A' , 'H' , 'M' , 'V' , 'N' , '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 ,
2014-08-06 20:27:01 +00:00
'idUser' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
);
2014-06-19 12:03:15 +00:00
$model = new Application_Model_JoTabMandataires ();
$id = intval ( str_replace ( 'm' , '' , '' . $infos -> id ));
if ( intval ( $id ) != 0 ) {
try {
$model -> update ( $tabUpdate , 'id=' . $id );
return true ;
} catch ( Zend_Db_Exception $e ){
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} else {
try {
$tabUpdate [ 'dateInsert' ] = date ( 'YmdHis' );
$model -> insert ( $tabUpdate );
return true ;
} catch ( Zend_Db_Exception $e ){
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
2013-11-05 11:18:30 +00:00
}
2014-06-19 12:03:15 +00:00
return false ;
2013-11-05 11:18:30 +00:00
}
/**
* Supprime une annonce issue de la collecte
* @ param string $idAnn
* @ param string $siret
* @ return SupprAnnonceCollecteReturn
*/
public function supprAnnonceCollecte ( $idAnn , $siret = null )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $siret )) $siret = 0 ;
$error = new ErrorType ();
$result = false ;
if ( ! $this -> checkEdition ())
{
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
}
else
{
$siren = substr ( $siret , 0 , 9 ) * 1 ;
$iDb = new WDB ();
$idAnn = preg_replace ( '/^0\./' , '' , '' . $idAnn ) * 1 ;
if ( $idAnn > 0 )
{
if ( $iDb -> update ( 'annonces' , array (
'dateSuppr' => date ( 'YmdHis' ),
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
" id= $idAnn " , false ))
{
debugLog ( 'I' , " Suppression de l'annonce collectée n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$result = true ;
}
else
{
$error -> errnum = 1 ;
$error -> errmsg = 'Suppression de l\'annonce impossible' ;
debugLog ( 'I' , " Suppression impossible de l'annonce collectée n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
}
}
else
{
$error -> errnum = 1 ;
$error -> errmsg = 'idAnn incorrect' ;
}
}
$output = new SupprAnnonceCollecteReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Récupère le mandataire par son id
* @ param int $id Identifiant du mandataire
* @ return string
*/
public function getMandataire ( $id )
{
$this -> authenticate ();
require_once 'Metier/insee/classMInsee.php' ;
$iInsee = new MInsee ();
$tabRet = $iInsee -> getMandataire ( $id );
return json_encode ( $tabRet );
}
/**
* 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 ;
}
/**
* 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 );
}
/**
* Duplique une annonce issue de la collecte
* @ param string $idAnn
* @ param string $siret
* @ return DupliqueAnnonceReturn
*/
public function dupliqueAnnonceCollecte ( $idAnn , $siret = null )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $siret )) $siret = '' ;
$error = new ErrorType ();
$result = 0 ;
if ( ! $this -> checkEdition ()) {
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
} else {
$siren = intval ( substr ( $siret , 0 , 9 ));
$nic = intval ( substr ( $siret , 9 , 5 ));
$iDb = new WDB ();
$idAnn = intval ( preg_replace ( '/^0\./' , '' , '' . $idAnn ));
if ( $idAnn > 0 && $siren > 1000 ){
$res = $iDb -> select ( 'annonces' , '*' , " id= $idAnn " , false , MYSQL_ASSOC );
if ( count ( $res ) == 0 ) {
$error -> errnum = 1 ;
$error -> errmsg = 'Annonce inexistante' ;
} else {
$annonce = $res [ 0 ];
// Suppression des zones inexistantes dans la table ou devant être vides
unset ( $annonce [ 'id' ]);
unset ( $annonce [ 'nic' ]); //=$nic;
$annonce [ 'siren' ] = $siren ;
$annonce [ 'nic' ] = $nic ;
if ( $iDb -> insert ( 'annonces' , $annonce , false )) {
debugLog ( 'I' , " Duplication de l'annonce collectée n° $idAnn sur $siret " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$result = 1 ;
} else {
debugLog ( 'I' , " Suppression impossible de l'annonce collectée n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = 'Suppression de l\'annonce impossible' ;
}
}
}
}
$output = new DupliqueAnnonceCollecte ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* 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 ;
if ( ! $this -> checkEdition ()) {
$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' ,
2014-09-08 06:53:37 +00:00
'id, LPAD(siren,9,0) AS 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' ,
2013-11-05 11:18:30 +00:00
" 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 ;
}
/**
* 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 ( ST )
* @ param string $libelle Libellé de l ' acte
* @ param string $date Date de l ' acte au format AAAAMMDD
* return boolean
*/
public function setActeAsso ( $siren , $waldec , $type , $libelle , $date )
{
$this -> authenticate ();
if ( ! $this -> checkEdition ()) {
$this -> sendError ( '0902' );
}
( $type == 'ST' ) ? $type_acte = 'ST' : $type_acte = 'ST' ;
$data = array (
'siren' => $siren ,
'waldec' => $waldec ,
'pdfLink' => '' ,
'pdfSize' => '' ,
'pdfVer' => '' ,
'pdfPage' => '' ,
'date_acte' => WDate :: dateT ( 'Ymd' , 'Y-m-d' , $date ),
'type_acte' => $type_acte ,
'type_acte_libelle' => $libelle ,
);
//Save
try {
$doc = new Application_Model_AssoActes ();
$id = $doc -> insert ( $data );
} catch ( Zend_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
return $id ;
}
/**
* 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 ;
}
/**
* Suppression logique d ' une annonce relative à une entité
* @ param integer $source 0 = Collecte , 1 = BODACC , 2 = B . A . L . O , 3 = JO Association , 4 = Boamp
* @ param string $idAnn Identifiant de l ' annonce
* @ param string $siret Siren de l 'entreprise ou Siret de l' établissement
* @ return SupprAnnonceReturn
*/
public function supprAnnonce ( $source = 0 , $idAnn , $siret = 0 )
{
$this -> authenticate ();
//Initialisation
if ( empty ( $siret )) $siret = 0 ;
if ( empty ( $source )) $source = 0 ;
$error = new ErrorType ();
$result = false ;
if ( ! $this -> checkEdition ())
{
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
}
else
{
$siren = substr ( $siret , 0 , 9 );
$iDb = new WDB ();
switch ( $source )
{
case 0 :
$idAnn = preg_replace ( '/^0\./' , '' , '' . $idAnn ) * 1 ;
$table = 'annonces' ;
break ;
case 1 :
if ( intval ( $idAnn ) < 0 ){
$error -> errnum = 1 ;
$error -> errmsg = 'Code annonce Incorrect' ;
} else {
$strSql = " AND siren= $siren " ;
$table = 'bodacc_detail' ;
}
break ;
case 3 :
$table = 'asso' ;
break ;
case 2 :
case 4 :
default :
$error -> errnum = 1 ;
$error -> errmsg = 'Cas non géré' ;
break ;
}
if ( intval ( $idAnn ) > 0 && $iDb -> update ( $table , array (
'dateSuppr' => date ( 'YmdHis' ),
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
" id= $idAnn $strSql " , false ))
{
debugLog ( 'I' , " Suppression de l'annonce en source $source n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 0 ;
$error -> errmsg = '' ;
$result = true ;
} else {
debugLog ( 'I' , " Suppression impossible de l'annonce en source $source n° $idAnn ( $siret ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = 'Suppression de l\'annonce impossible' ;
}
}
$output = new SupprAnnonceReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Duplication d ' une annonce relative à une entité
*
* @ param integer $source 0 = Collecte , 1 = BODACC , 2 = B . A . L . O , 3 = JO Association , 4 = Boamp
* @ param string $idAnn Identifiant de l ' annonce
* @ param string $siretIn Siren de l 'entreprise ou Siret de l' établissement de l ' annonce à duppliquer
* @ param string $siretOut Siren / Siret de l 'entreprise ou étab sur lequel il faut dupliquer l' annonce
* @ return DupliqueAnnonceReturn
*/
public function dupliqueAnnonce ( $source = 0 , $idAnn , $siretIn = 0 , $siretOut = 0 )
{
debugLog ( 'I' , " Demande de duplication d'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$this -> authenticate ();
//Initialisation
if ( empty ( $siret )) $siret = 0 ;
if ( empty ( $source )) $source = 0 ;
$error = new ErrorType ();
$result = false ;
if ( ! $this -> checkEdition ())
{
$error -> errnum = 1 ;
$error -> errmsg = 'Code Client Incorrect' ;
}
else
{
$sirenIn = substr ( $siretIn , 0 , 9 ) * 1 ;
$nicIn = substr ( $siretIn , 9 , 5 ) * 1 ;
$sirenOut = substr ( $siretOut , 0 , 9 ) * 1 ;
$nicOut = substr ( $siretOut , 9 , 5 ) * 1 ;
$iDb = new WDB ();
$strSql = '' ;
switch ( $source )
{
//
case 0 :
$idAnn = preg_replace ( '/^0\./' , '' , '' . $idAnn ) * 1 ;
$table = 'annonces' ;
break ;
//Bodacc
case 1 :
if ( intval ( $idAnn ) < 0 ) {
//@todo : Must be possible
$error -> errnum = 1 ;
$error -> errmsg = 'Code annonce Incorrect' ;
} else {
if ( intval ( $sirenIn ) > 0 ) $strSql .= " AND siren= $sirenIn " ;
$table = 'bodacc_detail' ;
}
break ;
//Association
case 3 :
$table = 'asso' ;
break ;
//
case 2 :
//
case 4 :
//
default :
$error -> errnum = 1 ;
$error -> errmsg = 'Cas non géré' ;
break ;
}
if ( intval ( $idAnn ) > 0 ) {
2014-03-17 10:04:40 +00:00
//@todo : define fields LPAD(siren,9,0) as siren
2013-11-05 11:18:30 +00:00
$res = $iDb -> select ( $table , '*' , " id= $idAnn $strSql " , false , MYSQL_ASSOC );
if ( count ( $res ) == 0 ) {
$error -> errnum = 1 ;
$error -> errmsg = 'Annonce inexistante' ;
} else {
/* Si table = asso => UPDATE de la ligne */
if ( $table == 'asso' ){
//$annonce = $res[0];
$annonce [ 'siren' ] = $sirenOut ;
$annonce [ 'sirenValide' ] = 2 ;
$annonce [ 'dateUpdate' ] = date ( 'YmdHis' );
2014-08-06 20:27:01 +00:00
$annonce [ 'idSirenage' ] = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
$annonce [ 'nic' ] = $nicOut ;
if ( $nicOut > 0 ) $annonce [ 'nicValide' ] = 2 ;
if ( $iDb -> update ( $table , $annonce , " id= " . $idAnn , true , true )) {
debugLog ( 'I' , " Duplication de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
//Si WALDEC présent dans l'annonce alors on rapproche tout
if ( $res [ 'Waldec' ] != '' ) {
$iDb -> update ( $table , $annonce , " Waldec= " . $res [ 'Waldec' ], false );
}
$result = true ;
} else {
debugLog ( 'I' , " Duplication impossible de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) : " . mysql_error (), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = " Duplication de l'annonce impossible " ;
}
}
/* Si sirenIn = 0 et table = bodacc_detail => INSERT + UPDATE */
elseif ( intval ( $sirenIn ) == 0 && $table == 'bodacc_detail' ) {
$annonce = $res [ 0 ];
$annonce [ 'siren' ] = $sirenOut ;
$annonce [ 'sirenValide' ] = 2 ;
$annonce [ 'dateInsert' ] = date ( 'YmdHis' );
2014-08-06 20:27:01 +00:00
$annonce [ 'idSirenage' ] = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
$annonce [ 'nic' ] = $nicOut ;
if ( $nicOut > 0 ) $annonce [ 'nicValide' ] = 2 ;
if ( $iDb -> insert ( $table , $annonce , true , true )) {
debugLog ( 'I' , " Duplication de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$result = true ;
$data = array (
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateSuppr' => date ( 'YmdHis' ),
);
$iDb -> update ( $table , $data , " id= $idAnn $strSql " , true , true );
} else {
debugLog ( 'I' , " Duplication impossible de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) : " . mysql_error (), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = " Duplication de l'annonce impossible " ;
}
}
/* si sirenIn != 0 et table = bodacc_detail => insert */
elseif ( intval ( $sirenIn ) != 0 && $table == 'bodacc_detail' ) {
$annonce = $res [ 0 ];
$annonce [ 'siren' ] = $sirenOut ;
$annonce [ 'sirenValide' ] = 2 ;
$annonce [ 'dateInsert' ] = date ( 'YmdHis' );
2014-08-06 20:27:01 +00:00
$annonce [ 'idSirenage' ] = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
$annonce [ 'nic' ] = $nicOut ;
if ( $nicOut > 0 ) $annonce [ 'nicValide' ] = 2 ;
if ( $iDb -> insert ( $table , $annonce , true , true )) {
debugLog ( 'I' , " Duplication de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$result = true ;
} else {
debugLog ( 'I' , " Duplication impossible de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) : " . mysql_error (), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = " Duplication de l'annonce impossible " ;
}
}
/* Si table = annonces => INSERT */
elseif ( $table == 'annonces' ){
$annonce = $res [ 0 ];
// Suppression des zones inexistantes dans la table ou devant être vides
unset ( $annonce [ 'id' ]);
unset ( $annonce [ 'nic' ]);
2014-08-06 20:27:01 +00:00
$annonce [ 'idSaisie' ] = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
if ( $iDb -> insert ( $table , $annonce , true , true )) {
debugLog ( 'I' , " Duplication de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$result = true ;
} else {
debugLog ( 'I' , " Duplication impossible de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) : " . mysql_error (), __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = " Duplication de l'annonce impossible " ;
}
}
}
} else {
debugLog ( 'I' , " Duplication impossible de l'annonce en source $source sur n° $idAnn (siretIn= $siretIn , siretOut= $siretOut ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
$error -> errnum = 1 ;
$error -> errmsg = " Duplication de l'annonce impossible " ;
}
}
$output = new DupliqueAnnonceReturn ();
$output -> error = $error ;
$output -> result = $result ;
return $output ;
}
/**
* Modification du code evenement d ' une annonce
* @ param string $siren
* @ param string $id
* @ param string [] $codeEven
* @ return boolean
*/
public function setAnnonceEven ( $siren , $id , $codeEven )
{
$this -> authenticate ();
$iDb = new WDB ( 'jo' );
$list = array ();
if ( is_object ( $codeEven )){
$list = $codeEven -> item ;
} else {
$list = $codeEven ;
}
//Get Rubrique of event
$eventM = new Application_Model_JoTabEvenements ();
$sql = $eventM -> select () -> where ( 'codEven=?' , $list [ 0 ]);
$row = $eventM -> fetchRow ( $sql );
if ( count ( $list ) > 0 ){
$tabUpdate = array (
'typeEven' => implode ( ';' , $list ),
'Rubrique' => $row -> Rubrique ,
2014-08-06 20:27:01 +00:00
'idSirenage' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
);
if ( $iDb -> update ( 'bodacc_detail' , $tabUpdate , " siren=' $siren ' AND id=' $id ' " )){
debugLog ( 'I' , " setAnnonceEven (siren= $siren , list= $list ) " , __LINE__ , __FILE__ , __FUNCTION__ , __CLASS__ );
return true ;
}
}
return false ;
}
/**
* Enregistre une information de contact
* @ param string $siret
2013-12-26 14:25:59 +00:00
* SIRET ou SIREN
2013-11-05 11:18:30 +00:00
* @ param string $type
2013-12-26 14:25:59 +00:00
* Type de l ' information ( tel | fax | mail | mob | web )
2013-11-05 11:18:30 +00:00
* @ param string $value
2013-12-26 14:25:59 +00:00
* Valeur
2013-11-05 11:18:30 +00:00
* @ param string $info
2013-12-26 14:25:59 +00:00
* Information complémentaire ( use for type " tel " as description )
* @ param int id
* Id ( only for editing )
2014-03-19 07:22:36 +00:00
* @ param boolean $delete
* Marqueur de suppression
2013-11-05 11:18:30 +00:00
* @ return int
2013-12-26 14:25:59 +00:00
* Retourne l 'identifiant de l' élément ou le nombre de ligne lors d ' un update
2013-11-05 11:18:30 +00:00
*/
2014-03-19 07:22:36 +00:00
public function setContactEt ( $siret , $type , $value , $info , $id = null , $delete = false )
2013-11-05 11:18:30 +00:00
{
$this -> authenticate ();
2014-08-06 20:27:01 +00:00
$idUtilisateur = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
2014-03-19 07:22:36 +00:00
//Delete
if ( $delete === true ) {
try {
$telephonieM = new Application_Model_JoTelephonie ();
2014-03-20 16:28:31 +00:00
$data = array (
'dateSuppr' => date ( 'YmdHis' ),
'idSuppr' => $idUtilisateur ,
);
2014-03-19 07:22:36 +00:00
$id = $telephonieM -> update ( $data , 'id=' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2014-03-19 07:22:36 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
return $id ;
}
2013-11-05 11:18:30 +00:00
//Control input value
2014-03-18 20:32:36 +00:00
if ( strlen ( $siret ) != 9 && strlen ( $siret ) != 14 ) {
2013-11-05 11:18:30 +00:00
$this -> sendError ( '1010' );
}
$siren = substr ( $siret , 0 , 9 );
if ( intval ( $siren ) == 0 ) {
$this -> sendError ( '1010' );
}
2014-03-18 20:32:36 +00:00
$nic = substr ( $siret , 10 , 5 );
2013-11-05 11:18:30 +00:00
if ( intval ( $nic ) == 0 ) {
$nic = '00000' ;
}
if ( ! in_array ( $type , array ( 'an8' , 'domaines' , 'fax' , 'logo' , 'mail' , 'mob' , 'tel' , 'web' ) ) ) {
throw new SoapFault ( 'ERR' , " unknow value for type " );
}
switch ( $type ) {
2014-03-20 16:28:31 +00:00
case 'mail' :
case 'web' :
case 'domaines' :
$info = $value ;
$value = 0 ;
break ;
2013-11-05 11:18:30 +00:00
case 'tel' :
2014-03-18 20:32:36 +00:00
$value = intval ( $value );
2013-11-05 11:18:30 +00:00
break ;
}
$iInsee = new MInsee ();
$entrep = $iInsee -> getIdentiteLight ( $siren , $nic );
if ( empty ( $entrep [ 'id' ]) || intval ( $entrep [ 'id' ]) == 0 ) {
$this -> sendError ( '1020' );
}
$data = array (
'siren' => $siren ,
'nic' => $nic ,
'dateProvPartenaire' => date ( 'Y' ) . date ( 'm' ) . date ( 'd' ),
2013-12-26 14:25:59 +00:00
'typeTel' => $type ,
2013-11-05 11:18:30 +00:00
'infoTel' => $info ,
'telephone' => $value ,
2013-12-26 14:25:59 +00:00
'actif' => 1 ,
'partenaire' => 175 ,
2013-11-05 11:18:30 +00:00
);
2013-12-26 14:25:59 +00:00
if ( $id === null ) {
try {
2014-03-18 20:32:36 +00:00
$data [ 'idUtilisateur' ] = $idUtilisateur ;
$data [ 'dateInsert' ] = date ( 'YmdHis' );
2013-12-26 14:25:59 +00:00
$telephonieM = new Application_Model_JoTelephonie ();
$id = $telephonieM -> insert ( $data );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2014-03-18 20:32:36 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-12-26 14:25:59 +00:00
} else {
2014-03-18 20:32:36 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
2013-12-26 14:25:59 +00:00
}
}
} else {
2014-03-18 20:32:36 +00:00
$data [ 'idUpdate' ] = $idUtilisateur ;
$data [ 'dateUpdate' ] = date ( 'YmdHis' );
2013-12-26 14:25:59 +00:00
try {
$telephonieM = new Application_Model_JoTelephonie ();
$id = $telephonieM -> update ( $data , 'id=' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2014-03-18 20:32:36 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
2013-12-26 14:25:59 +00:00
}
}
return $id ;
}
/**
* Get a contact
* @ param int $id
* @ throws SoapFault
* @ return string
*/
public function getContactEt ( $id )
{
$this -> authenticate ();
2014-03-18 20:32:36 +00:00
$contactM = new Application_Model_JoTelephonie ();
2013-11-05 11:18:30 +00:00
try {
2014-03-20 16:28:31 +00:00
$sql = $contactM -> select ( true ) -> columns ( array (
'id' ,
'LPAD(siren,9,0) AS siren' ,
'LPAD(nic,5,0) AS nic' ,
'dateProvPartenaire' ,
'typeTel' ,
'infoTel' ,
'telephone' ,
'actif' ,
'partenaire' ,
'idUtilisateur' ,
'DATE_FORMAT(dateInsert, "%Y-%m-%d") AS dateInsert' ,
'idUpdate' ,
'DATE_FORMAT(dateUpdate, "%Y-%m-%d") AS dateUpdate' ,
'idSuppr' ,
'DATE_FORMAT(dateSuppr, "%Y-%m-%d") AS dateSuppr' ,
)) -> where ( 'id=?' , $id );
$row = $contactM -> fetchRow ( $sql );
2013-11-05 11:18:30 +00:00
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2014-03-20 16:28:31 +00:00
} else {
throw new SoapFault ( 'ERR' , " Application error " );
2013-11-05 11:18:30 +00:00
}
}
2014-03-18 20:32:36 +00:00
$result = $row -> toArray ();
$userM = new Application_Model_Sdv1Utilisateurs ();
if ( $result [ 'idUtilisateur' ] != 0 ) {
2014-03-20 16:28:31 +00:00
$sql = $userM -> select ( true ) -> columns ( array ( 'login' , 'nom' , 'prenom' )) -> where ( 'id=?' , $result [ 'idUtilisateur' ]);
2014-03-18 20:32:36 +00:00
$row = $userM -> fetchRow ( $sql );
$result [ 'idUtilisateurName' ] = $row -> nom . ' ' . $row -> prenom ;
}
if ( $result [ 'idUpdate' ] != 0 ) {
2014-03-20 16:28:31 +00:00
$sql = $userM -> select ( true ) -> columns ( array ( 'login' , 'nom' , 'prenom' )) -> where ( 'id=?' , $result [ 'idUpdate' ]);
2014-03-18 20:32:36 +00:00
$row = $userM -> fetchRow ( $sql );
$result [ 'idUpdateName' ] = $row -> nom . ' ' . $row -> prenom ;
}
if ( $result [ 'idSuppr' ] != 0 ) {
2014-03-20 16:28:31 +00:00
$sql = $userM -> select ( true ) -> columns ( array ( 'login' , 'nom' , 'prenom' )) -> where ( 'id=?' , $result [ 'idSuppr' ]);
2014-03-18 20:32:36 +00:00
$row = $userM -> fetchRow ( $sql );
$result [ 'idSupprName' ] = $row -> nom . ' ' . $row -> prenom ;
}
2013-12-26 14:25:59 +00:00
return json_encode ( $result );
2013-11-05 11:18:30 +00:00
}
2013-12-26 14:25:59 +00:00
2013-11-05 11:18:30 +00:00
/**
* Saisie d ' un bilan
* @ param string $siren
2014-10-29 15:24:17 +00:00
* SIREN de l ' entité
* @ param string $cloture
* Date de cloture original
* @ param string $type
* Type original du bilan
2013-11-05 11:18:30 +00:00
* @ param BilanInfos $data
2014-10-29 15:24:17 +00:00
* Postes et Information du bilan
2013-11-05 11:18:30 +00:00
* @ param string $step ( normal | nocheck | onlycheck )
2014-10-29 15:24:17 +00:00
* Etape
2013-11-05 11:18:30 +00:00
* @ return int
* @ throws SoapFault
*/
2014-10-29 15:24:17 +00:00
public function setBilan ( $siren , $cloture , $type , $data , $step = null )
2013-11-05 11:18:30 +00:00
{
$this -> authenticate ();
2015-02-06 11:10:56 +00:00
// --- Control input value
2013-11-05 11:18:30 +00:00
if ( strlen ( $siren ) != 9 ) {
$this -> sendError ( '1010' );
}
$tabPostes = array ();
2015-02-06 11:10:56 +00:00
// --- Control des valeurs
2014-02-07 16:14:36 +00:00
if ( ! in_array ( $data -> unite , array ( '' , 'U' , 'K' , 'M' )) ) {
throw new SoapFault ( 'MSG' , " Erreur Unite " );
}
2013-11-05 11:18:30 +00:00
if ( ! preg_match ( '/[0-9]{8}/' , $data -> dateCloture )) {
throw new SoapFault ( 'MSG' , " Erreur Date de cloture " );
}
2014-10-29 15:24:17 +00:00
if ( $data -> dateCloturePre != 'AAAAMMJJ' && ! preg_match ( '/[0-9]{8}/' , $data -> dateCloturePre )) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'MSG' , " Erreur Date de cloture précédente " );
}
2014-10-29 15:24:17 +00:00
if ( $data -> dateCloturePre == 'AAAAMMJJ' ) {
2013-11-05 11:18:30 +00:00
$data -> dateCloturePre = 0 ;
}
2014-10-29 15:24:17 +00:00
if ( intval ( $data -> dureeMois ) < 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'MSG' , " Erreur Durée " );
}
2014-10-29 15:24:17 +00:00
if ( $data -> dureeMoisPre != 0 && intval ( $data -> dureeMoisPre ) < 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'MSG' , " Erreur Durée précédente " );
}
if ( ! empty ( $data -> postes )) {
$listPostes = explode ( ';' , $data -> postes );
foreach ( $listPostes as $strPoste ) {
$itemPoste = explode ( '=' , $strPoste );
2015-02-06 11:10:56 +00:00
if ( ! is_numeric ( $itemPoste [ 1 ]) ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'MSG' , " Erreur poste " . $itemPoste [ 0 ]);
break ;
}
$tabPostes [ $itemPoste [ 0 ]] = intval ( $itemPoste [ 1 ]);
}
} else {
throw new SoapFault ( 'MSG' , " Aucun poste saisi " );
}
2015-02-06 11:10:56 +00:00
// --- Mathematic control
if ( $step != 'nocheck' && count ( $tabPostes ) > 0 )
2013-11-05 11:18:30 +00:00
{
2015-02-06 11:10:56 +00:00
require_once 'Metier/partenaires/classMBilansInput.php' ;
$control = new MBilansInput ();
try {
$control -> control ( $data -> typeBilan , $tabPostes );
} catch ( Exception $e ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
// --- End of Mathematic control
2013-11-05 11:18:30 +00:00
if ( $step == 'onlycheck' ) {
return 1 ;
2015-02-06 11:10:56 +00:00
}
// --- Insertion dans la bdd
else {
2013-11-05 11:18:30 +00:00
try {
$bilansM = new Application_Model_JoBilans ();
$sql = $bilansM -> select ()
-> where ( 'siren=?' , $siren )
2014-10-29 15:24:17 +00:00
-> where ( 'dateExercice=?' , $cloture )
-> where ( 'typeBilan=?' , $type );
2013-11-05 11:18:30 +00:00
$row = $bilansM -> fetchRow ( $sql );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
2013-11-06 14:29:20 +00:00
$postesDiff = array ();
2014-10-29 15:24:17 +00:00
if ( $row !== null ) {
2013-11-05 11:18:30 +00:00
2015-02-06 11:10:56 +00:00
// --- Make the diff
2013-11-06 14:29:20 +00:00
$postesDiff = array_diff ( explode ( ';' , $data -> postes ), explode ( ';' , $row -> postes ));
2015-02-06 11:10:56 +00:00
// --- Backup in historiques
2013-11-05 11:18:30 +00:00
$historiquesM = new Application_Model_HistoriquesBilans ();
$backupData = $row -> toArray ();
unset ( $backupData [ 'id' ]);
try {
$historiquesM -> insert ( $backupData );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
2015-02-06 11:10:56 +00:00
// --- Define data
2013-11-05 11:18:30 +00:00
$dataToUpdate = array (
2014-10-29 15:24:17 +00:00
'dateProvPartenaire' => date ( 'Ymd' ),
'dateExercice' => $data -> dateCloture ,
2013-11-05 11:18:30 +00:00
'dateExercicePre' => $data -> dateCloturePre ,
'dureeExercice' => $data -> dureeMois ,
'dureeExercicePre' => $data -> dureeMoisPre ,
2014-10-29 15:24:17 +00:00
'monnaie' => 'EUR' ,
'typeBilan' => $data -> typeBilan ,
2013-11-05 11:18:30 +00:00
'monnaieOrigine' => 'EUR' ,
'unite' => $data -> unite ,
'postes' => $data -> postes ,
'partenaire' => 1 ,
'confidentiel' => 0 ,
'dateInsert' => date ( 'YmdHis' ),
);
2015-02-06 11:10:56 +00:00
// --- Update
2013-11-05 11:18:30 +00:00
try {
$id = $bilansM -> update ( $dataToUpdate , 'id = ' . $row -> id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
} else {
2015-02-06 11:10:56 +00:00
// --- Define data
2013-11-05 11:18:30 +00:00
$dataToInsert = array (
'siren' => $siren ,
'dateProvPartenaire' => date ( 'Ymd' ),
'dateExercice' => $data -> dateCloture ,
'dateExercicePre' => $data -> dateCloturePre ,
'dureeExercice' => $data -> dureeMois ,
'dureeExercicePre' => $data -> dureeMoisPre ,
'monnaie' => 'EUR' ,
'typeBilan' => $data -> typeBilan ,
'monnaieOrigine' => 'EUR' ,
'unite' => $data -> unite ,
'postes' => $data -> postes ,
'partenaire' => 1 ,
'confidentiel' => 0 ,
'dateInsert' => date ( 'YmdHis' ),
);
2015-02-06 11:10:56 +00:00
// --- Insert
2013-11-05 11:18:30 +00:00
try {
$id = $bilansM -> insert ( $dataToInsert );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
if ( empty ( $id )) {
throw new SoapFault ( 'ERR' , " Application error " );
}
2015-02-06 11:10:56 +00:00
// --- Save user
2013-11-05 11:18:30 +00:00
$userM = new Application_Model_JoBilansUser ();
try {
$userM -> insert ( array (
2014-08-06 20:27:01 +00:00
'idUtilisateur' => $this -> User -> id ,
'login' => $this -> User -> login ,
2013-11-05 11:18:30 +00:00
'siren' => $siren ,
'dateExercice' => $data -> dateCloture ,
'typeBilan' => $data -> typeBilan ,
'dateAction' => date ( 'YmdHis' ),
2013-11-06 14:29:20 +00:00
'postesDiff' => implode ( ';' , $postesDiff ),
2013-11-05 11:18:30 +00:00
));
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
return $id ;
}
}
/**
* Créer un identifiant local pour un pays
* @ param string $infos
* @ param string $id
* @ throws SoapFault
* @ return int
*/
public function setCountryId ( $infos , $id = null )
{
$this -> authenticate ();
$data = json_decode ( $infos , true );
if ( $id !== null ) {
//Update
try {
$countryIdM = new Application_Model_JoTabIdLocal ();
$id = $countryIdM -> update ( $data , 'id = ' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
} else {
//Insert
try {
$countryIdM = new Application_Model_JoTabIdLocal ();
$id = $countryIdM -> insert ( $data );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
return $id ;
}
/**
* Get lien informations
* @ param int $id
* @ throws SoapFault
* @ return string
*/
public function getLien ( $id )
{
$this -> authenticate ();
$lienM = new Application_Model_JoLiens ();
try {
$row = $lienM -> find ( $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
$result = $row -> current () -> toArray ();
return json_encode ( $result );
}
/**
* Définition d ' un lien
* @ param string $infos
* @ param int $id
* @ throws SoapFault
* @ return int
*/
public function setLien ( $infos , $id = null )
{
$this -> authenticate ();
$dataLien = json_decode ( $infos , true );
$dataLien [ 'source' ] = 1900 ;
$lienM = new Application_Model_JoLiens ();
//Test si PDetention >= 100
if ( $dataLien [ 'actif' ] != 0 ) {
$sql = $lienM -> select () -> from ( $lienM , array (
'idPar' , new Zend_Db_Expr ( 'SUM( PDetention ) AS sumDet' )
))
-> where ( 'idPar=?' , $dataLien [ 'idPar' ]);
if ( null !== $id ) {
$sql -> where ( 'id!=?' , $id );
}
2013-12-26 14:25:59 +00:00
$sql -> where ( 'actif=?' , 1 ) -> where ( 'dateSuppr=?' , '0000-00-00 00:00:00' );
2013-11-05 11:18:30 +00:00
$result = $lienM -> fetchRow ( $sql );
if ( null !== $result ) {
if ( ( float ) ( $result -> sumDet + $dataLien [ 'PDetention' ]) > 100.1 ) {
throw new SoapFault ( 'ERR' , " Erreur Detention sup 100% " );
}
}
}
//Enregistrer les infos
if ( empty ( $id )) {
$dataLien = array_merge ( $dataLien , array (
2014-08-06 20:27:01 +00:00
'idInsert' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateInsert' => date ( 'YmdHis' ),
));
try {
$id = $lienM -> insert ( $dataLien );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
//Mise à jour des infos
else {
2013-12-26 14:25:59 +00:00
if ( $dataLien [ 'motifUpdate' ] == " Erreur d'affiliation " ) {
2013-11-05 11:18:30 +00:00
$dataLien = array_merge ( $dataLien , array (
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateSuppr' => date ( 'YmdHis' ),
));
} else {
$dataLien = array_merge ( $dataLien , array (
2014-08-06 20:27:01 +00:00
'idUpdate' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateUpdate' => date ( 'YmdHis' ),
));
}
try {
$id = $lienM -> update ( $dataLien , 'id = ' . $id );
} catch ( Zend_Db_Statement_Exception $e ) {
if ( $e -> getCode () == 1062 ) {
$id = $lienM -> delete ( 'id = ' . $id );
}
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
return $id ;
}
/**
* Définition d ' une fiche lien
* @ param string $infos
* @ param int $id
* @ throws SoapFault
* @ return int
*/
public function setLienRef ( $infos , $id = null )
{
$this -> authenticate ();
$dataRef = json_decode ( $infos , true );
$dataRef [ 'source' ] = 1900 ;
2014-08-06 20:27:01 +00:00
2014-07-09 11:08:27 +00:00
if ( strlen ( trim ( $dataRef [ 'isin' ]))) {
$iBourse = new MBourse ();
if ( ! $iBourse -> isIsin ( $dataRef [ 'isin' ])) {
throw new SoapFault ( 'ERR' , 'Code Isin incorrect.' );
}
}
2013-11-05 11:18:30 +00:00
$refM = new Application_Model_JoLiensRef ();
//Insert
if ( $id === null ) {
//Check if exist
if ( intval ( $dataRef [ 'siren' ]) != 0 ) {
$sql = $refM -> select () -> from ( $refM , array ( 'id' )) -> where ( 'siren=?' , $dataRef [ 'siren' ]);
$rowset = $refM -> fetchRow ( $sql );
if ( $rowset !== null ) {
return $rowset -> id ;
}
}
$dataRef = array_merge ( $dataRef , array (
'actif' => 1 ,
2014-08-06 20:27:01 +00:00
'idInsert' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateInsert' => date ( 'YmdHis' ))
);
try {
$id = $refM -> insert ( $dataRef );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
//Update
else {
2013-12-26 14:25:59 +00:00
if ( array_key_exists ( 'delete' , $dataRef ) && $dataRef [ 'delete' ] == 1 ) {
2013-11-05 11:18:30 +00:00
2013-12-26 14:25:59 +00:00
$dataRef = array (
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateSuppr' => date ( 'YmdHis' ),
2013-12-26 14:25:59 +00:00
);
2013-11-13 14:04:35 +00:00
2013-11-05 11:18:30 +00:00
try {
$id = $refM -> update ( $dataRef , 'id = ' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
} else {
$dataRef = array_merge ( $dataRef , array (
2014-08-06 20:27:01 +00:00
'idUpdate' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateUpdate' => date ( 'YmdHis' ),
));
try {
$id = $refM -> update ( $dataRef , 'id = ' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
}
return $id ;
}
/**
* Retourne les informations de référence
* @ param int $id
* @ throws SoapFault
* @ return string
*/
public function getLienRef ( $id )
{
$this -> authenticate ();
$refM = new Application_Model_JoLiensRef ();
2014-02-25 16:33:07 +00:00
$row = $refM -> fetchRow ( 'id=' . $id );
2013-11-05 11:18:30 +00:00
$ouput = '' ;
if ( $row === null ) {
2014-02-25 16:33:07 +00:00
$output = json_encode ( array ( 'Aucun résultat' ));
2013-11-05 11:18:30 +00:00
} else {
2014-02-25 16:33:07 +00:00
$output = json_encode ( $row -> toArray ());
2013-11-05 11:18:30 +00:00
}
return $output ;
}
/**
* Liste des documents pour un lien
* @ param int $id
* @ param string $type null | Lien | Entreprise | Siren
* @ throws SoapFault
* @ return LienDoc []
*/
public function getLienDoc ( $id , $type = null )
{
$this -> authenticate ();
//Type = Entreprise => Search id by Siren
if ( $type == 'Siren' ) {
$lienrefM = new Application_Model_JoLiensRef ();
$sql = $lienrefM -> select () -> where ( 'siren=?' , $id );
$row = $lienrefM -> fetchRow ( $sql );
$idNum = $row -> id ;
$type = 'Entreprise' ;
}
//Type = Lien
elseif ( $type == 'Lien' || $type == 'Entreprise' ) {
$idNum = $id ;
}
$output = array ();
if ( $type !== null && $idNum === null ) {
return $output ;
}
//Get the result
$liendocM = new Application_Model_JoLiensDoc ();
try {
if ( $idNum === null ) {
$sql = $liendocM -> select ()
-> where ( 'id=?' , $id )
-> where ( 'dateSuppr=?' , '0000-00-00 00:00:00' );
} else {
$sql = $liendocM -> select ()
-> where ( 'idNum=?' , $idNum )
-> where ( 'idType=?' , $type )
-> where ( 'dateSuppr=?' , '0000-00-00 00:00:00' );
}
2014-02-28 08:03:43 +00:00
$sql -> order ( 'dateDocRef DESC' );
2013-11-05 11:18:30 +00:00
$rowset = $liendocM -> fetchAll ( $sql );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
if ( $rowset -> count () > 0 ) {
foreach ( $rowset as $item ) {
$struct = new LienDoc ();
$struct -> id = $item -> id ;
$struct -> perimetre = $item -> periDoc ;
$params = explode ( '-' , $item -> docRef );
switch ( $params [ 0 ]) {
case 'INTERNE' :
$tabLabel = array (
'CA' => " Comptes Annuels " ,
'CC' => " Comptes Consolidés " ,
'DR' => " Document de référence " ,
'RA' => " Rapport Annuel ou d'Activité " ,
'RS' => " Rapport Semestriel " ,
'RG' => " Rapport de gestion " ,
'RF' => " Rapport financier " ,
'OR' => " Organigramme " ,
'AP' => " Article de presse " ,
'AC' => " Acte " ,
'ST' => " Statuts " ,
'DW' => " Document Web/Internet " ,
);
$struct -> label = $tabLabel [ $params [ 2 ]] . ' (' . WDate :: dateT ( 'Ymd' , 'd/m/Y' , $params [ 3 ]) . ')' ;
$struct -> url = $item -> docRef . '.pdf' ;
break ;
case 'GREFFE' :
$struct -> label = $item -> docRef ;
$struct -> url = $item -> docRef ;
//@todo
break ;
}
$struct -> date = $item -> dateDocRef ;
$output [] = $struct ;
}
}
return $output ;
}
/**
* Définition d ' un document attaché à un lien
* @ param string $infos
* @ param int $id
* @ throws SoapFault
* @ return int
*/
public function setLienDoc ( $infos , $id = null )
{
$this -> authenticate ();
$dataDoc = json_decode ( $infos , true );
$docM = new Application_Model_JoLiensDoc ();
//Insert
if ( $id === null ) {
$dataDoc = array_merge ( $dataDoc , array (
2014-08-06 20:27:01 +00:00
'idInsert' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateInsert' => date ( 'YmdHis' ))
);
try {
$id = $docM -> insert ( $dataDoc );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
//Update
else {
$dataDoc = array_merge ( $dataDoc , array (
2014-08-06 20:27:01 +00:00
'idSuppr' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateSuppr' => date ( 'YmdHis' ),
));
try {
$id = $docM -> update ( $dataDoc , 'id = ' . $id );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
return $id ;
}
/**
* Recherche de fiche lien dans le référentiel
* @ param string $query
* @ param string $type null | siren | identifiant | id | special
* @ throws SoapFault
* @ return SearchLienRef []
*/
public function searchLienRef ( $query , $type = null )
{
$this -> authenticate ();
$db = Zend_Db_Table_Abstract :: getDefaultAdapter ();
2014-08-11 20:17:16 +00:00
$sql = $db -> select () -> from (
array ( 'l' => 'jo.liensRef' ),
array (
'id' , 'siren' , 'actif' , 'RS' ,
'nom' , 'prenom' , 'nom_usage' , 'naissance_date' , 'nat' , 'adresse_cp' , 'adresse_ville'
)
);
2013-11-05 11:18:30 +00:00
if ( $type == 'siren' ) {
$queries = explode ( ' ' , $query );
2014-04-09 13:41:26 +00:00
$sql -> joinLeft ( array ( 'p' => 'jo.tabPays' ), 'p.codPays3 = l.adresse_pays' , array ( 'codPays3' , 'libPays' ));
2013-11-05 11:18:30 +00:00
$sql -> where ( " l.siren=? " , $queries [ 0 ]);
2014-02-25 16:33:07 +00:00
} elseif ( $type == 'isin' ) {
$queries = explode ( ' ' , $query );
2014-04-09 13:41:26 +00:00
$sql -> joinLeft ( array ( 'p' => 'jo.tabPays' ), 'p.codPays3 = l.adresse_pays' , array ( 'codPays3' , 'libPays' ));
2014-02-25 16:33:07 +00:00
$sql -> where ( " l.isin=? " , $queries [ 0 ]);
2014-08-11 20:17:16 +00:00
}
// Identifiant Nationnaux
elseif ( $type == 'identifiant' ) {
2013-11-05 11:18:30 +00:00
$queries = explode ( ' ' , $query );
2014-04-09 13:41:26 +00:00
$sql -> joinLeft ( array ( 'p' => 'jo.tabPays' ), 'p.codPays3 = l.adresse_pays' , array ( 'codPays3' , 'libPays' ));
2013-11-05 11:18:30 +00:00
$sql -> where ( " l.idLoc1Num=? " , $queries [ 0 ]);
2014-08-11 20:17:16 +00:00
}
// Identifiant interne
elseif ( $type == 'id' ) {
2013-11-05 11:18:30 +00:00
2014-04-09 13:41:26 +00:00
$sql -> joinLeft ( array ( 'p' => 'jo.tabPays' ), 'p.codPays3 = l.adresse_pays' , array ( 'codPays3' , 'libPays' ));
2013-11-05 11:18:30 +00:00
$sql -> where ( " l.id=? " , $query );
2014-08-11 20:17:16 +00:00
}
// Structure spécial
elseif ( $type == 'special' ) {
2013-11-05 11:18:30 +00:00
$queries = explode ( ' ' , $query );
if ( count ( $queries ) > 0 ) {
$where = '' ;
$i = 0 ;
foreach ( $queries as $item ) {
if ( strlen ( $item ) > 2 ) {
$where .= 'LIKE "%' . strtolower ( $item ) . '%"' ;
}
$i ++ ;
if ( count ( $queries ) > $i ){
$where .= ' OR ' ;
}
}
$sql -> where ( " (l.RS " . $where . " ) OR (l.nom " . $where . " ) " );
$sql -> where ( 'l.id<1000' );
}
2014-08-11 20:17:16 +00:00
}
// Recherche par nom
else {
2013-11-05 11:18:30 +00:00
$pos = strrpos ( $query , ',' );
if ( $pos !== false ) {
$country = trim ( substr ( $query , $pos + 1 ));
$query = trim ( substr ( $query , 0 , $pos ));
}
2014-08-11 20:17:16 +00:00
$sql -> joinLeft ( array ( 'p' => 'jo.tabPays' ), 'p.codPays3 = l.adresse_pays' , array ( 'codPays3' , 'libPays' ));
$sql -> where ( 'MATCH (l.RS, l.nom, l.prenom) AGAINST ("' . strtolower ( $query ) . '" IN NATURAL LANGUAGE MODE)' );
$sql -> where ( 'l.id>=1000' );
2013-11-05 11:18:30 +00:00
if ( ! empty ( $country ) ) {
$sql -> where ( 'l.adresse_pays=?' , $country );
}
2014-08-11 20:17:16 +00:00
2013-11-05 11:18:30 +00:00
}
2014-08-11 20:17:16 +00:00
2013-11-13 14:04:35 +00:00
$sql -> where ( " l.dateSuppr='0000-00-00 00:00:00' " );
2013-11-05 11:18:30 +00:00
$sql -> limit ( 20 );
try {
$result = $db -> fetchAll ( $sql , null , Zend_Db :: FETCH_OBJ );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
$output = array ();
if ( count ( $result > 0 )) {
foreach ( $result as $item ) {
$tmp = new SearchLienRef ();
$tmp -> id = $item -> id ;
//Personne Morale
if ( $item -> siren != '' ) {
$lib = $item -> RS . ', ' . str_pad ( $item -> siren , 9 , '0' , STR_PAD_LEFT );
} else {
$lib = $item -> RS . ', ' . $item -> adresse_cp . ' ' . $item -> adresse_ville . ', ' . $item -> libPays ;
}
//Personne Physique
if ( $item -> nom != '' ) {
2014-08-11 20:17:16 +00:00
$lib = ' ' . $item -> nom . ' ' . $item -> prenom . ', ' ;
if ( $item -> nom_usage != '' ) {
$lib .= $item -> nom_usage . ', ' ;
}
$lib .= $item -> naissance_date . ', ' . $item -> nat ;
if ( intval ( $item -> siren ) ) {
$lib .= ' (' . $item -> siren . ')' ;
}
2013-11-05 11:18:30 +00:00
}
if ( $item -> actif != 1 ) {
$lib .= ' (inactif)' ;
}
$tmp -> lib = $lib ;
$output [] = $tmp ;
}
}
return $output ;
}
/**
* Change siren for a registered mark
* @ param int $id
* Registered mark ID
* @ param string $siren
* Siren to affect
* @ throws SoapFault
* @ return int
*/
public function dupliqueMarque ( $id , $siren )
{
$this -> authenticate ();
2014-08-06 20:27:01 +00:00
$idUser = $this -> User -> id ;
2013-11-05 11:18:30 +00:00
$data = array (
'sirenDeposant' => $siren ,
'sirenValide' => 2 ,
'idSirenage' => $idUser ,
'dateUpdate' => date ( 'YmdHis' )
);
try {
$marqueM = new Application_Model_BopiMarques ();
$result = $marqueM -> update ( $data , 'id=' . $id );
} catch ( Zend_Db_Adapter_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , " Application error " );
}
return $result ;
}
/**
* Bourse
* @ param string $isin
* @ param string $infos
* @ throws SoapFault
* @ return int
*/
public function setBourse ( $isin , $infos )
{
$this -> authenticate ();
if ( strlen ( $isin ) > 12 ) {
throw new SoapFault ( 'ERR' , 'Code Isin incorrect.' );
}
$data = json_decode ( $infos , true );
2014-07-11 11:57:45 +00:00
if ( strlen ( trim ( $isin ))) {
2014-07-09 11:08:27 +00:00
$iBourse = new MBourse ();
2014-07-11 11:57:45 +00:00
if ( ! $iBourse -> isIsin ( $isin )) {
2014-07-09 11:08:27 +00:00
throw new SoapFault ( 'ERR' , 'Code Isin incorrect.' );
}
}
2013-11-05 11:18:30 +00:00
$bourseM = new Application_Model_Sdv1BourseIsin ();
//Check if exist
$sql = $bourseM -> select () -> where ( 'code_isin=?' , $isin );
$result = $bourseM -> fetchAll ( $sql );
//Insert
if ( $result -> count () == 0 ) {
$data = array_merge ( $data , array (
'dateInsert' => date ( 'YmdHis' ),
));
try {
$id = $bourseM -> insert ( $data );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
//Update
else {
try {
2014-06-16 06:10:41 +00:00
$id = $bourseM -> update ( $data , array ( 'code_isin = ? ' => $isin ));
2013-11-05 11:18:30 +00:00
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient != 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
} else {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
}
}
return $id ;
}
/**
* Informations boursières pour la saisie
* @ param string $isin
* @ throws SoapFault
* @ return string
*/
public function getBourse ( $isin )
{
$this -> authenticate ();
if ( strlen ( $isin ) > 12 ) {
throw new SoapFault ( 'ERR' , 'Code Isin incorrect.' );
}
$bourseM = new Application_Model_Sdv1BourseIsin ();
2014-06-16 06:10:41 +00:00
$sql = $bourseM -> select () -> where ( 'code_isin=?' , $isin );
$result = $bourseM -> fetchRow ( $sql );
2013-11-05 11:18:30 +00:00
if ( $result === null ) {
throw new SoapFault ( 'MSG' , 'Aucun résultat' );
}
return json_encode ( $result -> toArray ());
}
/**
* LienRef Fusion or Move LienRef
* @ param string $action fusion | moveact | movepar
* @ param int $idLien
* Identifiant du lien entre idPar et idAct
* @ param int $id
* Identifiant à affecter ( idPar ou idAct )
* @ throws SoapFault
* @ return boolean
*/
public function setLienChange ( $action , $idLien , $id )
{
$this -> authenticate ();
if ( empty ( $action )) {
throw new SoapFault ( 'ERR' , " action " );
}
$lienM = new Application_Model_JoLiens ();
//Fusion :
if ( $action == 'fusion' )
{
//Ecraser les actionnaires avec l'ancien id
$lienM -> update (
2014-08-06 20:27:01 +00:00
array ( 'idAct' => $idLien , 'idUpdate' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
'idAct=' . $id );
//Ecraser les participations avec l'ancien id
$lienM -> update (
2014-08-06 20:27:01 +00:00
array ( 'idPar' => $idLien , 'idUpdate' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
'idPar=' . $id );
//Supprimer la fiche
$lienrefM = new Application_Model_JoLiensRef ();
$lienM -> update (
2014-08-06 20:27:01 +00:00
array ( 'dateSuppr' => date ( 'Ymd' ), 'idSuppr' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
'id=' . $id );
return true ;
}
//Move actionnaire to a new parent
elseif ( $action == 'moveact' )
{
try {
2014-08-06 20:27:01 +00:00
$result = $lienM -> update ( array ( 'idPar' => $id , 'idUpdate' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
'id=' . $idLien );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
if ( $result ) return true ;
}
//Move participation to a new parent
elseif ( $action == 'movepar' )
{
try {
2014-08-06 20:27:01 +00:00
$result = $lienM -> update ( array ( 'idAct' => $id , 'idUpdate' => $this -> User -> id ),
2013-11-05 11:18:30 +00:00
'id=' . $idLien );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
if ( $result ) return true ;
}
2014-06-06 08:41:57 +00:00
//Move active participations if TUP and Fusion selected
elseif ( $action == 'tupfusion' )
{
try {
2014-08-06 20:27:01 +00:00
$result = $lienM -> update ( array ( 'idAct' => $id , 'idUpdate' => $this -> User -> id ),
2014-06-10 05:14:44 +00:00
" idAct= $idLien AND actif=1 AND dateSuppr='0000-00-00 00:00:00' " );
2014-06-06 08:41:57 +00:00
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2014-06-06 08:41:57 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
if ( $result ) return true ;
}
2013-11-05 11:18:30 +00:00
return false ;
}
/**
* Position cut - off pour le calcul des scores
* @ param string $infos
* json_encode array with this values
* siren
* encours
* scoreSolv
* scoreDir
* scoreConf
* remarque
2015-02-13 05:01:49 +00:00
* paiement
2013-11-05 11:18:30 +00:00
* @ param boolean $delete
* @ throws SoapFault
* @ return int
*/
public function setScoreCutoff ( $infos , $delete = false )
{
$this -> authenticate ();
if ( null === $delete ) {
$delete = false ;
}
$data = json_decode ( $infos , true );
//if profil = score (20), use this table to convert
2014-08-06 20:27:01 +00:00
if ( $this -> User -> typeScore == 20 ) {
2013-11-05 11:18:30 +00:00
$convert20to100 = array (
0 => 0 ,
1 => 19 ,
2 => 29 ,
3 => 34 ,
4 => 35 ,
5 => 38 ,
6 => 40 ,
7 => 44 ,
8 => 45 ,
9 => 49 ,
10 => 50 ,
11 => 54 ,
12 => 56 ,
13 => 59 ,
14 => 61 ,
15 => 64 ,
16 => 68 ,
17 => 72 ,
18 => 79 ,
19 => 80 ,
20 => 90 ,
);
$data [ 'scoreSolv' ] = $convert20to100 [ $data [ 'scoreSolv' ]];
$data [ 'scoreDir' ] = $convert20to100 [ $data [ 'scoreDir' ]];
$data [ 'scoreConf' ] = $convert20to100 [ $data [ 'scoreConf' ]];
}
$cutoffM = new Application_Model_JoScoresCutoff ();
$sql = $cutoffM -> select () -> where ( 'siren=?' , $data [ 'siren' ]);
$row = $cutoffM -> fetchRow ( $sql );
//Historisation
if ( null !== $row ) {
$mvtM = new Application_Model_JoScoresCutoffMvt ();
$backupData = $row -> toArray ();
unset ( $backupData [ 'dateUpdate' ]);
$backupData = array_merge ( $backupData , array (
2014-08-06 20:27:01 +00:00
'idMvt' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateMvt' => date ( 'YmdHis' )
));
try {
$mvtM -> insert ( $backupData );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2014-03-26 15:33:50 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
2013-11-05 11:18:30 +00:00
} else {
2014-03-26 15:33:50 +00:00
throw new SoapFault ( 'ERR' , " Application error " );
2013-11-05 11:18:30 +00:00
}
}
2014-03-26 15:33:50 +00:00
$result = $cutoffM -> delete ( 'siren=' . $data [ 'siren' ]);
2013-11-05 11:18:30 +00:00
}
if ( ! $delete ) {
//Insertion
$data = array_merge ( $data , array (
2014-08-06 20:27:01 +00:00
'idInsert' => $this -> User -> id ,
2013-11-05 11:18:30 +00:00
'dateInsert' => date ( 'YmdHis' )
));
try {
$result = $cutoffM -> insert ( $data );
} catch ( Zend_Db_Exception $e ) {
2014-08-06 20:27:01 +00:00
if ( $this -> User -> idClient == 1 ) {
2013-11-05 11:18:30 +00:00
throw new SoapFault ( 'ERR' , $e -> getMessage ());
} else {
throw new SoapFault ( 'ERR' , " Application error " );
}
}
//Mise en surveillance
2014-08-06 20:27:01 +00:00
if ( $result > 0 && ! empty ( $this -> User -> email )) {
2013-11-05 11:18:30 +00:00
$iInsee = new MInsee ();
$tabIdentite = $iInsee -> getIdentiteLight ( $data [ 'siren' ]);
$data = array (
'source' => 'score' ,
2014-08-06 20:27:01 +00:00
'login' => $this -> User -> login ,
'email' => $this -> User -> email ,
2013-11-05 11:18:30 +00:00
'siren' => $data [ 'siren' ],
'nic' => 0 ,
'ref' => 'CUTOFF' ,
'encoursClient' => 0 ,
'rs' => $tabIdentite [ 'Nom' ],
'cp' => $tabIdentite [ 'CP' ],
'ville' => $tabIdentite [ 'Ville' ],
'dateAjout' => date ( 'Y-m-d' ),
'dateSuppr' => 0 ,
);
$iDb = new WDB ( 'jo' );
$iDb -> insert ( 'surveillances_site' , $data );
}
}
return $result ;
}
/**
* Get cutoff on a SIREN
* @ param string $siren
* @ return mixed
*/
public function getScoreCutoff ( $siren )
{
$this -> authenticate ();
$cutoffM = new Application_Model_JoScoresCutoff ();
$sql = $cutoffM -> select () -> where ( 'siren=?' , $siren );
$row = $cutoffM -> fetchRow ( $sql );
$result = false ;
if ( null !== $row ) {
$scoreSolv = intval ( $row -> scoreSolv );
$scoreDir = intval ( $row -> scoreDir );
$scoreConf = intval ( $row -> scoreConf );
2014-08-06 20:27:01 +00:00
if ( $this -> User -> typeScore == 20 ) {
2013-11-05 11:18:30 +00:00
$convert100to20 = array (
0 => 0 ,
19 => 1 ,
29 => 2 ,
34 => 3 ,
35 => 4 ,
38 => 5 ,
40 => 6 ,
44 => 7 ,
45 => 8 ,
49 => 9 ,
50 => 10 ,
54 => 11 ,
56 => 12 ,
59 => 13 ,
61 => 14 ,
64 => 15 ,
68 => 16 ,
72 => 17 ,
79 => 18 ,
80 => 19 ,
90 => 20 ,
);
$scoreSolv = $convert100to20 [ $scoreSolv ];
$scoreDir = $convert100to20 [ $scoreDir ];
$scoreConf = $convert100to20 [ $scoreConf ];
}
$result = json_encode ( array (
'siren' => $row -> siren ,
'encours' => $row -> encours ,
'scoreSolv' => $scoreSolv ,
'scoreDir' => $scoreDir ,
'scoreConf' => $scoreConf ,
'remarque' => $row -> remarque ,
2015-02-13 05:01:49 +00:00
'paiement' => $row -> paiement ,
2013-11-05 11:18:30 +00:00
'dateInsert' => $row -> dateInsert ,
'dateUpdate' => $row -> dateUpdate ,
));
}
return $result ;
}
2014-03-19 07:22:36 +00:00
2014-04-09 13:41:26 +00:00
/**
* Ajouter , modifier , supprimer le dirigeant opérationnel
* @ param string $infos
* @ param string $mode
* @ param int $id
* @ return mixed
*/
public function setDirigeantsOp ( $infos , $mode , $id )
2014-03-18 11:27:16 +00:00
{
2014-04-09 13:41:26 +00:00
$this -> authenticate ();
2014-03-19 07:22:36 +00:00
2014-04-09 13:41:26 +00:00
$dirOp = new Application_Model_Sdv1DirigeantsOp ();
$checkDel = ' AND dateSuppr="0000-00-00 00:00:00.000000"' ;
$where = " id= $id " . $checkDel ;
2014-08-06 20:27:01 +00:00
$userId = $this -> User -> id ;
2014-04-09 13:41:26 +00:00
$dataRef = json_decode ( $infos , true );
$tabRet = array (
'siren' => $dataRef [ 'siren' ],
'nic' => $dataRef [ 'nic' ],
'civ' => $dataRef [ 'civilite' ],
'nom' => strtoupper ( $dataRef [ 'nom' ]),
'prenom' => ucfirst ( strtolower ( $dataRef [ 'prenom' ])),
'nom_usage' => $dataRef [ 'nom_usage' ],
'dateNais' => $dataRef [ 'dateNais' ],
'lieuNais' => $dataRef [ 'lieuNais' ],
'codFct' => $dataRef [ 'codFct' ],
'tel' => $dataRef [ 'tel' ],
'fax' => $dataRef [ 'fax' ],
'email' => $dataRef [ 'email' ],
);
switch ( $mode ) {
case 'add' :
2014-04-15 08:35:23 +00:00
$tabRet [ 'dateInsert' ] = date ( 'Y-m-d H:i:s' );
$tabRet [ 'idInsert' ] = $userId ;
2014-04-09 13:41:26 +00:00
try {
$result = $dirOp -> insert ( $tabRet );
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
return $result ;
2014-04-15 08:35:23 +00:00
case 'edit' :
$tabRet [ 'idUpdate' ] = $userId ;
2014-04-09 13:41:26 +00:00
try {
$result = $dirOp -> update ( $tabRet , $where );
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
return $result ;
case 'del' :
$tabRet = array (
'dateSuppr' => date ( 'Y-m-d H:i:s' ),
'idSuppr' => $userId
);
try {
$result = $dirOp -> update ( $tabRet , $where );
} catch ( Zend_Exception $e ) {
throw new SoapFault ( 'ERR' , $e -> getMessage ());
}
return $result ;
}
return false ;
2014-03-18 11:27:16 +00:00
}
2015-03-30 10:18:58 +00:00
2014-06-11 15:36:42 +00:00
/**
2015-03-30 10:18:58 +00:00
* Set geocode from web application
* @ param string $companyId
* @ param string $type
* @ param string $data
* JSON string containing formatted data
2015-04-07 09:58:06 +00:00
* source , lat , lng , alt , address , precis
2015-03-30 10:18:58 +00:00
* @ param string $override
* @ throws SoapFault
* @ return int
2014-06-11 15:36:42 +00:00
*/
2015-04-07 09:58:06 +00:00
public function setGeoCode ( $companyId , $type = null , $data , $override = false )
2014-06-11 15:36:42 +00:00
{
2015-03-30 10:18:58 +00:00
$this -> authenticate ();
$siren = null ;
// --- Identifiant SD : source + id
if ( $type === null ) {
2014-06-11 15:36:42 +00:00
2015-03-30 10:18:58 +00:00
}
// --- Siren
elseif ( strtolower ( $type ) == 'siren' ) {
if ( strlen ( $companyId ) != 14 ) {
throw new SoapFault ( 'ERR' , 'SIRET invalide.' );
2014-06-11 15:36:42 +00:00
}
}
2015-03-30 10:18:58 +00:00
// Erreur
else {
throw new SoapFault ( 'ERR' , 'Type identifiant inconnu.' );
}
// --- Lecture de l'adresse
$etablissementM = new Application_Model_JoEtablissement ();
$sql = $etablissementM -> select ( true ) -> columns ( array (
'LPAD(adr_num,4,0) AS adr_num' ,
'adr_btq' ,
'adr_typeVoie' ,
'adr_libVoie' ,
'adr_comp' ,
'LPAD(adr_cp,5,0) AS adr_cp' ,
'adr_ville'
)) -> where ( 'siren=?' , substr ( $companyId , 0 , 9 )) -> where ( 'nic=?' , substr ( $companyId , 9 , 5 ));
$result = $etablissementM -> fetchRow ( $sql );
if ( $result === null ) {
return 0 ;
}
// --- Result from database
$AdresseNum = $result -> adr_num ;
$AdresseTypeVoie = $result -> adr_typeVoie ;
$AdresseLibVoie = $result -> adr_libVoie ;
$AdresseCP = $result -> adr_cp ;
$AdresseVille = $result -> adr_ville ;
$insee = new MInsee ();
$AdresseTypeVoieLong = $insee -> getCodeVoie ( $AdresseTypeVoie );
// --- Format adress
$adressPrimary = trim ( preg_replace ( '/ +/' , ' ' , " $AdresseNum $AdresseTypeVoieLong $AdresseLibVoie " ));
// --- Code Rivoli
$codeRivoli = '' ;
$inseeidentiteM = new Application_Model_InseeIdentite ();
$sql = $inseeidentiteM -> select ( true )
-> columns ( array ( 'ADR_DEP' , 'LPAD(ADR_COM,3,0) AS ADR_COM' , 'CODEVOIE' ))
-> where ( 'SIREN=?' , substr ( $companyId , 0 , 9 ))
-> where ( 'NIC=?' , substr ( $companyId , 9 , 5 ));
$result = $inseeidentiteM -> fetchRow ( $sql );
if ( $result !== null ) {
if ( empty ( $result -> CODEVOIE )) {
$codeRivoli = $insee -> getCodeVoieRivoli ( $result -> ADR_DEP . $result -> ADR_COM , $result -> ADR_TYPEVOIE , $result -> ADR_LIBVOIE );
} else {
$codeRivoli = $result -> ADR_DEP . $result -> ADR_COM . $result -> CODEVOIE ;
}
}
// --- Prepare geocoding
$zonageM = new Application_Model_JoZonageXY ();
$sql = $zonageM -> select ()
-> where ( 'address=?' , $adressPrimary )
-> where ( 'adr_cp=?' , $AdresseCP )
-> where ( 'adr_ville=?' , $AdresseVille );
$result = $zonageM -> fetchRow ( $sql );
if ( $result === null ) {
$tableModif = 'insert' ;
} else {
$tableModif = 'update' ;
}
$output = 0 ;
2015-04-07 09:58:06 +00:00
$data = json_decode ( $data );
2015-03-30 10:18:58 +00:00
if ( ! empty ( $data -> lat ) && ! empty ( $data -> lng )) {
if ( strtolower ( $data -> source ) == 'google' ) {
$precision = 0 ;
switch ( $data -> precis ) {
/**
* Precise geocode for which we have location information accurate down to street address precision .
*/
case 'ROOFTOP' :
$precision = 8 ;
break ;
/**
* Approximation ( usually on a road ) interpolated between two precise points ( such as intersections ) .
* Interpolated results are generally returned when rooftop geocodes are unavailable for a street address .
*/
case 'RANGE_INTERPOLATED' :
$precision = 7 ;
break ;
/**
* Geometric center of a result such as a polyline ( for example , a street ) or polygon ( region ) .
*/
case 'GEOMETRIC_CENTER' :
$precision = 6 ;
break ;
/**
* indicates that the returned result is approximate .
*/
case 'APPROXIMATE' :
$precision = 4 ;
break ;
}
require_once 'Metier/partenaire/classMMap.php' ;
$lambert = geos2lambert93 ( $data -> lat , $data -> lng );
$dataGeocode = array (
'address' => $adressPrimary ,
'adr_cp' => $AdresseCP ,
'adr_ville' => $AdresseVille ,
'adrNum' => $AdresseNum ,
'adrIndRep' => '' ,
'adrTypeVoie' => $AdresseTypeVoie ,
'adrLibVoie' => $AdresseLibVoie ,
'rivoli' => $codeRivoli ,
2015-04-07 09:58:06 +00:00
'adresseValidee' => $data -> address ,
2015-03-30 10:18:58 +00:00
'lat' => $data -> lat ,
'lon' => $data -> lng ,
'l93_x' => $lambert [ 'x_93' ],
'l93_y' => $lambert [ 'y_93' ],
2015-04-07 09:58:06 +00:00
'alt' => intval ( $data -> alt ),
2015-03-30 10:18:58 +00:00
'precis' => $precision ,
'source' => 'Google' ,
'dateInsert' => date ( 'YmdHis' ),
);
}
2014-06-11 15:36:42 +00:00
2015-03-30 10:18:58 +00:00
if ( $tableModif == 'insert' ) {
$output = $zonageM -> insert ( $dataGeocode );
} else {
$output = $zonageM -> update ( $dataGeocode , array ( 'address=?' => $adressPrimary ));
}
}
return $output ;
2014-06-11 15:36:42 +00:00
}
2013-11-05 11:18:30 +00:00
}