702 lines
16 KiB
PHP
702 lines
16 KiB
PHP
<?php
|
|
require_once 'Metier/insee/classMInsee.php';
|
|
|
|
require_once 'Metier/scores/classMScores.php';
|
|
|
|
/**
|
|
*
|
|
*
|
|
*/
|
|
class Metier_Sfr
|
|
{
|
|
/**
|
|
* Version of rules (for loading static files)
|
|
* @var double
|
|
*/
|
|
protected $version = '1.0';
|
|
|
|
/**
|
|
* Debug mode
|
|
* @var boolean
|
|
*/
|
|
protected $debug = true;
|
|
|
|
/**
|
|
* True, to use static file for set vars otherwise read in the database
|
|
* @var boolean
|
|
*/
|
|
protected $compile = true;
|
|
|
|
/**
|
|
*
|
|
* @var Zend_Db_Adapter_Abstract
|
|
*/
|
|
protected $db = null;
|
|
|
|
/**
|
|
* Feu vert
|
|
* @var int
|
|
*/
|
|
const VERT = 3;
|
|
|
|
/**
|
|
* Feu orange
|
|
* @var int
|
|
*/
|
|
const ORANGE = 2;
|
|
|
|
/**
|
|
* Feu rouge
|
|
* @var int
|
|
*/
|
|
const ROUGE = 1;
|
|
|
|
/**
|
|
* CAC = Entreprise du CAC
|
|
* @var int
|
|
*/
|
|
const CAC = 4;
|
|
|
|
/**
|
|
* GE = Grande Entreprise
|
|
* @var int
|
|
*/
|
|
const GE = 3;
|
|
|
|
/**
|
|
* Petites et Moyennes Entreprise
|
|
* @var int
|
|
*/
|
|
const PME = 2;
|
|
|
|
/**
|
|
* Très Petites Entreprise
|
|
* @var int
|
|
*/
|
|
const TPE = 1;
|
|
|
|
/**
|
|
* Constante valeur UNDEFINE
|
|
* @var null
|
|
*/
|
|
const UNDEFINE = null;
|
|
|
|
/**
|
|
* Liste des NAF Administration
|
|
* @var array
|
|
*/
|
|
protected $TabAdminNaf = array(
|
|
'8411Z',
|
|
'8412Z',
|
|
'8413Z',
|
|
'8421Z',
|
|
'8422Z',
|
|
'8423Z',
|
|
'8424Z',
|
|
'8425Z',
|
|
'8430A',
|
|
'8430B',
|
|
'8430C',
|
|
);
|
|
|
|
/**
|
|
* Liste des FJ Administration
|
|
* @var array
|
|
*/
|
|
protected $TabAdminFj = array(
|
|
'4110',
|
|
'4120',
|
|
'4130',
|
|
'4140',
|
|
'4150',
|
|
'4160',
|
|
|
|
'7111',
|
|
'7112',
|
|
'7113',
|
|
'7120',
|
|
'7130',
|
|
'7150',
|
|
'7160',
|
|
'7171',
|
|
'7172',
|
|
'7179',
|
|
|
|
'7210',
|
|
'7220',
|
|
'7225',
|
|
'7229',
|
|
'7230',
|
|
|
|
'7312',
|
|
'7313',
|
|
'7314',
|
|
'7321',
|
|
'7322',
|
|
'7323',
|
|
'7331',
|
|
'7340',
|
|
'7341',
|
|
'7342',
|
|
'7343',
|
|
'7344',
|
|
'7345',
|
|
'7346',
|
|
'7347',
|
|
'7348',
|
|
'7349',
|
|
'7351',
|
|
'7352',
|
|
'7353',
|
|
'7354',
|
|
'7355',
|
|
'7356',
|
|
'7361',
|
|
'7362',
|
|
'7363',
|
|
'7364',
|
|
'7365',
|
|
'7366',
|
|
'7371',
|
|
'7372',
|
|
'7373',
|
|
'7378',
|
|
'7379',
|
|
'7381',
|
|
'7382',
|
|
'7383',
|
|
'7384',
|
|
'7385',
|
|
'7389',
|
|
|
|
'7410',
|
|
'7430',
|
|
'7450',
|
|
'7470',
|
|
'7490',
|
|
|
|
'81',
|
|
'8110',
|
|
'8120',
|
|
'8130',
|
|
'8140',
|
|
'8150',
|
|
'8160',
|
|
'8170',
|
|
'8190',
|
|
|
|
'8210',
|
|
'8250',
|
|
'8290',
|
|
|
|
'8310',
|
|
'8311',
|
|
|
|
'8510',
|
|
'8520',
|
|
|
|
);
|
|
|
|
/**
|
|
* Liste des NAFs société étrangère
|
|
* @var unknown
|
|
*/
|
|
protected $TabEtrangerNaf = array(
|
|
'9900Z'
|
|
);
|
|
|
|
/**
|
|
* Liste des FJ société étrangère
|
|
* @var unknown
|
|
*/
|
|
protected $TabEtrangerFj = array(
|
|
'31',
|
|
'32',
|
|
);
|
|
|
|
/**
|
|
* Liste des NAF clés
|
|
* @var array
|
|
*/
|
|
protected $TabNafSFR = array(
|
|
'4791A',
|
|
'4791B',
|
|
'4799B',
|
|
'6110Z',
|
|
'6120Z',
|
|
'6130Z',
|
|
'6190Z',
|
|
'7320Z',
|
|
);
|
|
|
|
//Valeurs à remplir
|
|
protected $ValIsCAC = null;
|
|
protected $ValTypeEntrep = null;
|
|
protected $ValIsAdmin = null;
|
|
protected $ValIsEtranger = null;
|
|
protected $ValEffectif = null;
|
|
protected $ValNAF = null;
|
|
protected $ValFJ = null;
|
|
protected $ValRJ = 0;
|
|
protected $ValLJ = 0;
|
|
protected $ValSV = 0;
|
|
protected $ValIndiscore = null;
|
|
protected $ValInseeActif = null;
|
|
protected $ValInseeAge = null;
|
|
protected $ValEntrepRecente = null;
|
|
|
|
protected $ValContratDate = null;
|
|
protected $ValIR = null;
|
|
|
|
protected $ValFEU = null;
|
|
protected $ValPO = null;
|
|
protected $ValComment = null;
|
|
|
|
protected $dateCalculIndiscore;
|
|
|
|
//Rules
|
|
protected $RulesVORP = array();
|
|
protected $RulesVORD = array();
|
|
protected $RulesPO = array();
|
|
|
|
/**
|
|
*
|
|
* @param string $version
|
|
* @param string $compile
|
|
*/
|
|
public function __construct( $version = null, $compile = true )
|
|
{
|
|
$this->setVersion($version);
|
|
|
|
$this->setCompile($compile);
|
|
|
|
//Charger les Tabs - ou pas
|
|
|
|
//Get default database adapter
|
|
//$this->db = Zend_Db_Table_Abstract::getDefaultAdapter();
|
|
|
|
//Charger les Rules (dans l'ordre)
|
|
$this->RulesVORP = include realpath(dirname(__FILE__)) . DIRECTORY_SEPARATOR . 'RulesVorp-'.$this->version.'.php';
|
|
$this->RulesVORD = include realpath(dirname(__FILE__)) . DIRECTORY_SEPARATOR . 'RulesVord-'.$this->version.'.php';
|
|
$this->RulesPO = include realpath(dirname(__FILE__)) . DIRECTORY_SEPARATOR . 'RulesPO-'.$this->version.'.php';
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "DEBUT\n");
|
|
|
|
}
|
|
|
|
public function evaluate($siren)
|
|
{
|
|
Zend_Date::setOptions(array('extend_month' => true));
|
|
|
|
$classInsee = new MInsee();
|
|
$classInsee->AnnoncesInMemory = true;
|
|
|
|
//Identite
|
|
$identite = $classInsee->getIdentiteEntreprise($siren);
|
|
|
|
//Naf de l'entreprise
|
|
$this->ValNAF = $identite['NafEnt'];
|
|
|
|
//Forme juridique de l'entreprise
|
|
$this->ValFJ = $identite['FJ']; //insee
|
|
|
|
/**
|
|
* Effectif de l'entreprise
|
|
* 1 - Chiffre au bilan
|
|
* 2 - Info insee Identite::Effectif à la centaine approché
|
|
*/
|
|
$this->ValEffectif = $identite['Effectif'];
|
|
|
|
$bilanAgeMax = 3*12; //Age maximum du dernier bilan en mois
|
|
if (!empty($identite['bilanDate']) && intval($identite['bilanYP'])>0 ) {
|
|
|
|
Zend_Date::setOptions(array('extend_month' => true));
|
|
$dateBilan = new Zend_Date($identite['bilanDate'], 'yyyyMMdd');
|
|
$dateNow = new Zend_Date();
|
|
$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 ) {
|
|
$this->ValEffectif = $identite['bilanYP'];
|
|
}
|
|
|
|
}
|
|
|
|
//Entreprise Active à l'insee
|
|
$this->ValInseeActif = $identite['Actif'];
|
|
|
|
//Age de l'entreprise en mois
|
|
$this->ValInseeAge = null; //Date création Insee (ATTENTION vide) / Date immat RNCS
|
|
|
|
if ( !empty($identite['DateCreaEn']) && $identite['DateCreaEn']!='0000-00-00 00:00:00' ) {
|
|
|
|
$dateC = new Zend_Date($identite['DateCreaEn'], 'yyyyMMdd');
|
|
$dateNow = new Zend_Date();
|
|
$difference = $dateNow->sub($dateC);
|
|
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
|
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
$this->ValInseeAge = $measure->getValue();
|
|
|
|
} elseif ( !empty($identite['dateImmat']) && $identite['dateImmat']!='0000-00-00 00:00:00' ) {
|
|
|
|
$dateC = new Zend_Date($identite['dateImmat'], 'yyyyMMdd');
|
|
$dateNow = new Zend_Date();
|
|
$difference = $dateNow->sub($dateC);
|
|
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
|
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
$this->ValInseeAge = $measure->getValue();
|
|
|
|
}
|
|
|
|
//Entreprise coté au CAC
|
|
$this->ValIsCAC = null;
|
|
/**
|
|
* - Sélectionner tout les ISIN du CAC40
|
|
* - Sélectionner ces entités dans les liens
|
|
* - Retourner une arborescence descendante (33%,40%,50%)
|
|
* Enregistrer les SIREN dans un tableau
|
|
* - Parcourir ce tableau et detecter si le SIREN est dedans
|
|
*/
|
|
|
|
//GetAnnoncesLegales
|
|
|
|
//Si procédure collective ou autre
|
|
if ( $identite['SituationJuridique']!='' ) {
|
|
|
|
$this->ValRJ = 0; //Liste des codes - 1200
|
|
$retRJ = $classInsee->getAnnoncesLegales($siren, 0, array('1200','1201','1202','1203','1204','1205','1206','1207','1208','1209','1210','1211','1212','1214','1215','1216'));
|
|
if (count($retRJ)>0) {
|
|
$this->ValRJ = 1;
|
|
}
|
|
if ($this->debug) file_put_contents('sfr.log', "RJ = ".$this->ValRJ."\n", FILE_APPEND);
|
|
|
|
$this->ValSV = 0; //Liste des codes - 1100
|
|
$retSV = $classInsee->getAnnoncesLegales($siren, 0, array('1100','1101','1102','1110','1119'));
|
|
if (count($retSV)>0) {
|
|
$this->ValSV = 1;
|
|
}
|
|
if ($this->debug) file_put_contents('sfr.log', "SV = ".$this->ValSV."\n", FILE_APPEND);
|
|
|
|
$this->ValLJ = 0; //Liste des codes - 1300
|
|
$retLJ = $classInsee->getAnnoncesLegales($siren, 0, array('1300','1301','1302', '1303', '1304', '1305', '1306', '1307', '1308', '1309', '13010', '1311', '1312', '1313', '1346'));
|
|
if (count($retLJ)>0) {
|
|
$this->ValLJ = 1;
|
|
}
|
|
if ($this->debug) file_put_contents('sfr.log', "LJ = ".$this->ValLJ."\n", FILE_APPEND);
|
|
|
|
}
|
|
|
|
//Indiscore - aller chercher scores dans l'historique moins de 3 mois
|
|
$histo = getIndiscoreHisto($siren);
|
|
if ($this->debug) file_put_contents('sfr.log', "INDISCORE = ".print_r($histo,1)."\n", FILE_APPEND);
|
|
if ( count($histo)>0 ) {
|
|
|
|
$dateC = new Zend_Date($histo[0]['indiScoreDate'], 'yyyyMMdd');
|
|
$dateNow = new Zend_Date();
|
|
$difference = $dateNow->sub($dateC);
|
|
$measure = new Zend_Measure_Time($difference->toValue(), Zend_Measure_Time::SECOND);
|
|
$measure->convertTo(Zend_Measure_Time::MONTH);
|
|
|
|
if ( $measure->getValue() <= 3) {
|
|
$this->ValIndiscore = $histo[0]['indiScore20'];
|
|
$this->dateCalculIndiscore = $histo[0]['indiScoreDate'];
|
|
}
|
|
}
|
|
|
|
if ( $this->ValIndiscore === null ) {
|
|
$indiscore = calculIndiScore($siren);
|
|
$this->ValIndiscore = $indiscore['Indiscore20'];
|
|
$this->dateCalculIndiscore = date('Y-m-d');
|
|
}
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "INDISCORE = ".$this->ValIndiscore."\n", FILE_APPEND);
|
|
|
|
//Rules
|
|
$ruleType = array( 'VORP' , 'VORD' , 'PO');
|
|
foreach ( $ruleType as $type ) {
|
|
$this->rules($type);
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* Execution des règles
|
|
* Si les conditions contenu dans la regle
|
|
*
|
|
*
|
|
* @param string $type
|
|
*/
|
|
protected function rules($type)
|
|
{
|
|
$rules = $this->{'Rules'.$type};
|
|
foreach ( $rules as $rule ) {
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "\nREGLE - ".$rule['name']."\n", FILE_APPEND);
|
|
|
|
$all = false;
|
|
if ( $rule['value'] == 'CONTINUE' ) {
|
|
$all = true;
|
|
}
|
|
$return = $this->params($rule['params'], $all);
|
|
|
|
// Continue always
|
|
if ( $rule['value'] == 'CONTINUE' ) {
|
|
continue;
|
|
}
|
|
|
|
//Continue
|
|
elseif ( $return === false ){
|
|
continue;
|
|
}
|
|
|
|
// Stop
|
|
elseif ( $rule['value'] == 'STOP' && $return === true ) {
|
|
break;
|
|
}
|
|
|
|
//Set Value
|
|
else {
|
|
if( $type == 'PO' ) {
|
|
$this->ValPO = $this->paramValue($rule['value']);
|
|
} else {
|
|
$this->ValFEU = $this->paramValue($rule['value']);
|
|
$this->ValComment = $rule['comment'];
|
|
}
|
|
break;
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Traitement des conditions
|
|
* - Si la condition est FAUSSE
|
|
* => arrêt pour passer à la règle suivante
|
|
* - Si la condition est VRAI
|
|
* => passage à la condition suivante
|
|
* @param array $conditions
|
|
* - var : Nom de la variable
|
|
* - type : Type du test de la condition
|
|
* - value : Valeur à tester
|
|
* - define : "var" à définir avec la "value"
|
|
* @return boolean
|
|
*/
|
|
protected function params($conditions = array(), $all = false)
|
|
{
|
|
$test = false;
|
|
|
|
if ( count($conditions) > 0 ) {
|
|
foreach ( $conditions as $c ) {
|
|
|
|
$test = $this->paramEval($c['var'], $c['type'], $c['value']);
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "PARAM - RETURN = ".$test."\n", FILE_APPEND);
|
|
|
|
if ( null === $test ) {
|
|
// Oops ! Problem !
|
|
}
|
|
// Stopper
|
|
elseif ( $test === false && $all === false ) {
|
|
break;
|
|
// Continuer ou Stopper sur element define
|
|
} elseif ( $test === true ) {
|
|
if ( array_key_exists('define', $c) ) {
|
|
$this->paramDefine($c['define']['var'], $c['define']['value']);
|
|
}
|
|
if ($all === true) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
|
|
return $test;
|
|
}
|
|
|
|
/**
|
|
* Transformation des variables
|
|
* @param string $val
|
|
* @return number|mixed|NULL
|
|
*/
|
|
protected function paramValue($val)
|
|
{
|
|
if ( is_numeric($val) ) {
|
|
return (float) $val;
|
|
}
|
|
|
|
if ( is_string($val) && defined('self::'.$val) ) {
|
|
return constant('self::'.$val);
|
|
}
|
|
|
|
if ( is_string($val) && is_array($this->{'Tab'.$val}) ) {
|
|
return $this->{'Tab'.$val};
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
/**
|
|
* Evaluation de la condition
|
|
* @param string $var
|
|
* @param string $type
|
|
* @param string $value
|
|
* @return boolean|NULL
|
|
*/
|
|
protected function paramEval($var, $type, $value)
|
|
{
|
|
$valueReal = $this->paramValue($value);
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "PARAM - ".$var." ".$type." ".$value." = ".$this->{'Val'.$var}."\n", FILE_APPEND);
|
|
|
|
switch ($type) {
|
|
case 'MIN':
|
|
if ( $this->{'Val'.$var} > $valueReal ) {
|
|
return true;
|
|
}
|
|
return false;
|
|
break;
|
|
|
|
case 'MAX':
|
|
if ( $this->{'Val'.$var} < $valueReal ) {
|
|
return true;
|
|
}
|
|
return false;
|
|
break;
|
|
|
|
case 'EGAL':
|
|
if ( $this->{'Val'.$var} == $valueReal ) {
|
|
return true;
|
|
}
|
|
return false;
|
|
break;
|
|
|
|
case 'LIST':
|
|
if ( in_array($this->{'Val'.$var}, $valueReal) ) {
|
|
return true;
|
|
}
|
|
return false;
|
|
break;
|
|
}
|
|
|
|
return null;
|
|
}
|
|
|
|
protected function _Indicateur($value)
|
|
{
|
|
switch($value)
|
|
{
|
|
case self::VERT:
|
|
return 'VERT';
|
|
break;
|
|
case self::ROUGE:
|
|
return 'ROUGE';
|
|
break;
|
|
case self::ORANGE:
|
|
return 'ORANGE';
|
|
break;
|
|
}
|
|
}
|
|
|
|
public function getIndicateur()
|
|
{
|
|
return $this->_Indicateur($this->ValFEU);
|
|
}
|
|
|
|
public function getPo()
|
|
{
|
|
return $this->ValPO;
|
|
}
|
|
|
|
/**
|
|
*
|
|
* @param string $name
|
|
* @param string $val
|
|
*/
|
|
protected function paramDefine($name, $val)
|
|
{
|
|
$value = null;
|
|
|
|
if ( is_numeric($val) ) {
|
|
$value = (int) $val;
|
|
}
|
|
|
|
if ( is_string($val) && defined('self::'.$val) ) {
|
|
$value = constant('self::'.$val);
|
|
}
|
|
|
|
if ($this->debug) file_put_contents('sfr.log', "SET VAR - Val".$name." = ".$value."\n", FILE_APPEND);
|
|
|
|
$this->{'Val'.$name} = $value;
|
|
}
|
|
|
|
/**
|
|
*
|
|
*/
|
|
public function getComment()
|
|
{
|
|
return $this->ValComment;
|
|
}
|
|
|
|
public function getDateCalculIndiscore()
|
|
{
|
|
return $this->dateCalculIndiscore;
|
|
}
|
|
|
|
/**
|
|
*
|
|
*/
|
|
protected function setTabs()
|
|
{
|
|
if ( $this->compile ) {
|
|
|
|
} else {
|
|
return $this->loadTabsFromDb();
|
|
}
|
|
}
|
|
|
|
/**
|
|
*
|
|
*/
|
|
protected function loadTabsFromDb(){}
|
|
|
|
/**
|
|
*
|
|
*/
|
|
protected function setRules()
|
|
{
|
|
if ( $this->compile ) {
|
|
$this->RulesVORp = include_once 'Metier/Sfr/RulesVORp-'.$this->version.'.php';
|
|
$this->RulesVORd = include_once 'Metier/Sfr/RulesVORd-'.$this->version.'.php';
|
|
} else {
|
|
$this->RulesVORp = $this->loadRulesFromDb('VORp');
|
|
$this->RulesVORd = $this->loadRulesFromDb('VORd');
|
|
}
|
|
}
|
|
|
|
protected function loadRulesFromDb($type = null)
|
|
{
|
|
|
|
|
|
}
|
|
|
|
|
|
protected function setCompile($compile = true)
|
|
{
|
|
$this->compile = $compile;
|
|
}
|
|
|
|
/**
|
|
* Define static file and version
|
|
* @param string $version
|
|
*/
|
|
protected function setVersion($version = null)
|
|
{
|
|
if ( null !== $version ) {
|
|
$this->version = $version;
|
|
}
|
|
}
|
|
|
|
} |