2013-11-05 11:18:30 +00:00
|
|
|
<?php
|
|
|
|
require_once dirname(__FILE__) . DIRECTORY_SEPARATOR . 'Infogreffe.php';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Infogreffe : Document Acte
|
|
|
|
*/
|
|
|
|
class Metier_Infogreffe_Ac extends Metier_Infogreffe
|
|
|
|
{
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Db Adapter
|
|
|
|
* @var Zend_Db_Adapter_Abstract
|
|
|
|
*/
|
|
|
|
public $db;
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $siren
|
|
|
|
*/
|
|
|
|
public function __construct($siren, $db = null)
|
|
|
|
{
|
|
|
|
parent::__construct();
|
|
|
|
|
|
|
|
//Set type
|
|
|
|
$this->type_document = 'AC';
|
|
|
|
|
|
|
|
//Set Siren
|
|
|
|
$this->siren = $siren;
|
|
|
|
|
|
|
|
//Get defaut database adapter
|
|
|
|
if ($db === null) {
|
2013-12-26 14:25:59 +00:00
|
|
|
$this->db = Zend_Db_Table_Abstract::getDefaultAdapter();
|
2013-11-05 11:18:30 +00:00
|
|
|
} else {
|
|
|
|
$this->db = $db;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param $onlyDb
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getList($onlyDb = false)
|
|
|
|
{
|
|
|
|
$this->mode_diffusion = 'XL';
|
|
|
|
$this->reference_client = 'list-' . $this->siren;
|
|
|
|
|
2014-02-25 16:33:07 +00:00
|
|
|
$actesM = new Application_Model_JoGreffesActes($this->db);
|
|
|
|
|
2013-11-05 11:18:30 +00:00
|
|
|
//Requete WebService
|
|
|
|
$actesXML = null;
|
|
|
|
if ( $onlyDb === false ) {
|
2014-02-25 16:33:07 +00:00
|
|
|
$actesM->update(array('actif' => 0), 'siren='.$this->siren);
|
2013-12-26 14:25:59 +00:00
|
|
|
//Infogreffe webservice
|
|
|
|
try {
|
|
|
|
$xml = $this->callRequest();
|
|
|
|
} catch( Exception $e ) {
|
2014-02-07 16:14:36 +00:00
|
|
|
//file_put_contents('debug.log', $e->getMessage());
|
2013-12-26 14:25:59 +00:00
|
|
|
//@todo : get error message
|
2014-02-25 16:33:07 +00:00
|
|
|
//echo $e->getMessage();
|
|
|
|
return array();
|
2013-12-26 14:25:59 +00:00
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
$actesXML = $this->formatList($xml);
|
|
|
|
}
|
|
|
|
|
|
|
|
//Lecture de la base de données
|
|
|
|
$sql = $actesM->select()
|
|
|
|
->where('siren=?', $this->siren)
|
2014-02-25 16:33:07 +00:00
|
|
|
->where('actif=1')
|
2014-02-07 16:14:36 +00:00
|
|
|
->order('date_depot DESC')
|
|
|
|
->order('num_depot DESC')
|
|
|
|
->order('num_acte ASC')
|
2013-11-05 11:18:30 +00:00
|
|
|
->order('date_acte DESC');
|
|
|
|
$rows = $actesM->fetchAll($sql);
|
|
|
|
|
|
|
|
$actes = array();
|
|
|
|
if ( count($rows)>0 ) {
|
|
|
|
foreach ( $rows as $row ) {
|
|
|
|
$item = new stdClass();
|
|
|
|
$item->File = $row->pdfLink;
|
|
|
|
$item->FileSize = $row->pdfSize;
|
|
|
|
$item->FileNumberOfPages = $row->pdfPage;
|
|
|
|
$item->DepotNum = $row->num_depot;
|
|
|
|
$item->DepotDate = $row->date_depot;
|
2014-02-07 16:14:36 +00:00
|
|
|
$item->ActeNum = str_pad($row->num_acte, 2, '0', STR_PAD_LEFT);
|
2013-11-05 11:18:30 +00:00
|
|
|
$item->ActeDate = $row->date_acte;
|
|
|
|
$item->ActeNumberOfPages = $row->nbpages_acte;
|
|
|
|
$item->ActeType = $row->type_acte;
|
|
|
|
$item->ActeTypeLabel = $row->type_acte_libelle;
|
|
|
|
|
|
|
|
$decisions = $row->decision_nature;
|
|
|
|
if (!empty($row->decision_nature) && !empty($row->decision_libelle)) {
|
|
|
|
$decisions.= ' : ';
|
|
|
|
}
|
|
|
|
$decisions.= $row->decision_libelle;
|
|
|
|
|
|
|
|
$item->infos[] = $decisions;
|
|
|
|
|
|
|
|
$mode_diffusion = explode(',', $row->mode_diffusion);
|
2014-01-16 10:47:25 +00:00
|
|
|
if (in_array('T',$mode_diffusion) || !empty($item->File)) {
|
2013-11-05 11:18:30 +00:00
|
|
|
$item->ModeDiffusion = 'T';
|
|
|
|
} elseif (in_array('C',$mode_diffusion)) {
|
|
|
|
$item->ModeDiffusion = 'C';
|
|
|
|
} else {
|
|
|
|
$item->ModeDiffusion = '';
|
|
|
|
}
|
|
|
|
|
|
|
|
$actes[] = $item;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $actes;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @todo : En cours
|
|
|
|
* @param string $depotDate
|
|
|
|
* @param int $depotNum
|
|
|
|
* @param string $acteType
|
|
|
|
* @param string $acteDate
|
|
|
|
* @param int $acteNum
|
2014-02-07 16:14:36 +00:00
|
|
|
* @param int $orderId
|
2013-11-05 11:18:30 +00:00
|
|
|
* @throws Exception
|
|
|
|
* @return string
|
|
|
|
* Return the full path of the file
|
|
|
|
*/
|
2014-02-07 16:14:36 +00:00
|
|
|
public function getCommandeT($depotDate, $depotNum, $acteType, $acteDate, $acteNum, $orderId = null)
|
2013-11-05 11:18:30 +00:00
|
|
|
{
|
|
|
|
//Lire dans la base de données
|
|
|
|
$actesM = new Application_Model_JoGreffesActes($this->db);
|
|
|
|
|
|
|
|
$sql = $actesM->select()
|
|
|
|
->where('siren=?', $this->siren)
|
|
|
|
->where('num_depot=?', $depotNum)
|
|
|
|
->where('date_depot=?', $depotDate)
|
|
|
|
->where('num_acte=?', $acteNum)
|
|
|
|
->where('date_acte=?', $acteDate)
|
|
|
|
->where('type_acte=?', $acteType);
|
|
|
|
|
|
|
|
$row = $actesM->fetchRow($sql);
|
|
|
|
if ( null === $row ) {
|
|
|
|
throw new Exception('Not exist');
|
|
|
|
}
|
|
|
|
|
2014-02-25 16:33:07 +00:00
|
|
|
$this->mode_diffusion = 'T';
|
|
|
|
$this->reference_client = 'T'.date('YmdHis');
|
2013-11-05 11:18:30 +00:00
|
|
|
$this->greffe = $row->numGreffe;
|
|
|
|
$this->dossier_millesime = substr($row->numRC,0,2);
|
|
|
|
$this->dossier_statut = substr($row->numRC,2,1);
|
|
|
|
$this->dossier_chrono = substr($row->numRC,3);
|
2014-02-25 16:33:07 +00:00
|
|
|
$this->date_depot = $row->date_depot;
|
2013-11-05 11:18:30 +00:00
|
|
|
$this->num_depot = $row->num_depot;
|
2014-02-25 16:33:07 +00:00
|
|
|
$this->date_acte = $row->date_acte;
|
|
|
|
$this->num = str_pad($row->num_acte, 2, '0', STR_PAD_LEFT);
|
|
|
|
|
|
|
|
//Needed element for filename
|
|
|
|
$date = $row->date_acte;
|
|
|
|
$type = $row->type_acte;
|
|
|
|
$num = $row->num_acte;
|
|
|
|
$options = $row->numGreffe . '-' . substr($row->numRC,0,2) . '-' . substr($row->numRC,2,1) . '-' . substr($row->numRC,3) . '-' . $row->num_depot;
|
|
|
|
|
|
|
|
//Set filename
|
|
|
|
$filename = $this->getFilePath($date) . '/' . $this->getFileName($date, $num, $type, $options);
|
2013-11-05 11:18:30 +00:00
|
|
|
|
|
|
|
if ( $row->pdfLink != '' ) {
|
|
|
|
|
|
|
|
//Set the filename
|
2014-02-25 16:33:07 +00:00
|
|
|
$filename = $this->getFilePath($date) . '/' . $row->pdfLink;
|
2013-11-05 11:18:30 +00:00
|
|
|
|
|
|
|
//Check if filename exist
|
2014-02-25 16:33:07 +00:00
|
|
|
if ( !file_exists($this->config->storage->path . '/' . $filename) ) {
|
2013-11-05 11:18:30 +00:00
|
|
|
throw new Exception('File not found');
|
|
|
|
}
|
|
|
|
|
2014-02-25 16:33:07 +00:00
|
|
|
} elseif ( file_exists($this->config->storage->path . '/' . $filename) ) {
|
|
|
|
|
|
|
|
//Analyser le fichier - Nombre de page et taille
|
|
|
|
$infos = $this->pdfInfos($this->config->storage->path . '/' . $filename);
|
|
|
|
|
|
|
|
//Enregistrer les infos du fichier dans la base de données
|
|
|
|
if (false !== $infos) {
|
|
|
|
$this->dbSetFile(basename($filename), $infos['size'], $infos['pages'], $infos['version']);
|
|
|
|
} else {
|
|
|
|
$this->dbSetFile(basename($filename));
|
|
|
|
}
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
try {
|
|
|
|
$xml = $this->callRequest();
|
|
|
|
} catch(Exception $e) {
|
|
|
|
throw new Exception($e->getMessage(), $e->getCode());
|
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
|
|
|
|
$acte = $this->formatItem($xml);
|
2014-02-25 16:33:07 +00:00
|
|
|
$url = $acte['actes'][0]['url_acces'];
|
2013-11-05 11:18:30 +00:00
|
|
|
if (empty($url)) {
|
|
|
|
throw new Exception('File url not given');
|
|
|
|
}
|
|
|
|
|
2014-02-07 16:14:36 +00:00
|
|
|
if ( $orderId !== null ) {
|
|
|
|
$commandeM = new Application_Model_Sdv1GreffeCommandesAc();
|
|
|
|
$commandeM->update(array(
|
|
|
|
'cmdUrl'=> $url,
|
|
|
|
'dateCommande' => date('YmdHis'),
|
|
|
|
), 'id='.$orderId);
|
|
|
|
}
|
|
|
|
|
2013-11-05 11:18:30 +00:00
|
|
|
//Récupérer le fichier
|
|
|
|
$getfile = $this->download($url, $filename);
|
|
|
|
|
|
|
|
//Analyser le fichier - Nombre de page et taille
|
|
|
|
$infos = $this->pdfInfos($getfile);
|
|
|
|
|
|
|
|
//Enregistrer les infos du fichier dans la base de données
|
|
|
|
if (false !== $infos) {
|
2014-02-25 16:33:07 +00:00
|
|
|
$this->dbSetFile(basename($filename), $infos['size'], $infos['pages'], $infos['version']);
|
|
|
|
} else {
|
|
|
|
$this->dbSetFile(basename($filename));
|
2013-11-05 11:18:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $filename;
|
|
|
|
}
|
|
|
|
|
2014-01-16 10:47:25 +00:00
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param unknown $depotDate
|
|
|
|
* @param unknown $depotNum
|
|
|
|
* @param unknown $acteType
|
|
|
|
* @param unknown $acteDate
|
|
|
|
* @param unknown $acteNum
|
|
|
|
* @param string $reference
|
|
|
|
* @throws Exception
|
|
|
|
* @return boolean
|
|
|
|
*/
|
|
|
|
public function getCommandeC($depotDate, $depotNum, $acteType, $acteDate, $acteNum, $reference = '')
|
2013-11-05 11:18:30 +00:00
|
|
|
{
|
2014-01-16 10:47:25 +00:00
|
|
|
//Lire dans la base de données
|
|
|
|
$actesM = new Application_Model_JoGreffesActes();
|
|
|
|
$sql = $actesM->select()
|
|
|
|
->where('siren=?', $this->siren)
|
|
|
|
->where('num_depot=?', $depotNum)
|
|
|
|
->where('date_depot=?', $depotDate)
|
|
|
|
->where('num_acte=?', $acteNum)
|
|
|
|
->where('date_acte=?', $acteDate)
|
|
|
|
->where('type_acte=?', $acteType);
|
|
|
|
$row = $actesM->fetchRow($sql);
|
|
|
|
if ( null === $row ) {
|
|
|
|
throw new Exception('Not exist');
|
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
|
2014-02-07 16:14:36 +00:00
|
|
|
$this->mode_diffusion = 'C';
|
2014-01-16 10:47:25 +00:00
|
|
|
$this->reference_client = $reference;
|
2013-11-05 11:18:30 +00:00
|
|
|
|
2014-01-16 10:47:25 +00:00
|
|
|
//Générer les paramètres de commande depuis la base de données
|
|
|
|
$this->greffe = $row->numGreffe;
|
|
|
|
$this->dossier_millesime = substr($row->numRC,0,2);
|
|
|
|
$this->dossier_statut = substr($row->numRC,2,1);
|
|
|
|
$this->dossier_chrono = substr($row->numRC,3);
|
|
|
|
$this->num_depot = $row->num_depot;
|
|
|
|
$this->type_acte = $row->type_acte;
|
|
|
|
$this->date_acte = $row->date_acte;
|
2014-02-07 16:14:36 +00:00
|
|
|
$this->num = str_pad($row->num_acte, 2, '0', STR_PAD_LEFT);
|
2013-11-05 11:18:30 +00:00
|
|
|
|
2014-01-16 10:47:25 +00:00
|
|
|
//Faire la requete
|
|
|
|
try {
|
|
|
|
$xml = $this->callRequest();
|
|
|
|
} catch(Exception $e) {
|
2014-02-07 16:14:36 +00:00
|
|
|
//La prise en charge du courrier est effective
|
|
|
|
if ( $e->getCode() != 17 ) {
|
|
|
|
throw new Exception($e->getMessage());
|
|
|
|
}
|
2014-01-16 10:47:25 +00:00
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
|
2014-01-16 10:47:25 +00:00
|
|
|
return true;
|
2013-11-05 11:18:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $date
|
|
|
|
* Date de l'acte au format AAAAMMJJ
|
|
|
|
* @param string $num
|
|
|
|
* Numéro de l'acte
|
|
|
|
* @param string $type
|
|
|
|
* Type de l'acte
|
|
|
|
* @param string $options
|
|
|
|
* (Numéro du Greffe)-(dossier_millesime)-(dossier_statut)-(dossier_chrono)-(num_depot)
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFileName($date, $num, $type, $options)
|
|
|
|
{
|
|
|
|
return 'acte-' . $this->siren . '-' . $type . '-' . $date . '-' . $options . '-' . $num . '.pdf';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param string $date
|
|
|
|
* Date de l'acte au format AAAA-MM-JJ
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getFilePath($date)
|
|
|
|
{
|
2014-02-07 16:14:36 +00:00
|
|
|
$dir = 'actes/' . substr($date,0,4) . '/' . substr($date,5,2);
|
|
|
|
if ( !file_exists( $this->config->storage->path . '/' . $dir ) ) {
|
|
|
|
mkdir($this->config->storage->path . '/' . $dir, 0777, true);
|
|
|
|
}
|
|
|
|
return $dir;
|
2013-11-05 11:18:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format XML to Array for a list of items
|
|
|
|
* @param string $xml
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function formatList($xml)
|
|
|
|
{
|
|
|
|
$doc = new DOMDocument();
|
|
|
|
$doc->loadXML($xml);
|
|
|
|
|
|
|
|
$liste_depot_acte = $doc->getElementsByTagName('liste_depot_acte')->item(0);
|
|
|
|
$depot_actes = $liste_depot_acte->getElementsByTagName('depot_acte');
|
|
|
|
$actes = array();
|
|
|
|
foreach($depot_actes as $depot_acte)
|
|
|
|
{
|
|
|
|
$acte = array();
|
|
|
|
|
|
|
|
$acte['num_gest'] = array();
|
|
|
|
$num_gest = $depot_acte->getElementsByTagName('num_gest')->item(0);
|
|
|
|
$acte['num_gest']['greffe'] = $num_gest->getElementsByTagName('greffe')->item(0)->nodeValue;
|
|
|
|
$acte['num_gest']['dossier_millesime'] = $num_gest->getElementsByTagName('dossier_millesime')->item(0)->nodeValue;
|
|
|
|
$acte['num_gest']['dossier_statut'] = $num_gest->getElementsByTagName('dossier_statut')->item(0)->nodeValue;
|
|
|
|
$acte['num_gest']['dossier_chrono'] = $num_gest->getElementsByTagName('dossier_chrono')->item(0)->nodeValue;
|
|
|
|
|
|
|
|
$acte['num_siren'] = $depot_acte->getElementsByTagName('num_siren')->item(0)->nodeValue;
|
|
|
|
$acte['num_depot'] = $depot_acte->getElementsByTagName('num_depot')->item(0)->nodeValue;
|
|
|
|
$acte['date_depot'] = $depot_acte->getElementsByTagName('date_depot')->item(0)->nodeValue;
|
|
|
|
|
|
|
|
$infoActes = $depot_acte->getElementsByTagName('acte');
|
|
|
|
$acte['depot'] = array();
|
|
|
|
foreach($infoActes as $infoActe)
|
|
|
|
{
|
|
|
|
$actenum = array();
|
|
|
|
$actenum['date_acte'] = $infoActe->getElementsByTagName('date_acte')->item(0)->nodeValue;
|
2014-02-07 16:14:36 +00:00
|
|
|
if ($infoActe->getElementsByTagName('date_acte')->item(0)->nodeValue == '') {
|
|
|
|
$actenum['date_acte'] = '0000-00-00';
|
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
$actenum['num_acte'] = $infoActe->getElementsByTagName('num_acte')->item(0)->nodeValue;
|
|
|
|
$actenum['type_acte'] = $infoActe->getElementsByTagName('type_acte')->item(0)->nodeValue;
|
|
|
|
$actenum['type_acte_libelle'] = $infoActe->getElementsByTagName('type_acte_libelle')->item(0)->nodeValue;
|
|
|
|
$actenum['nbpages_acte'] = $infoActe->getElementsByTagName('nbpages_acte')->item(0)->nodeValue;
|
|
|
|
$decision = $infoActe->getElementsByTagName('decision')->item(0);
|
|
|
|
if($decision)
|
|
|
|
{
|
|
|
|
$actenum['decision'] = array();
|
|
|
|
$actenum['decision']['nature'] = $decision->getElementsByTagName('nature')->item(0)->nodeValue;
|
|
|
|
$actenum['decision']['libelle'] = $decision->getElementsByTagName('libelle')->item(0)->nodeValue;
|
|
|
|
}
|
|
|
|
|
|
|
|
$actenum['mode_diffusion'] = array();
|
|
|
|
$mode_diffusion = $infoActe->getElementsByTagName('mode_diffusion')->item(0)->getElementsByTagName('mode');
|
|
|
|
foreach($mode_diffusion as $mode)
|
|
|
|
{
|
|
|
|
$actenum['mode_diffusion'][] = $mode->getAttribute('type');
|
|
|
|
}
|
|
|
|
$acte['depot'][] = $actenum;
|
|
|
|
}
|
|
|
|
//Fin listes des infos acte
|
|
|
|
|
|
|
|
//Enregistrer dans la bdd
|
|
|
|
$this->dbUpdateItem($acte);
|
|
|
|
|
|
|
|
//Génération de l'index pour le tri
|
|
|
|
if(!empty($acte['date_depot'])){ $date = $acte['date_depot']; }
|
|
|
|
else { $date = ''; }
|
|
|
|
|
|
|
|
if(!empty($date))
|
|
|
|
{
|
|
|
|
$datef = substr($date,0,4).substr($date,5,2).substr($date,8,2);
|
|
|
|
$key = $datef.'-'.$acte['num_depot'];
|
|
|
|
//Affectation liste générale avec un index permettant le tri
|
|
|
|
$actes[$key] = $acte;
|
|
|
|
}
|
|
|
|
//Prise en compte de l'acte -1
|
|
|
|
if($acte['num_depot']==-1)
|
|
|
|
{
|
|
|
|
$actes[0] = $acte;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//Tri suivant la date d'acte ou de depot
|
|
|
|
krsort($actes);
|
|
|
|
return $actes;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format XML to Array for one item
|
|
|
|
* @param string $xml
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
protected function formatItem($xml)
|
|
|
|
{
|
|
|
|
$doc = new DOMDocument();
|
|
|
|
$doc->loadXML($xml);
|
|
|
|
|
|
|
|
$depot_acte = $doc->getElementsByTagName('depot_acte')->item(0);
|
|
|
|
|
|
|
|
$info = array();
|
|
|
|
$info['num_gest'] = array();
|
|
|
|
|
|
|
|
$num_gest = $depot_acte->getElementsByTagName('num_gest')->item(0);
|
|
|
|
|
|
|
|
$info['num_gest']['greffe'] = $num_gest->getElementsByTagName('greffe')->item(0)->nodeValue;
|
|
|
|
$info['num_gest']['dossier_millesime'] = $num_gest->getElementsByTagName('dossier_millesime')->item(0)->nodeValue;
|
|
|
|
$info['num_gest']['dossier_statut'] = $num_gest->getElementsByTagName('dossier_statut')->item(0)->nodeValue;
|
|
|
|
$info['num_gest']['dossier_chrono'] = $num_gest->getElementsByTagName('dossier_chrono')->item(0)->nodeValue;
|
|
|
|
|
|
|
|
$info['num_siren'] = $depot_acte->getElementsByTagName('num_siren')->item(0)->nodeValue;
|
|
|
|
$info['num_depot'] = $depot_acte->getElementsByTagName('num_depot')->item(0)->nodeValue;
|
|
|
|
$info['date_depot'] = $depot_acte->getElementsByTagName('date_depot')->item(0)->nodeValue;
|
|
|
|
|
|
|
|
$infoActes = $depot_acte->getElementsByTagName('acte');
|
|
|
|
$info['actes'] = array();
|
|
|
|
foreach($infoActes as $infoActe)
|
|
|
|
{
|
|
|
|
$actenum = array();
|
|
|
|
$actenum['date_acte'] = $infoActe->getElementsByTagName('date_acte')->item(0)->nodeValue;
|
|
|
|
$actenum['num_acte'] = $infoActe->getElementsByTagName('num_acte')->item(0)->nodeValue;
|
|
|
|
$actenum['type_acte'] = $infoActe->getElementsByTagName('type_acte')->item(0)->nodeValue;
|
|
|
|
$actenum['type_acte_libelle'] = $infoActe->getElementsByTagName('type_acte_libelle')->item(0)->nodeValue;
|
|
|
|
$actenum['nbpages_acte'] = $infoActe->getElementsByTagName('nbpages_acte')->item(0)->nodeValue;
|
|
|
|
|
|
|
|
$decision = $infoActe->getElementsByTagName('decision')->item(0);
|
|
|
|
if($decision)
|
|
|
|
{
|
|
|
|
$actenum['decision'] = array();
|
|
|
|
$actenum['decision']['nature'] = $decision->getElementsByTagName('nature')->item(0)->nodeValue;
|
|
|
|
$actenum['decision']['libelle'] = $decision->getElementsByTagName('libelle')->item(0)->nodeValue;
|
|
|
|
}
|
|
|
|
$actenum['url_acces'] = htmlspecialchars_decode($infoActe->getElementsByTagName('url_acces')->item(0)->nodeValue);
|
|
|
|
$info['actes'][] = $actenum;
|
|
|
|
}
|
|
|
|
return $info;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Update informations about an item in database
|
|
|
|
* @param array $list
|
|
|
|
*/
|
|
|
|
protected function dbUpdateItem($list)
|
|
|
|
{
|
2014-02-07 16:14:36 +00:00
|
|
|
foreach ($list['depot'] as $depot) {
|
|
|
|
$data = array(
|
|
|
|
'siren' => $list['num_siren'],
|
|
|
|
'numRC' => $list['num_gest']['dossier_millesime'].
|
|
|
|
$list['num_gest']['dossier_statut'].$list['num_gest']['dossier_chrono'],
|
|
|
|
'numGreffe' => $list['num_gest']['greffe'],
|
|
|
|
'num_depot' => $list['num_depot'],
|
|
|
|
'date_depot' => $list['date_depot'],
|
|
|
|
'date_acte' => $depot['date_acte'],
|
|
|
|
'num_acte' => $depot['num_acte'],
|
|
|
|
'type_acte' => $depot['type_acte'],
|
|
|
|
'type_acte_libelle' => $depot['type_acte_libelle'],
|
|
|
|
'nbpages_acte' => $depot['nbpages_acte'],
|
|
|
|
'decision_nature' => empty($depot['decision']['nature']) ? '' : $depot['decision']['nature'] ,
|
|
|
|
'decision_libelle' => empty($depot['decision']['libelle']) ? '' : $depot['decision']['libelle'] ,
|
|
|
|
'mode_diffusion' => join(',',$depot['mode_diffusion']),
|
2014-02-25 16:33:07 +00:00
|
|
|
'actif' => 1,
|
2014-02-07 16:14:36 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
//Only new element are inserted
|
|
|
|
try {
|
|
|
|
$acteM = new Application_Model_JoGreffesActes($this->db);
|
|
|
|
$sql = $acteM->select()
|
2014-02-25 16:33:07 +00:00
|
|
|
->where('siren=?', $list['num_siren'])
|
|
|
|
->where('num_depot=?', intval($list['num_depot']))
|
|
|
|
//->where('date_depot=?', $list['date_depot'])
|
|
|
|
//->where('date_acte=?', $depot['date_acte'])
|
|
|
|
->where('num_acte=?', intval($depot['num_acte']))
|
|
|
|
->order('dateInsert DESC');
|
2014-02-07 16:14:36 +00:00
|
|
|
$rows = $acteM->fetchAll($sql);
|
|
|
|
} catch(Zend_Db_Adapter_Exception $e) {
|
2014-02-25 16:33:07 +00:00
|
|
|
throw new Exception($e->getMessage());
|
2014-02-07 16:14:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//Insert new element
|
|
|
|
if ( count($rows)==0 ) {
|
|
|
|
try {
|
2014-02-25 16:33:07 +00:00
|
|
|
//Add dateInsert
|
|
|
|
$data['dateInsert'] = date('YmdHis');
|
2014-02-07 16:14:36 +00:00
|
|
|
$result = $acteM->insert($data);
|
|
|
|
} catch(Zend_Exception $e) {
|
|
|
|
throw new Exception($e->getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//Update information
|
|
|
|
else {
|
|
|
|
//Correct multiple item
|
|
|
|
$item = $rows[0];
|
|
|
|
if ( count($rows) > 1 ) {
|
|
|
|
try {
|
2014-02-25 16:33:07 +00:00
|
|
|
$result = $acteM->delete(array(
|
|
|
|
'siren='.$this->siren,
|
|
|
|
'num_depot='.intval($list['num_depot']),
|
|
|
|
'num_acte='.intval($depot['num_acte']),
|
|
|
|
'id!='.$item->id,
|
|
|
|
));
|
2014-02-07 16:14:36 +00:00
|
|
|
} catch(Zend_Exception $e) {
|
|
|
|
throw new Exception($e->getMessage());
|
|
|
|
}
|
|
|
|
}
|
2014-02-25 16:33:07 +00:00
|
|
|
|
|
|
|
try {
|
|
|
|
$result = $acteM->update($data, 'id='.$item->id);
|
|
|
|
} catch(Zend_Exception $e) {
|
|
|
|
throw new Exception($e->getMessage());
|
2014-02-07 16:14:36 +00:00
|
|
|
}
|
2013-11-05 11:18:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2014-02-07 16:14:36 +00:00
|
|
|
return true;
|
2013-11-05 11:18:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set file informations in database
|
|
|
|
* @param string $filename
|
|
|
|
* @param int $size
|
|
|
|
* @param int $numberOfPage
|
|
|
|
* @param string $version
|
|
|
|
* @return boolean
|
|
|
|
*/
|
2014-02-25 16:33:07 +00:00
|
|
|
protected function dbSetFile($filename, $size = 0, $numberOfPage = '', $version = '')
|
2013-11-05 11:18:30 +00:00
|
|
|
{
|
|
|
|
$data = array(
|
|
|
|
'pdfLink' => $filename,
|
|
|
|
'pdfSize' => $size,
|
|
|
|
'pdfPage' => $numberOfPage,
|
2014-02-25 16:33:07 +00:00
|
|
|
'pdfVer' => $version,
|
|
|
|
'pdfDate' => date('Ymd'),
|
2013-11-05 11:18:30 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
$where = array(
|
2014-02-25 16:33:07 +00:00
|
|
|
'siren='.$this->siren,
|
|
|
|
'num_depot='.$this->num_depot,
|
|
|
|
'date_depot="'.$this->date_depot.'"',
|
|
|
|
'date_acte="'.$this->date_acte.'"',
|
|
|
|
'num_acte='.$this->num,
|
2013-11-05 11:18:30 +00:00
|
|
|
);
|
|
|
|
|
|
|
|
try {
|
|
|
|
$acteM = new Application_Model_JoGreffesActes();
|
|
|
|
$result = $acteM->update($data, $where);
|
|
|
|
} catch(Zend_Db_Adapter_Exception $e) {
|
|
|
|
throw new Exception($e->getMessage());
|
|
|
|
} catch(Zend_Db_Exception $e) {
|
|
|
|
throw new Exception($e->getMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($result) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
}
|