2012-11-23 15:34:49 +00:00
< ? php
class MLiens2
{
2012-12-03 10:49:19 +00:00
/**
* Company Reference id
* @ var int
*/
protected $idRef = null ;
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
/**
* Company SIREN
* @ var string
*/
protected $siren = null ;
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
/**
2013-02-21 17:03:56 +00:00
* @ var Zend_Db_Adapter_Abstract
2012-12-03 10:49:19 +00:00
*/
protected $db ;
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
/**
* Array to list id find during list of childrens
* @ var array
*/
2012-11-23 15:34:49 +00:00
protected $findId = array ();
2013-02-11 13:26:20 +00:00
2013-09-23 06:24:24 +00:00
/**
* Stop the process to looks for company group head
* @ var boolean
*/
public $stopAtFirstIsin = false ;
/**
* Databas table name
* @ var string
*/
protected $_schema = 'jo' ;
2013-08-22 13:01:01 +00:00
/**
2012-11-23 15:34:49 +00:00
*
* @ param string $id
* @ param string $type ref | siren
2013-08-22 13:01:01 +00:00
* @ param Zend_Db_Adapter $db
2012-11-23 15:34:49 +00:00
* @ throws SoapFault
*/
2013-08-22 13:01:01 +00:00
public function __construct ( $id , $type = 'ref' , $db = null )
2012-11-23 15:34:49 +00:00
{
2013-02-21 17:03:56 +00:00
//Get defaut database adapter
2013-08-22 13:01:01 +00:00
if ( $db === null ) {
$this -> db = Zend_Db_Table_Abstract :: getDefaultAdapter ();
} else {
$this -> db = $db ;
Zend_Db_Table_Abstract :: setDefaultAdapter ( $db );
}
2013-09-11 19:30:48 +00:00
2013-02-21 17:03:56 +00:00
//Get Id
2012-12-04 15:54:34 +00:00
if ( $type == 'siren' ) {
2012-12-03 10:49:19 +00:00
$this -> siren = $id ;
2013-02-21 17:03:56 +00:00
$refM = new Application_Model_JoLiensRef ();
2012-11-23 15:34:49 +00:00
$sql = $refM -> select () -> where ( 'siren=?' , $id );
$result = $refM -> fetchRow ( $sql );
2012-12-04 15:54:34 +00:00
if ( $result !== null ) {
$this -> idRef = $result -> id ;
2012-11-23 15:34:49 +00:00
}
} else {
$this -> idRef = $id ;
}
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
/**
* Retourne les actionnaires
* @ param int $id
2012-12-03 10:49:19 +00:00
* @ param boolean $actif
2012-11-23 15:34:49 +00:00
* @ return array Tableau d ' actionnaires
*/
2012-12-03 10:49:19 +00:00
public function getActionnaires ( $id = null , $actif = null )
2012-11-23 15:34:49 +00:00
{
if ( null === $id ) {
$id = $this -> idRef ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
$liens = array ();
2013-02-11 13:26:20 +00:00
2012-12-04 15:54:34 +00:00
if ( null === $id ) {
return $liens ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
try {
$sql = $this -> db -> select ()
2013-02-21 17:03:56 +00:00
-> from ( array ( 'l' => $this -> _schema . '.liens2' ),
2012-11-23 15:34:49 +00:00
array ( 'id' , 'idAct' , 'PDetention' , 'Pvote' , 'MajMin' , 'idPar' ,
2013-02-18 08:35:19 +00:00
'dateEffetLien' , 'dateInsert' , 'dateUpdate' ))
2012-12-03 10:49:19 +00:00
-> where ( 'idPar=?' , $id )
2013-02-21 17:03:56 +00:00
-> join ( array ( 'r' => $this -> _schema . '.liensRef' ), 'l.idAct=r.id' ,
2012-11-23 15:34:49 +00:00
array ( 'LPAD(siren, 9, 000000000) AS siren' , 'PpPm' , 'RS' , 'civilite' , 'nom' , 'prenom' , 'nom_usage' ,
'naissance_date' , 'naissance_dept_pays' , 'naissance_lieu' , 'nat' ,
'adresse_num' , 'adresse_btq' , 'adresse_codvoie' , 'adresse_libvoie' ,
2013-02-18 08:35:19 +00:00
'adresse_comp' , 'adresse_cp' , 'adresse_ville' , 'adresse_pays' ,
'idLoc1Type' , 'idLoc1Num' , 'idLoc2Type' , 'idLoc2Num' , 'idLoc3Type' , 'idLoc3Num' ,
2012-11-23 15:34:49 +00:00
))
2012-12-03 10:49:19 +00:00
-> order ( 'PDetention DESC' );
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
//Actif / Inactif
if ( null !== $actif ) {
if ( false === $actif ) {
$sql -> where ( 'l.actif=?' , 0 );
} else {
$sql -> where ( 'l.actif=?' , 1 );
}
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
$liens = $this -> db -> fetchAll ( $sql , null , Zend_Db :: FETCH_OBJ );
2013-02-11 13:26:20 +00:00
} catch ( Zend_Db_Exception $e ) {
2013-02-21 17:03:56 +00:00
throw new Exception ( __METHOD__ . ': ' . $e -> getMessage ());
2012-11-23 15:34:49 +00:00
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
return $liens ;
}
/**
* Retourne les participations
* @ param int $id
2012-12-03 10:49:19 +00:00
* @ param boolean $actif
2012-11-23 15:34:49 +00:00
* @ return array Tableau des participations
*/
2012-12-03 10:49:19 +00:00
public function getParticipations ( $id = null , $actif = null )
2012-11-23 15:34:49 +00:00
{
if ( null === $id ) {
$id = $this -> idRef ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
if ( false === $actif ) {
$actif = 0 ;
} else {
$actif = 1 ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
$liens = array ();
2013-02-11 13:26:20 +00:00
2012-12-04 15:54:34 +00:00
if ( null === $id ) {
return $liens ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
try {
$sql = $this -> db -> select ()
2013-02-21 17:03:56 +00:00
-> from ( array ( 'l' => $this -> _schema . '.liens2' ),
2012-11-23 15:34:49 +00:00
array ( 'id' , 'idAct' , 'PDetention' , 'Pvote' , 'MajMin' , 'idPar' ,
2013-02-18 08:35:19 +00:00
'dateEffetLien' , 'dateInsert' , 'dateUpdate' ))
2012-12-03 10:49:19 +00:00
-> where ( 'idAct=?' , $id )
2013-02-21 17:03:56 +00:00
-> join ( array ( 'r' => $this -> _schema . '.liensRef' ), 'l.idPar=r.id' ,
2012-11-23 15:34:49 +00:00
array ( 'LPAD(siren, 9, 000000000) AS siren' , 'PpPm' , 'RS' , 'civilite' , 'nom' , 'prenom' , 'nom_usage' ,
'naissance_date' , 'naissance_dept_pays' , 'naissance_lieu' , 'nat' ,
'adresse_num' , 'adresse_btq' , 'adresse_codvoie' , 'adresse_libvoie' ,
2013-02-18 08:35:19 +00:00
'adresse_comp' , 'adresse_cp' , 'adresse_ville' , 'adresse_pays' ,
'idLoc1Type' , 'idLoc1Num' , 'idLoc2Type' , 'idLoc2Num' , 'idLoc3Type' , 'idLoc3Num' ,
2012-11-23 15:34:49 +00:00
))
2012-12-03 10:49:19 +00:00
-> order ( 'PDetention DESC' );
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
//Actif / Inactif
if ( null !== $actif ) {
if ( false === $actif ) {
$sql -> where ( 'l.actif=?' , 0 );
} else {
$sql -> where ( 'l.actif=?' , 1 );
}
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
$liens = $this -> db -> fetchAll ( $sql , null , Zend_Db :: FETCH_OBJ );
2013-02-11 13:26:20 +00:00
} catch ( Zend_Db_Exception $e ) {
2013-02-21 17:03:56 +00:00
throw new Exception ( __METHOD__ . ': ' . $e -> getMessage ());
2012-11-23 15:34:49 +00:00
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
return $liens ;
}
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
/**
* Fonctions de direction
2012-12-04 15:54:34 +00:00
* @ param boolean $actif
2012-12-03 10:49:19 +00:00
* @ return Zend_Db_Table_Rowset_Abstract
*/
public function getDirections ( $actif = null )
{
if ( null === $this -> siren ) {
2013-02-21 17:03:56 +00:00
$refM = new Application_Model_JoLiensRef ();
2012-12-03 10:49:19 +00:00
$rows = $refM -> find ( $this -> idRef );
2012-12-04 15:54:34 +00:00
$siren = str_pad ( $rows -> current () -> siren , 9 , '0' , STR_PAD_LEFT );
2012-12-03 10:49:19 +00:00
} else {
$siren = $this -> siren ;
}
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
$result = array ();
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
if ( null !== $siren && intval ( $siren ) != 0 )
{
2013-02-21 17:03:56 +00:00
try {
$directionsM = new Application_Model_JoRncsDirigeants ();
$sql = $directionsM -> select () -> from ( $directionsM , array (
'siren' , 'raisonSociale' , 'dirSiren' , 'dirRS' , 'civilite' , 'nom' ,
'prenom' , 'naissance_date' , 'naissance_lieu' , 'fonction_code' , 'fonction_lib'
)) -> where ( " typeDir IN ('PM', 'PP') " ) -> where ( 'dirSiren=?' , $siren );
//Actif / Inactif
if ( null !== $actif ) {
if ( false === $actif ) {
$sql -> where ( 'actif=?' , 0 );
} else {
$sql -> where ( 'actif=?' , 1 );
}
}
$sql -> order ( 'fonction_code DESC' );
$sql -> order ( 'raisonSociale ASC' );
$result = $directionsM -> fetchAll ( $sql );
} catch ( Zend_Db_Exception $e ) {
throw new Exception ( __METHOD__ . ': ' . $e -> getMessage ());
2012-12-03 10:49:19 +00:00
}
}
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
return $result ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
/**
* Retourne la maison mère
* @ param int $id
* @ return int
*/
public function getHead ( $id = null )
{
if ( null === $id ) {
$id = $this -> idRef ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
//Add ID to the list of known
$this -> findId [] = $id ;
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
//Through the list
2012-12-03 10:49:19 +00:00
$liens = $this -> getActionnaires ( $id , true );
2013-02-27 10:41:32 +00:00
2012-11-23 15:34:49 +00:00
//Find the following up entity
if ( count ( $liens ) > 0 ) {
foreach ( $liens as $item ) {
//Don't through again and again
if ( in_array ( $item -> idAct , $this -> findId ) ) {
2013-02-27 09:58:11 +00:00
return $item -> idAct ;
2013-09-23 06:24:24 +00:00
} elseif ( $this -> stopAtFirstIsin === true && ! empty ( $item -> isin )) {
break ;
}
//Remove physical person
elseif ( $item -> PpPm == 'PP' ) {
continue ;
2012-11-23 15:34:49 +00:00
}
//Same id
2012-12-03 10:49:19 +00:00
elseif ( $item -> idAct == $id ) {
2012-11-23 15:34:49 +00:00
return $id ;
}
//PDetention>50
2013-04-22 19:11:50 +00:00
elseif ( $item -> PDetention > 50 && $item -> idAct > 1000 ) {
2012-11-23 15:34:49 +00:00
return $this -> getHead ( $item -> idAct );
}
//MajMin=+
2013-04-22 19:11:50 +00:00
elseif ( $item -> MajMin == '+' && $item -> idAct > 1000 ) {
2012-11-23 15:34:49 +00:00
return $this -> getHead ( $item -> idAct );
}
//--
2012-12-03 10:49:19 +00:00
elseif ( $item -> idAct > 1000 ) {
2013-02-27 09:58:11 +00:00
return $this -> getHead ( $item -> idAct );
2012-11-23 15:34:49 +00:00
}
}
}
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
return $id ;
2012-11-23 15:34:49 +00:00
}
/**
* Retourne les éléments identitaire présent dans lienRef
* @ param string $id
* @ return Zend_Db_Table_Rowset_Abstract
*/
public function getIdentity ( $id = null )
{
if ( null === $id ) {
$id = $this -> idRef ;
}
2013-02-11 13:26:20 +00:00
2013-02-21 17:03:56 +00:00
$refM = new Application_Model_JoLiensRef ();
2012-11-23 15:34:49 +00:00
$row = $refM -> find ( $id );
if ( null !== row ) {
return $row -> current ();
}
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
/**
* Retourne l ' arborescence pour les groupes
* @ param int $pctMin
* @ param int $nbNiveaux
* @ return array
*/
public function getTree ( $pctMin = 33 , $nbNiveaux = 10 )
{
2013-09-23 06:24:24 +00:00
//Get identity to stop at isin
$itemWithIsin = null ;
if ( $this -> stopAtFirstIsin === true ) {
$id = $this -> idRef ;
$identity = $this -> getIdentity ( $this -> idRef );
if ( ! empty ( $isin ) ) {
$itemWithIsin = true ;
}
}
2012-11-23 15:34:49 +00:00
2013-09-23 06:24:24 +00:00
if ( $itemWithIsin !== true ) {
//Récupération de la maison mère
$id = $this -> getHead ();
//Informations de la maison mère
$identity = $this -> getIdentity ( $id );
}
2012-11-23 15:34:49 +00:00
$this -> findId = array ();
$this -> findId [] = $identity -> id ;
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
$nom = $identity -> RS ;
if ( $identity -> nom != '' ) {
$nom = $identity -> civilite . ' ' . $identity -> nom . ' ' . $identity -> prenom ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
//Retour
$tabRet = array (
'id' => $identity -> id ,
2012-12-03 10:49:19 +00:00
'name' => $nom ,
2012-11-23 15:34:49 +00:00
'siren' => str_pad ( $identity -> siren , 9 , '0' , STR_PAD_LEFT ),
2012-12-03 10:49:19 +00:00
'pmin' => $item -> PDetention ,
2012-11-23 15:34:49 +00:00
'pays' => $identity -> adresse_pays ,
'children' => $this -> getTreeRecursive ( $identity -> id , $pctMin , 1 , $nbNiveaux ),
);
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
return $tabRet ;
}
/**
* Retourne un sous élement de l ' arborescence pour les groupes
* @ param int $id
* @ param int $pctMin
* @ param int $niveau
* @ param int $nbNiveaux
* @ return array
*/
public function getTreeRecursive ( $id , $pctMin = 33 , $niveau = 0 , $nbNiveaux = 10 )
{
if ( $niveau > $nbNiveaux ) return array ();
$niveau ++ ;
$tabRet = array ();
2012-12-03 10:49:19 +00:00
$participations = $this -> getParticipations ( $id , true );
2012-11-23 15:34:49 +00:00
if ( count ( $participations ) > 0 ) {
foreach ( $participations as $item ) {
if ( $item -> PDetention > $pctMin ) {
$identity = $this -> getIdentity ( $item -> idPar );
2013-02-11 13:26:20 +00:00
2012-12-03 10:49:19 +00:00
$nom = $identity -> RS ;
if ( $identity -> nom != '' ) {
$nom = $identity -> civilite . ' ' . $identity -> nom . ' ' . $identity -> prenom ;
}
2013-02-11 13:26:20 +00:00
2012-11-23 15:34:49 +00:00
$data = array (
'id' => $identity -> id ,
2012-12-03 10:49:19 +00:00
'name' => $nom ,
2012-11-23 15:34:49 +00:00
'siren' => str_pad ( $identity -> siren , 9 , '0' , STR_PAD_LEFT ),
2012-12-03 10:49:19 +00:00
'pmin' => $item -> PDetention ,
2012-11-23 15:34:49 +00:00
'pays' => $identity -> adresse_pays ,
'children' => array (),
);
//Pour éviter d'avoir des boucles infinis
if ( ! in_array ( $identity -> id , $this -> findId ) ){
$this -> findId [] = $identity -> id ;
$data [ 'children' ] = $this -> getTreeRecursive ( $identity -> id , $pctMin , $niveau , $nbNiveaux );
}
$tabRet [] = $data ;
}
}
}
return $tabRet ;
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
/**
2013-09-11 19:30:48 +00:00
*
2013-08-22 13:01:01 +00:00
* @ return multitype : NULL
*/
public function getCAC40 ()
{
$sql = " SELECT isin, nom, MAX(`date`) AS dateMAJ FROM sdv1.bourse_listes WHERE lstCode='xcac40p' GROUP BY lstCode, isin HAVING MAX(`date`) ORDER BY dateMAJ DESC; " ;
$result = $this -> db -> query ( $sql );
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
$output = array ();
foreach ( $result as $item ) {
2013-09-11 19:30:48 +00:00
$output [] = $item -> isin ;
2013-08-22 13:01:01 +00:00
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
return $output ;
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
/**
2013-09-11 19:30:48 +00:00
*
2013-08-22 13:01:01 +00:00
* @ param number $pctMin
* @ return array
*/
public function getGroupeCAC40 ( $pctMin = 50 )
{
$listeIsin = $this -> getCAC40 ();
$isin = implode ( " , " , $listeIsin );
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
$refM = new Application_Model_JoLiensRef ();
$sql = $refM -> select ()
-> where ( " idLoc1Type=63 " ) -> where ( " idLoc1Num IN (?) " , $isin )
-> orWhere ( " idLoc2Type=63 " ) -> where ( " idLoc2Num IN (?) " , $isin )
-> orWhere ( " idLoc3Type=63 " ) -> where ( " idLoc3Num IN (?) " , $isin );
$result = $refM -> fetchAll ( $sql );
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
$this -> findId = array ();
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
$output = array ();
if ( $result -> count () > 0 ) {
foreach ( $result as $item ) {
$output = $output + $this -> getListeGroupeCAC40 ( $item -> id , $pctMin );
}
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
return $output ;
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
/**
2013-09-11 19:30:48 +00:00
*
2013-08-22 13:01:01 +00:00
* @ param int $id
* @ param number $pctMin
* @ return array
*/
2013-09-11 19:30:48 +00:00
public function getListeGroupeCAC40 ( $id , $pctMin = 50 )
2013-08-22 13:01:01 +00:00
{
$participations = $this -> getParticipations ( $id , true );
$output = array ();
if ( count ( $participations ) > 0 ) {
foreach ( $participations as $item ) {
if ( $item -> PDetention > $pctMin ) {
$identity = $this -> getIdentity ( $item -> idPar );
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
if ( intval ( $identity -> siren ) != 0 ) {
$output [] = $identity -> siren ;
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
if ( ! in_array ( $identity -> id , $this -> findId ) ){
$this -> findId [] = $identity -> id ;
$output = $output + $this -> getListeGroupeCAC40 ( $identity -> id , $pctMin );
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
}
}
}
return $output ;
}
2012-11-23 15:34:49 +00:00
2013-08-22 13:01:01 +00:00
/**
2013-09-11 19:30:48 +00:00
*
2013-08-22 13:01:01 +00:00
* @ param number $pctMin
* @ return boolean
*/
public function isInGroupeCAC40 ( $pctMin = 50 )
{
//Si pas d'actionnaires => false
if ( count ( $this -> getActionnaires ()) == 0 ) {
return false ;
2013-09-11 19:30:48 +00:00
}
$listeInGroupeCAC40 = $this -> getGroupeCAC40 ( $pctMin );
2013-08-22 13:01:01 +00:00
if ( in_array ( $this -> siren , $listeInGroupeCAC40 ) ) {
2013-09-11 19:30:48 +00:00
return true ;
2013-08-22 13:01:01 +00:00
}
2013-09-11 19:30:48 +00:00
2013-08-22 13:01:01 +00:00
return false ;
}
2013-09-11 19:30:48 +00:00
2012-11-23 15:34:49 +00:00
}