150 lines
5.5 KiB
PHP
150 lines
5.5 KiB
PHP
<?php
|
|
require_once 'framework/common/curl.php';
|
|
|
|
class MBourse
|
|
{
|
|
var $siren=false;
|
|
|
|
public function __construct($siren=0) {
|
|
$this->siren=$siren;
|
|
}
|
|
|
|
public function getLibSource($source) {
|
|
switch ($source) {
|
|
case 'B': return 'Business Wire'; break;
|
|
case 'H': return 'Hugin'; break;
|
|
case 'A': return 'ActusNews'; break;
|
|
case 'D': return 'DiRelease'; break;
|
|
case 'E': return 'Les Echos'; break;
|
|
default: return 'N/C'; break;
|
|
}
|
|
}
|
|
|
|
/** Obtenir le code ISIN à partir d'un siren
|
|
**
|
|
** @param integer $siren
|
|
** @return string
|
|
**/
|
|
function getCodeIsin($siren=false) {
|
|
$iDb=new WDB();
|
|
if (!$siren)
|
|
$siren=$this->siren;
|
|
|
|
$tabTmp=$iDb->select('infos_entrep', 'isin', "siren=$siren AND isin<>''", false, MYSQL_ASSOC);
|
|
return trim(@$tabTmp[0]['isin']);
|
|
}
|
|
|
|
/** Obtenir le SIREN à partir d'un code ISIN
|
|
**
|
|
** @param string $isin Code ISIN
|
|
** @return integer
|
|
**/
|
|
function getCodeSiren($isin) {
|
|
$iDb=new WDB();
|
|
$tabTmp=$iDb->select('infos_entrep', 'siren', "isin='$isin' AND siren<>0", false, MYSQL_ASSOC);
|
|
return trim($tabTmp[0]['siren']);
|
|
}
|
|
|
|
/** A partir d'un siren, récupère les informations règlementés
|
|
**
|
|
** @param integer $siren
|
|
** @param integer $id
|
|
** @return unknown
|
|
**/
|
|
function getInfosReg($siren=false, $id=false) {
|
|
|
|
if (!$siren)
|
|
$siren=$this->siren;
|
|
|
|
$isin=$this->getCodeIsin($siren);
|
|
unset($iDb);
|
|
$tabRet=array();
|
|
if ($isin<>'') {
|
|
$iDb=new WDB('presse');
|
|
if ($id) $sqlID=" AND id=$id ";
|
|
else $sqlID='';
|
|
|
|
$bodacc=$iDb->select( 'articles',
|
|
'id, companyName, companyIsin, companySiren, companyWebSite, pressReleaseDate, pressReleaseTitle, '.
|
|
'pressReleaseText, pressReleaseHtml, pressReleaseAttachments, pressReleaseUrl, source, dateInsert',
|
|
"companyIsin='$isin' $sqlID ORDER BY pressReleaseDate DESC", false, MYSQL_ASSOC);
|
|
if (count($bodacc)>0) {
|
|
foreach ($bodacc as $k=>$ann) {
|
|
if ($id)
|
|
$tabRet[$k]=array( 'id'=>$ann['id'],
|
|
'source'=>$this->getLibSource($ann['source']),
|
|
'DateParution'=>$ann['pressReleaseDate'],
|
|
'raisonSociale'=>$ann['companyName'],
|
|
'titre'=>$ann['pressReleaseTitle'],
|
|
'communique'=>$ann['pressReleaseText'],
|
|
'communiqueHtml'=>$ann['pressReleaseHtml'],
|
|
'pj'=>$ann['pressReleaseAttachments'],
|
|
'url'=>$ann['pressReleaseUrl'],
|
|
'dateInsertionSD'=>$ann['dateInsert'],
|
|
);
|
|
else
|
|
$tabRet[$k]=array( 'id'=>$ann['id'],
|
|
'source'=>$this->getLibSource($ann['source']),
|
|
'DateParution'=>$ann['pressReleaseDate'],
|
|
'raisonSociale'=>$ann['companyName'],
|
|
'titre'=>$ann['pressReleaseTitle'],
|
|
'pj'=>$ann['pressReleaseAttachments'],
|
|
'url'=>$ann['pressReleaseUrl'],
|
|
'dateInsertionSD'=>$ann['dateInsert'],
|
|
);
|
|
}
|
|
}
|
|
}
|
|
return $tabRet;
|
|
}
|
|
|
|
/** A partir d'un siren, récupère les informations boursières
|
|
**
|
|
** @param integer $siren
|
|
** @return unknown
|
|
**/
|
|
function getInfosBourse($siren=false) {
|
|
global $timer;
|
|
$iDb=new WDB('sdv1');
|
|
|
|
if (!$siren)
|
|
$siren=$this->siren;
|
|
|
|
$isin=$this->getCodeIsin($siren);
|
|
$timer['infosBoursieres-getCodeIsin']=microtime(true);
|
|
$tabRet=array();
|
|
if ($isin<>'') {
|
|
$datePre=date('Y-m').'-01';
|
|
if (APPLICATION_ENV=='development') {
|
|
$tabRes=$iDb->select( 'bourse_isin b, bourse_cours c',
|
|
'siren, raisonSociale, adresse, effectif, code_sicovam, code_mnemo, code_bloomberg, code_datastream, code_isin, logo, code_ric, '.
|
|
'dateIntroduction, dateDerAG, dateRadiation, autre_isin, eligibleSRD, eligiblePEA, nombreTitres, tel1, tel2, fax1, fax2, web, mail, '.
|
|
'marche, placeCotation, description, secteur, activite, activiteDet, dirigeants, actionnaires, chiffresTrim, '.
|
|
'c.autre, c.`date`, c.`heure`, c.`open` , c.`high` , c.`low` , c.`close` , c.`volume`',
|
|
"code_isin='$isin' /*OR siren=$siren)*/ AND b.code_isin=c.isin AND c.autre IN('','e','f','g','m','s','u') ORDER BY b.dateUpdate DESC, c.dateInsert DESC LIMIT 0,1", false, MYSQL_ASSOC);
|
|
} else {
|
|
$tabRes=$iDb->select( 'bourse_isin b, bourse_cours c',
|
|
'siren, raisonSociale, adresse, effectif, code_sicovam, code_mnemo, code_bloomberg, code_datastream, code_isin, logo, code_ric, '.
|
|
'dateIntroduction, dateDerAG, dateRadiation, autre_isin, eligibleSRD, eligiblePEA, nombreTitres, tel1, tel2, fax1, fax2, web, mail, '.
|
|
'marche, placeCotation, description, secteur, activite, activiteDet, dirigeants, actionnaires, chiffresTrim, '.
|
|
'c.autre, c.`date`, c.`heure`, c.`open` , c.`high` , c.`low` , c.`close` , c.`volume`',
|
|
"code_isin='$isin' /*OR siren=$siren)*/ AND b.code_isin=c.isin AND c.autre IN('','e','f','g','m','s','u') AND c.`date`>='$datePre' ORDER BY b.dateUpdate DESC, c.dateInsert DESC LIMIT 0,1", false, MYSQL_ASSOC);
|
|
}
|
|
|
|
$tabRet=$tabRes[0];
|
|
$timer['infosBoursieres-infosIsin']=microtime(true);
|
|
|
|
$tabRes=$iDb->select( 'bourse_cours',
|
|
'min(close) AS coursMin, avg(close) AS coursMoy, max(close) AS coursMax',
|
|
"isin='$isin' GROUP BY isin", false, MYSQL_ASSOC);
|
|
$tabTmp=$tabRes[0];
|
|
$tabRet['coursMin']=$tabTmp['coursMin'];
|
|
$tabRet['coursMoy']=$tabTmp['coursMoy'];
|
|
$tabRet['coursMax']=$tabTmp['coursMax'];
|
|
$timer['infosBoursieres-derniersCours']=microtime(true);
|
|
|
|
|
|
}
|
|
return $tabRet;
|
|
}
|
|
} |