Librairies Update
This commit is contained in:
parent
6f8da88cab
commit
f74b432bf3
@ -111,59 +111,74 @@ class Metier_Insee_MInsee extends Metier_Insee_Table
|
|||||||
if (!empty($nic)) {
|
if (!empty($nic)) {
|
||||||
$nic = str_pad($nic, 5, '0', STR_PAD_LEFT);
|
$nic = str_pad($nic, 5, '0', STR_PAD_LEFT);
|
||||||
}
|
}
|
||||||
if (!Metier_Util_String::valideData($siren, 9, 9,'N')) //Siren non précisé ou incorrect.
|
//Siren non précisé ou incorrect.
|
||||||
|
if (!Metier_Util_String::valideData($siren, 9, 9,'N')) {
|
||||||
return $erreur;
|
return $erreur;
|
||||||
elseif ($siren*1==0) // Siren vide
|
}
|
||||||
|
// Siren vide
|
||||||
|
elseif (intval($siren) == 0) {
|
||||||
return $erreur;
|
return $erreur;
|
||||||
else
|
}
|
||||||
{
|
else {
|
||||||
if (!isset($nic) || trim($nic)=='')
|
if (!isset($nic) || trim($nic)=='') {
|
||||||
{
|
$somme = 0;
|
||||||
$somme=0;
|
// Traitement IMPAIR
|
||||||
for ($i=0; $i<=8; $i+=2) // Traitement IMPAIR
|
for ($i=0; $i<=8; $i+=2) {
|
||||||
$somme+=(integer)substr($siren,$i,1);
|
$somme+= (integer) substr($siren,$i,1);
|
||||||
|
|
||||||
for ($i=1; $i<=7; $i+=2)
|
|
||||||
{ // Traitement PAIR
|
|
||||||
$var_tmp=(string)(2*((integer)substr($siren,$i,1)));
|
|
||||||
$som_tmp=0;
|
|
||||||
for($j=0;$j<strlen($var_tmp);$j++)
|
|
||||||
$som_tmp+=(integer)substr($var_tmp,$j,1);
|
|
||||||
$somme+=$som_tmp;
|
|
||||||
}
|
}
|
||||||
|
// Traitement PAIR
|
||||||
if ((integer)($somme/10)!=($somme/10))
|
for ($i=1; $i<=7; $i+=2) {
|
||||||
{ // Le Siren est faux
|
$var_tmp = (string) (2*((integer)substr($siren,$i,1)));
|
||||||
if (substr($siren,0,3)!='200') // Les siren débutant par 200 sont toujours valides (sirens provisoires de la BDF?!)
|
$som_tmp = 0;
|
||||||
return $erreur;
|
for($j=0; $j<strlen($var_tmp);$j++) {
|
||||||
}
|
$som_tmp+= (integer)substr($var_tmp,$j,1);
|
||||||
} else {
|
|
||||||
if (!Metier_Util_String::valideData($nic,1,5,'N')) // Nic de format incorrect.
|
|
||||||
return $erreur;
|
|
||||||
|
|
||||||
$SIRET=$siren.$nic;
|
|
||||||
if ($siren<>356000000) {
|
|
||||||
$somme=0;
|
|
||||||
for ($i=0; $i<=12; $i+=2)
|
|
||||||
{ // Traitement PAIR
|
|
||||||
$var_tmp=(string)(2*((integer)substr($SIRET,$i,1)));
|
|
||||||
$som_tmp=0;
|
|
||||||
for($j=0;$j<strlen($var_tmp);$j++)
|
|
||||||
$som_tmp+=(integer)substr($var_tmp,$j,1);
|
|
||||||
$somme+=$som_tmp;
|
|
||||||
}
|
}
|
||||||
for ($i=1; $i<=13; $i+=2) // Traitement IMPAIR
|
$somme+= $som_tmp;
|
||||||
$somme+=(integer)substr($SIRET,$i,1);
|
}
|
||||||
|
|
||||||
if ((integer)($somme/10)!=($somme/10))// Le Siret est faux
|
// Le Siren est faux
|
||||||
|
if ((integer) ($somme/10) != ($somme/10)) {
|
||||||
|
// Les siren débutant par 200 sont toujours valides (sirens provisoires de la BDF?!)
|
||||||
|
if (substr($siren,0,3) != '200') {
|
||||||
return $erreur;
|
return $erreur;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Nic de format incorrect.
|
||||||
|
if (!Metier_Util_String::valideData($nic,1,5,'N')) {
|
||||||
|
return $erreur;
|
||||||
|
}
|
||||||
|
$SIRET = $siren.$nic;
|
||||||
|
if ($siren != 356000000) {
|
||||||
|
$somme=0;
|
||||||
|
// Traitement PAIR
|
||||||
|
for ($i=0; $i<=12; $i+=2) {
|
||||||
|
$var_tmp = (string) (2*((integer)substr($SIRET,$i,1)));
|
||||||
|
$som_tmp = 0;
|
||||||
|
for($j=0; $j<strlen($var_tmp); $j++) {
|
||||||
|
$som_tmp+= (integer) substr($var_tmp,$j,1);
|
||||||
|
}
|
||||||
|
$somme+= $som_tmp;
|
||||||
|
}
|
||||||
|
// Traitement IMPAIR
|
||||||
|
for ($i=1; $i<=13; $i+=2) {
|
||||||
|
$somme+= (integer) substr($SIRET,$i,1);
|
||||||
|
}
|
||||||
|
// Le Siret est faux
|
||||||
|
if ((integer) ($somme/10) != ($somme/10)) {
|
||||||
|
return $erreur;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Cas particulier du siren de LA POSTE : 356 000 000 00000
|
// Cas particulier du siren de LA POSTE : 356 000 000 00000
|
||||||
$somme=14;
|
$somme = 14;
|
||||||
for ($i=9; $i<=13; $i++)
|
for ($i=9; $i<=13; $i++) {
|
||||||
$somme+=(integer)substr($SIRET,$i,1);
|
$somme+= (integer)substr($SIRET,$i,1);
|
||||||
if ($somme%5!=0) // Le NIC de l'établissement de LA POSTE est faux !
|
}
|
||||||
|
// Le NIC de l'établissement de LA POSTE est faux !
|
||||||
|
if ($somme%5 != 0) {
|
||||||
return $erreur;
|
return $erreur;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -408,8 +408,8 @@ class Metier_Partenaires_MBilans
|
|||||||
return $this->Bilans[$typeBilan.$millesime];
|
return $this->Bilans[$typeBilan.$millesime];
|
||||||
}
|
}
|
||||||
|
|
||||||
$clotureDate = new Zend_Date($millesime, 'dd/MM/yyyy');
|
$clotureDate = DateTime::createFromFormat('d/m/Y', $millesime);
|
||||||
$clotureDateSql = $clotureDate->toString('yyyyMMdd');
|
$clotureDateSql = $clotureDate->format('Ymd');
|
||||||
if ($accesPartenaire) {
|
if ($accesPartenaire) {
|
||||||
// On ne veut pas de bilans "Téléchargés" directement sur Internet
|
// On ne veut pas de bilans "Téléchargés" directement sur Internet
|
||||||
$strSansBilansWeb=' AND partenaire<>7 ';
|
$strSansBilansWeb=' AND partenaire<>7 ';
|
||||||
@ -550,8 +550,8 @@ class Metier_Partenaires_MBilans
|
|||||||
|| ( ($tabBilan['N15']*1==0 || $tabBilan['N32']*1==0) && $tabBilan['CONSOLIDE']=='S' ) // Réel Simplifié
|
|| ( ($tabBilan['N15']*1==0 || $tabBilan['N32']*1==0) && $tabBilan['CONSOLIDE']=='S' ) // Réel Simplifié
|
||||||
) {
|
) {
|
||||||
|
|
||||||
$cloturePreDate = $clotureDate->subMonth($bilan['dureeExercice']);
|
$cloturePreDate = $clotureDate->sub(new DateInterval('P'.$bilan['dureeExercice'].'M'));
|
||||||
$cloturePreDateSql = $cloturePreDate->toString('yyyyMM');
|
$cloturePreDateSql = $cloturePreDate->format('Ym');
|
||||||
|
|
||||||
// --- Recherche des infos du bilan précédent
|
// --- Recherche des infos du bilan précédent
|
||||||
$ret = $this->iDb->select('jo.bilans',
|
$ret = $this->iDb->select('jo.bilans',
|
||||||
|
@ -198,6 +198,27 @@ class Metier_Partenaires_MCadastre
|
|||||||
return $lib;
|
return $lib;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Nature des locaux ou parcelles
|
||||||
|
* @param string $code
|
||||||
|
* @param string $type
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
public function getNatureLabel($code, $type = 'local')
|
||||||
|
{
|
||||||
|
if ($type == 'local') {
|
||||||
|
if (array_key_exists($code, self::$PEV)) {
|
||||||
|
return self::$PEV[$code];
|
||||||
|
}
|
||||||
|
} elseif ($type == 'parcelle') {
|
||||||
|
if (array_key_exists($code, self::$natureParcelles)) {
|
||||||
|
return self::$natureParcelles[$code];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return '';
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Locaux : Propriétés baties
|
* Locaux : Propriétés baties
|
||||||
* @param string $siren
|
* @param string $siren
|
||||||
@ -234,7 +255,7 @@ class Metier_Partenaires_MCadastre
|
|||||||
'pmAdrDep' => trim($loc['CCODEP']),
|
'pmAdrDep' => trim($loc['CCODEP']),
|
||||||
'pmAdrCom' => trim($loc['companyCCOCOM']),
|
'pmAdrCom' => trim($loc['companyCCOCOM']),
|
||||||
'localDroit' => trim($loc['CCODRO']),
|
'localDroit' => trim($loc['CCODRO']),
|
||||||
'localDroitLib' => self::$tabCodeDroit[trim($loc['CCODRO'])],
|
'localDroitLib' => self::$codeDroit[trim($loc['CCODRO'])],
|
||||||
'localDep' => trim($loc['CCODEP']),
|
'localDep' => trim($loc['CCODEP']),
|
||||||
'localCom' => trim($loc['CCOCOM']),
|
'localCom' => trim($loc['CCOCOM']),
|
||||||
'localComLib' => trim($loc['DLICOM']),
|
'localComLib' => trim($loc['DLICOM']),
|
||||||
@ -346,4 +367,110 @@ class Metier_Partenaires_MCadastre
|
|||||||
|
|
||||||
return $parcelles;
|
return $parcelles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List des éléments du patrimoine
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function patrimoine()
|
||||||
|
{
|
||||||
|
$locauxSql = "SELECT 'local' AS type, " .
|
||||||
|
"l.CCODRO AS role, " .
|
||||||
|
"l.DNUVOI AS adresseNum, " .
|
||||||
|
"l.DLTNUV AS adresseInd, " .
|
||||||
|
"l.CNAVOI AS adresseType, " .
|
||||||
|
"l.DLIVOI AS adresseLib, " .
|
||||||
|
"l.CCODEP AS departement, " .
|
||||||
|
"l.CCOCOM AS communeCode, " .
|
||||||
|
"l.DLICOM AS communeLib, " .
|
||||||
|
"l.CCOSEC AS section, " .
|
||||||
|
"l.DNUPLA AS planNum, " .
|
||||||
|
"l.CCORIV AS fantoir, " .
|
||||||
|
"l.DNUBAT AS batiment, " .
|
||||||
|
"l.DESC AS ent, " .
|
||||||
|
"l.DNIV AS niveau, " .
|
||||||
|
"(l.DSUPOD0 + l.DSUPOD1 + l.DSUPOD2 + l.DSUPOD3 + l.DSUPOD4 + l.DSUPOD5 + l.DSUPOD7 + l.DSUPOD8 + l.DSUPOD9) AS surfaceTotal, " .
|
||||||
|
"l.CCOAFF0 AS nature0, " .
|
||||||
|
"l.DSUPOD0 AS surface0, " .
|
||||||
|
"l.CCOAFF1 AS nature1, " .
|
||||||
|
"l.DSUPOD1 AS surface1, " .
|
||||||
|
"l.CCOAFF2 AS nature2, " .
|
||||||
|
"l.DSUPOD2 AS surface2, " .
|
||||||
|
"l.CCOAFF3 AS nature3, " .
|
||||||
|
"l.DSUPOD3 AS surface3, " .
|
||||||
|
"l.CCOAFF4 AS nature4, " .
|
||||||
|
"l.DSUPOD4 AS surface4, " .
|
||||||
|
"l.CCOAFF5 AS nature5, " .
|
||||||
|
"l.DSUPOD5 AS surface5, " .
|
||||||
|
"l.CCOAFF6 AS nature6, " .
|
||||||
|
"l.DSUPOD6 AS surface6, " .
|
||||||
|
"l.CCOAFF7 AS nature7, " .
|
||||||
|
"l.DSUPOD7 AS surface7, " .
|
||||||
|
"l.CCOAFF8 AS nature8, " .
|
||||||
|
"l.DSUPOD8 AS surface8, " .
|
||||||
|
"l.CCOAFF9 AS nature9, " .
|
||||||
|
"l.DSUPOD9 AS surface9, " .
|
||||||
|
"l.dateInsert " .
|
||||||
|
"FROM sdv1.cad_perloc l, sdv1.cad_permor e " .
|
||||||
|
"WHERE e.DSIREN='$this->siren' AND e.INTCIF=l.INTCIF AND e.DNUPER=l.DNUPER";
|
||||||
|
|
||||||
|
$parcellesSql = "SELECT 'parcelle' AS type, " .
|
||||||
|
"p.CCODRO AS role, " .
|
||||||
|
"p.DNUVOI AS adresseNum, " .
|
||||||
|
"p.DLTNUV AS adresseInd, " .
|
||||||
|
"p.CNAVOI AS adresseType, " .
|
||||||
|
"p.DLIVOI AS adresseLib ," .
|
||||||
|
"p.CCODEP AS departement, " .
|
||||||
|
"p.CCOCOM AS communeCode, " .
|
||||||
|
"p.DLICOM AS communeLib, " .
|
||||||
|
"p.CCOSEC AS section, " .
|
||||||
|
"p.DNUPLA AS planNum, " .
|
||||||
|
"p.CCORIV AS fantoir, " .
|
||||||
|
"'' AS batiment, " .
|
||||||
|
"'' AS ent, " .
|
||||||
|
"'' AS niveau, " .
|
||||||
|
"p.DCNPAR AS surfaceTotal, " .
|
||||||
|
"p.DSGRPF0 AS nature0, " .
|
||||||
|
"p.DCNSUF0 AS surface0, " .
|
||||||
|
"p.DSGRPF1 AS nature1, " .
|
||||||
|
"p.DCNSUF1 AS surface1, " .
|
||||||
|
"p.DSGRPF2 AS nature2, " .
|
||||||
|
"p.DCNSUF2 AS surface2, " .
|
||||||
|
"p.DSGRPF3 AS nature3, " .
|
||||||
|
"p.DCNSUF3 AS surface3, " .
|
||||||
|
"p.DSGRPF4 AS nature4, " .
|
||||||
|
"p.DCNSUF4 AS surface4, " .
|
||||||
|
"p.DSGRPF5 AS nature5, " .
|
||||||
|
"p.DCNSUF5 AS surface5, " .
|
||||||
|
"p.DSGRPF6 AS nature6, " .
|
||||||
|
"p.DCNSUF6 AS surface6, " .
|
||||||
|
"p.DSGRPF7 AS nature7, " .
|
||||||
|
"p.DCNSUF7 AS surface7, " .
|
||||||
|
"p.DSGRPF8 AS nature8, " .
|
||||||
|
"p.DCNSUF8 AS surface8, " .
|
||||||
|
"p.DSGRPF9 AS nature9, " .
|
||||||
|
"p.DCNSUF9 AS surface9, " .
|
||||||
|
"p.dateInsert " .
|
||||||
|
"FROM sdv1.cad_perpar p, sdv1.cad_permor e " .
|
||||||
|
"WHERE e.DSIREN='$this->siren' AND e.INTCIF=p.INTCIF AND e.DNUPER=p.DNUPER";
|
||||||
|
|
||||||
|
$sql = "SELECT * FROM ( ($locauxSql) UNION ALL ($parcellesSql) ) results";
|
||||||
|
|
||||||
|
$db = Zend_Db_Table::getDefaultAdapter();
|
||||||
|
|
||||||
|
//$results = $this->iDb->query($sql, true);
|
||||||
|
$results = $db->fetchAll($sql, null, Zend_Db::FETCH_ASSOC);
|
||||||
|
|
||||||
|
$list = array();
|
||||||
|
if (count($results) > 0) {
|
||||||
|
foreach ($results as $result) {
|
||||||
|
// Libellé role
|
||||||
|
$result['roleLib'] = self::$codeDroit[trim($result['role'])];
|
||||||
|
$list[] = $result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $list;
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
@ -186,82 +186,90 @@ class Metier_Partenaires_MTva
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/** Test de la validité du siren demandé
|
/**
|
||||||
** @param int SIREN à tester
|
* Test de la validité du siren demandé
|
||||||
** @param int NIC (facultatif)
|
* @param int SIREN à tester
|
||||||
** @param mixed Message textuel d'erreur à afficher en cas d'erreur ou false
|
* @param int NIC (facultatif)
|
||||||
** @return mixed true, false ou Message d'erreur passé en paramètre
|
* @param mixed Message textuel d'erreur à afficher en cas d'erreur ou false
|
||||||
**/
|
* @return mixed true, false ou Message d'erreur passé en paramètre
|
||||||
private function valideSiren($siren, $nic='', $erreur=false) {
|
*/
|
||||||
|
private function valideSiren($siren, $nic='', $erreur=false)
|
||||||
|
{
|
||||||
|
$siren = str_pad($siren, 9, '0', STR_PAD_LEFT);
|
||||||
|
if (!empty($nic)) {
|
||||||
|
$nic = str_pad($nic, 5, '0', STR_PAD_LEFT);
|
||||||
|
}
|
||||||
|
//Siren non précisé ou incorrect.
|
||||||
|
if (!Metier_Util_String::valideData($siren, 9, 9,'N')) {
|
||||||
|
return $erreur;
|
||||||
|
}
|
||||||
|
// Siren vide
|
||||||
|
elseif (intval($siren) == 0) {
|
||||||
|
return $erreur;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if (!isset($nic) || trim($nic)=='') {
|
||||||
|
$somme = 0;
|
||||||
|
// Traitement IMPAIR
|
||||||
|
for ($i=0; $i<=8; $i+=2) {
|
||||||
|
$somme+= (integer) substr($siren,$i,1);
|
||||||
|
}
|
||||||
|
// Traitement PAIR
|
||||||
|
for ($i=1; $i<=7; $i+=2) {
|
||||||
|
$var_tmp = (string) (2*((integer)substr($siren,$i,1)));
|
||||||
|
$som_tmp = 0;
|
||||||
|
for($j=0; $j<strlen($var_tmp);$j++) {
|
||||||
|
$som_tmp+= (integer)substr($var_tmp,$j,1);
|
||||||
|
}
|
||||||
|
$somme+= $som_tmp;
|
||||||
|
}
|
||||||
|
|
||||||
/** Si le siren est de taille < à 9, on ajoute des 0 significatifs **/
|
// Le Siren est faux
|
||||||
switch (strlen($siren)) {
|
if ((integer) ($somme/10) != ($somme/10)) {
|
||||||
case 1: $siren='00000000'.$siren; break;
|
// Les siren débutant par 200 sont toujours valides (sirens provisoires de la BDF?!)
|
||||||
case 2: $siren='0000000'.$siren; break;
|
if (substr($siren,0,3) != '200') {
|
||||||
case 3: $siren='000000'.$siren; break;
|
return $erreur;
|
||||||
case 4: $siren='00000'.$siren; break;
|
}
|
||||||
case 5: $siren='0000'.$siren; break;
|
}
|
||||||
case 6: $siren='000'.$siren; break;
|
}
|
||||||
case 7: $siren='00'.$siren; break;
|
else {
|
||||||
case 8: $siren='0'.$siren; break;
|
// Nic de format incorrect.
|
||||||
}
|
if (!Metier_Util_String::valideData($nic,1,5,'N')) {
|
||||||
|
return $erreur;
|
||||||
if (strlen($nic)>0) {
|
}
|
||||||
switch (strlen($nic)) {
|
$SIRET = $siren.$nic;
|
||||||
case 1: $nic='0000'.$nic; break;
|
if ($siren != 356000000) {
|
||||||
case 2: $nic='000'.$nic; break;
|
$somme=0;
|
||||||
case 3: $nic='00'.$nic; break;
|
// Traitement PAIR
|
||||||
case 4: $nic='0'.$nic; break;
|
for ($i=0; $i<=12; $i+=2) {
|
||||||
}
|
$var_tmp = (string) (2*((integer)substr($SIRET,$i,1)));
|
||||||
}
|
$som_tmp = 0;
|
||||||
|
for($j=0; $j<strlen($var_tmp); $j++) {
|
||||||
if (!Metier_Util_String::valideData($siren, 9, 9,'N')) //Siren non précisé ou incorrect.
|
$som_tmp+= (integer) substr($var_tmp,$j,1);
|
||||||
return $erreur;
|
}
|
||||||
elseif ($siren*1==0) // Siren vide
|
$somme+= $som_tmp;
|
||||||
return $erreur;
|
}
|
||||||
else
|
// Traitement IMPAIR
|
||||||
{
|
for ($i=1; $i<=13; $i+=2) {
|
||||||
if (!isset($nic) || trim($nic)=='')
|
$somme+= (integer) substr($SIRET,$i,1);
|
||||||
{
|
}
|
||||||
$somme=0;
|
// Le Siret est faux
|
||||||
for ($i=0; $i<=8; $i+=2) // Traitement IMPAIR
|
if ((integer) ($somme/10) != ($somme/10)) {
|
||||||
$somme+=(integer)substr($siren,$i,1);
|
return $erreur;
|
||||||
|
}
|
||||||
for ($i=1; $i<=7; $i+=2)
|
} else {
|
||||||
{ // Traitement PAIR
|
// Cas particulier du siren de LA POSTE : 356 000 000 00000
|
||||||
$var_tmp=(string)(2*((integer)substr($siren,$i,1)));
|
$somme = 14;
|
||||||
$som_tmp=0;
|
for ($i=9; $i<=13; $i++) {
|
||||||
for($j=0;$j<strlen($var_tmp);$j++)
|
$somme+= (integer)substr($SIRET,$i,1);
|
||||||
$som_tmp+=(integer)substr($var_tmp,$j,1);
|
}
|
||||||
$somme+=$som_tmp;
|
// Le NIC de l'établissement de LA POSTE est faux !
|
||||||
}
|
if ($somme%5 != 0) {
|
||||||
|
return $erreur;
|
||||||
if ((integer)($somme/10)!=($somme/10))
|
}
|
||||||
{ // Le Siren est faux
|
}
|
||||||
if (substr($siren,0,3)!='200') // Les siren débutant par 200 sont toujours valides (sirens provisoires de la BDF?!)
|
}
|
||||||
return $erreur;
|
}
|
||||||
}
|
return true;
|
||||||
} else {
|
}
|
||||||
if (!Metier_Util_String::valideData($nic,1,5,'N')) // Nic de format incorrect.
|
|
||||||
return $erreur;
|
|
||||||
|
|
||||||
$SIRET=$siren.$nic;
|
|
||||||
$somme=0;
|
|
||||||
for ($i=0; $i<=12; $i+=2)
|
|
||||||
{ // Traitement PAIR
|
|
||||||
$var_tmp=(string)(2*((integer)substr($SIRET,$i,1)));
|
|
||||||
$som_tmp=0;
|
|
||||||
for($j=0;$j<strlen($var_tmp);$j++)
|
|
||||||
$som_tmp+=(integer)substr($var_tmp,$j,1);
|
|
||||||
$somme+=$som_tmp;
|
|
||||||
}
|
|
||||||
for ($i=1; $i<=13; $i+=2) // Traitement IMPAIR
|
|
||||||
$somme+=(integer)substr($SIRET,$i,1);
|
|
||||||
|
|
||||||
if ((integer)($somme/10)!=($somme/10))// Le Siret est faux
|
|
||||||
return $erreur;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -3913,18 +3913,12 @@ function calculIndiScore($siren, $nic=0, $accesDist=false, $cycleClient=2, $mail
|
|||||||
$EffectifEn = $tabIdentite['Effectif'];
|
$EffectifEn = $tabIdentite['Effectif'];
|
||||||
$bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois
|
$bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois
|
||||||
if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) {
|
if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) {
|
||||||
|
$dateBilan = DateTime::createFromFormat('Ymd', $tabIdentite['bilanDate']);
|
||||||
Zend_Date::setOptions(array('extend_month' => true));
|
$dateCompare = new DateTime();
|
||||||
$dateBilan = new Zend_Date($tabIdentite['bilanDate'], 'yyyyMMdd');
|
$dateCompare->sub(new DateInterval('P'.$bilanAgeMax.'M'));
|
||||||
$dateNow = new Zend_Date();
|
if ($dateBilan > $dateCompare) {
|
||||||
$difference = $dateNow->sub($dateBilan);
|
$EffectifEn = $tabIdentite['bilanYP'];
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
}
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$nbMonth = $measure->getValue();
|
|
||||||
|
|
||||||
if ( $nbMonth < $bilanAgeMax ) {
|
|
||||||
$EffectifEn = $tabIdentite['bilanYP'];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//Insertion ou mise à jour du score
|
//Insertion ou mise à jour du score
|
||||||
|
@ -3891,16 +3891,10 @@ class SdMetier_Scoring_Base extends SdMetier_Scoring_Vars
|
|||||||
$EffectifEn = $tabIdentite['Effectif'];
|
$EffectifEn = $tabIdentite['Effectif'];
|
||||||
$bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois
|
$bilanAgeMax = 3 * 12; //Age maximum du dernier bilan en mois
|
||||||
if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) {
|
if (!empty($tabIdentite['bilanDate']) && intval($tabIdentite['bilanYP'])>0 ) {
|
||||||
|
$dateBilan = DateTime::createFromFormat('Ymd', $tabIdentite['bilanDate']);
|
||||||
Zend_Date::setOptions(array('extend_month' => true));
|
$dateCompare = new DateTime();
|
||||||
$dateBilan = new Zend_Date($tabIdentite['bilanDate'], 'yyyyMMdd');
|
$dateCompare->sub(new DateInterval('P'.$bilanAgeMax.'M'));
|
||||||
$dateNow = new Zend_Date();
|
if ($dateBilan > $dateCompare) {
|
||||||
$difference = $dateNow->sub($dateBilan);
|
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$nbMonth = $measure->getValue();
|
|
||||||
|
|
||||||
if ( $nbMonth < $bilanAgeMax ) {
|
|
||||||
$EffectifEn = $tabIdentite['bilanYP'];
|
$EffectifEn = $tabIdentite['bilanYP'];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -430,18 +430,14 @@ class SdMetier_Sfr_Scoring
|
|||||||
|
|
||||||
public function evaluate($siren)
|
public function evaluate($siren)
|
||||||
{
|
{
|
||||||
Zend_Date::setOptions(array('extend_month' => true));
|
|
||||||
|
|
||||||
if ($this->debug) file_put_contents('sfr.log', "SIREN = $siren\n", FILE_APPEND);
|
if ($this->debug) file_put_contents('sfr.log', "SIREN = $siren\n", FILE_APPEND);
|
||||||
|
|
||||||
//Set ValContratAge
|
//Set ValContratAge
|
||||||
if ( !empty($this->ValContratDate) ) {
|
if ( !empty($this->ValContratDate) ) {
|
||||||
$dateContrat = new Zend_Date($this->ValContratDate, 'yyyyMMdd');
|
$dateContrat = DateTime::createFromFormat('Ymd', $this->ValContratDate);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$diff = $dateNow->sub($dateContrat);
|
$interval = $dateNow->diff($dateContrat);
|
||||||
$measure = new Zend_Measure_Time($diff->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValContratAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValContratAge = $measure->getValue();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$classInsee = new Metier_Insee_MInsee();
|
$classInsee = new Metier_Insee_MInsee();
|
||||||
@ -467,16 +463,14 @@ class SdMetier_Sfr_Scoring
|
|||||||
if ( $result !== null ) {
|
if ( $result !== null ) {
|
||||||
|
|
||||||
//Indiscore - aller chercher scores dans l'historique moins de X mois
|
//Indiscore - aller chercher scores dans l'historique moins de X mois
|
||||||
$dateUpdate = new Zend_Date(substr($result->dateUpdate,0,10), 'yyyy-MM-dd');
|
$dateUpdate = DateTime::createFromFormat('Y-m-d', substr($result->dateUpdate,0,10));
|
||||||
|
$dateNow = new DateTime();
|
||||||
|
$interval = $dateNow->diff($dateUpdate);
|
||||||
|
$diff = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
|
|
||||||
$dateNow = new Zend_Date();
|
if ($this->debug) file_put_contents('sfr.log', "INDISCORE DIFF = " . $diff . "\n", FILE_APPEND);
|
||||||
$diffUpdate = $dateNow->sub($dateUpdate);
|
|
||||||
$measureUpdate = new Zend_Measure_Time($diffUpdate->toValue(), Zend_Measure_Time::SECOND);
|
|
||||||
$measureUpdate->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
|
|
||||||
if ($this->debug) file_put_contents('sfr.log', "INDISCORE DIFF = " . $measureUpdate->getValue() . "\n", FILE_APPEND);
|
if ( $diff <= 12 ) {
|
||||||
|
|
||||||
if ( $measureUpdate->getValue() <= 12 ) {
|
|
||||||
$this->ValIndiscore = $result->indiScore20;
|
$this->ValIndiscore = $result->indiScore20;
|
||||||
$this->ValDateCalculIndiscore = $result->indiScoreDate;
|
$this->ValDateCalculIndiscore = $result->indiScoreDate;
|
||||||
}
|
}
|
||||||
@ -488,21 +482,17 @@ class SdMetier_Sfr_Scoring
|
|||||||
|
|
||||||
if ( !empty($result->dateCrea) && $result->dateCrea!='0000-00-00 00:00:00' ) {
|
if ( !empty($result->dateCrea) && $result->dateCrea!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($result->dateCrea, 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $result->dateCrea);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
} elseif ( !empty($result->dateImmat) && $result->dateImmat!='0000-00-00 00:00:00' ) {
|
} elseif ( !empty($result->dateImmat) && $result->dateImmat!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($result->dateImmat, 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $result->dateImmat);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -536,17 +526,14 @@ class SdMetier_Sfr_Scoring
|
|||||||
$bilanAgeMax = 3*12; //Age maximum du dernier bilan en mois
|
$bilanAgeMax = 3*12; //Age maximum du dernier bilan en mois
|
||||||
if (!empty($identite['bilanDate']) && intval($identite['bilanYP'])>0 ) {
|
if (!empty($identite['bilanDate']) && intval($identite['bilanYP'])>0 ) {
|
||||||
|
|
||||||
$dateBilan = new Zend_Date($identite['bilanDate'], 'yyyyMMdd');
|
$dateBilan = DateTime::createFromFormat('Ymd', $identite['bilanDate']);
|
||||||
$dateNow = new Zend_Date();
|
$dateCompare = new DateTime();
|
||||||
$difference = $dateNow->sub($dateBilan);
|
$dateCompare->sub(new DateInterval('P'.$bilanAgeMax.'M'));
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
if ($dateBilan > $dateCompare) {
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
$this->ValEffectif = $identite['bilanYP'];
|
||||||
$nbMonth = $measure->getValue();
|
|
||||||
|
|
||||||
if ( $nbMonth < $bilanAgeMax ) {
|
|
||||||
$this->ValEffectif = $identite['bilanYP'];
|
|
||||||
}
|
}
|
||||||
if ($this->debug) file_put_contents('sfr.log', "Bilan : nbMonth = ".$nbMonth."\n", FILE_APPEND);
|
|
||||||
|
if ($this->debug) file_put_contents('sfr.log', "Bilan : ".$dateBilan->format('Ymd')." > ".$dateCompare->format('Ymd')."\n", FILE_APPEND);
|
||||||
}
|
}
|
||||||
if ($this->debug) file_put_contents('sfr.log', "ValEffectif = ".$this->ValEffectif."\n", FILE_APPEND);
|
if ($this->debug) file_put_contents('sfr.log', "ValEffectif = ".$this->ValEffectif."\n", FILE_APPEND);
|
||||||
|
|
||||||
@ -556,27 +543,22 @@ class SdMetier_Sfr_Scoring
|
|||||||
//Age de l'entreprise en mois
|
//Age de l'entreprise en mois
|
||||||
if ( !empty($identite['DateCreaEn']) && $identite['DateCreaEn']!='0000-00-00 00:00:00' ) {
|
if ( !empty($identite['DateCreaEn']) && $identite['DateCreaEn']!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($identite['DateCreaEn'], 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $identite['DateCreaEn']);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
} elseif ( !empty($identite['dateImmat']) && $identite['dateImmat']!='0000-00-00 00:00:00' ) {
|
} elseif ( !empty($identite['dateImmat']) && $identite['dateImmat']!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($identite['dateImmat'], 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $identite['dateImmat']);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
if ($this->debug) file_put_contents('sfr.log', "ValInseeAge = ".$this->ValInseeAge."\n", FILE_APPEND);
|
if ($this->debug) file_put_contents('sfr.log', "ValInseeAge = ".$this->ValInseeAge."\n", FILE_APPEND);
|
||||||
|
|
||||||
$this->ValSituationJuridique = $identite['SituationJuridique'];
|
$this->ValSituationJuridique = $identite['SituationJuridique'];
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
@ -587,35 +569,30 @@ class SdMetier_Sfr_Scoring
|
|||||||
//Age de l'entreprise en mois
|
//Age de l'entreprise en mois
|
||||||
if ( !empty($this->ValDateCrea) && $this->ValDateCrea!='0000-00-00 00:00:00' ) {
|
if ( !empty($this->ValDateCrea) && $this->ValDateCrea!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($this->ValDateCrea, 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $this->ValDateCrea);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
} elseif ( !empty($this->ValDateImmat) && $this->ValDateImmat!='0000-00-00 00:00:00' ) {
|
} elseif ( !empty($this->ValDateImmat) && $this->ValDateImmat!='0000-00-00 00:00:00' ) {
|
||||||
|
|
||||||
$dateC = new Zend_Date($this->ValDateImmat, 'yyyy-MM-dd');
|
$dateC = DateTime::createFromFormat('Y-m-d', $this->ValDateImmat);
|
||||||
$dateNow = new Zend_Date();
|
$dateNow = new DateTime();
|
||||||
$difference = $dateNow->sub($dateC);
|
$interval = $dateNow->diff($dateC);
|
||||||
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
$this->ValInseeAge = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
$this->ValInseeAge = $measure->getValue();
|
|
||||||
|
|
||||||
}
|
}
|
||||||
if ($this->debug) file_put_contents('sfr.log', "ValInseeAge = ".$this->ValInseeAge."\n", FILE_APPEND);
|
if ($this->debug) file_put_contents('sfr.log', "ValInseeAge = ".$this->ValInseeAge."\n", FILE_APPEND);
|
||||||
|
|
||||||
//Vérification validité du score
|
//Vérification validité du score
|
||||||
$dateNow = new Zend_Date();
|
$dateUpdate = DateTime::createFromFormat('Y-m-d', substr($this->ValDateUpdate,0,10));
|
||||||
$dateUpdate = new Zend_Date(substr($this->ValDateUpdate,0,10), 'yyyy-MM-dd');
|
$dateNow = new DateTime();
|
||||||
$diffUpdate = $dateNow->sub($dateUpdate);
|
$interval = $dateNow->diff($dateUpdate);
|
||||||
$measureUpdate = new Zend_Measure_Time($diffUpdate->toValue(), Zend_Measure_Time::SECOND);
|
$diff = $interval->format('%y') * 12 + $interval->format('%m');
|
||||||
$measureUpdate->convertTo(Zend_Measure_Time::MONTH);
|
|
||||||
|
|
||||||
if ($this->debug) file_put_contents('sfr.log', "INDISCORE DIFF = " . $measureUpdate->getValue() . "\n", FILE_APPEND);
|
if ($this->debug) file_put_contents('sfr.log', "INDISCORE DIFF = " . $diff . "\n", FILE_APPEND);
|
||||||
|
|
||||||
if ( $measureUpdate->getValue() > 12 ) {
|
if ( $diff > 12 ) {
|
||||||
$this->ValIndiscore = null;
|
$this->ValIndiscore = null;
|
||||||
$this->ValDateCalculIndiscore = null;
|
$this->ValDateCalculIndiscore = null;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user