Пример #1
0
                 $notice_display = $display->result;
             }
             echo "\n\t\t\t\t\t\t<div class='row'>\n\t\t\t\t\t\t{$notice_display}\n\t\t\t\t \t    </div>\n\t\t\t\t\t\t<script type='text/javascript'>document.getElementById('el" . $r->notice_id . "Child').setAttribute('startOpen','Yes');</script>\n\t\t\t\t\t\t</div>";
             continue;
             $enCours++;
         }
     }
 }
 $z->signature = $signature;
 if ($infos['notice']) {
     $z->notice = $infos['notice'];
 }
 if ($infos['source_id']) {
     $z->source_id = $infos['source_id'];
 }
 $z->var_to_post();
 $ret = $z->insert_in_database();
 $id_notice = $ret[1];
 $rqt = "select recid from external_count where rid = '{$external_notice}'";
 $res = mysql_query($rqt);
 if (mysql_num_rows($res)) {
     $recid = mysql_result($res, 0, 0);
 }
 $req = "insert into notices_externes set num_notice = '" . $id_notice . "', recid = '" . $recid . "'";
 mysql_query($req);
 if ($ret[0]) {
     if ($z->bull_id && $z->perio_id) {
         $notice_display = new serial_display($ret[1], 6);
     } else {
         $notice_display = new mono_display($ret[1], 6);
     }
Пример #2
0
 function catalog_notice()
 {
     global $dbh;
     if ($this->sugg_noti_unimarc && !$this->num_notice) {
         $z = new z3950_notice("unimarc", $this->sugg_noti_unimarc);
         $z->var_to_post();
         $ret = $z->insert_in_database();
         //On attache la notice à la suggestion
         $req = " update suggestions set num_notice='" . $ret[1] . "' where id_suggestion='" . $this->id_suggestion . "'";
         pmb_mysql_query($req, $dbh);
     }
 }
Пример #3
0
 function doSync($id_connector, $id_source, $auto_import = false, $id_tache = '', $callback_listen_command = NULL, $callback_deals_command = NULL)
 {
     global $base_path, $dbh, $PMBuserid, $PMBusername, $msg, $charset;
     if (!$id_connector || !$id_source) {
         return array();
     }
     if (SESSrights & ADMINISTRATION_AUTH) {
         $this->callback_listen_command = $callback_listen_command;
         $this->callback_deals_command = $callback_deals_command;
         $result = array();
         $this->id_source = $id_source;
         $this->id_tache = $id_tache;
         $contrs = new connecteurs();
         require_once $base_path . "/admin/connecteurs/in/" . $contrs->catalog[$id_connector]["PATH"] . "/" . $contrs->catalog[$id_connector]["NAME"] . ".class.php";
         eval("\$conn=new " . $contrs->catalog[$id_connector]["NAME"] . "(\"" . $base_path . "/admin/connecteurs/in/" . $contrs->catalog[$id_connector]["PATH"] . "\");");
         //Vérification qu'il n'y a pas de synchronisation en cours...
         $is_already_sync = false;
         $recover_env = "";
         $recover = false;
         $requete = "select * from source_sync where source_id={$id_source}";
         $resultat = mysql_query($requete, $dbh);
         if (mysql_num_rows($resultat)) {
             $rs_s = mysql_fetch_object($resultat);
             if (!$rs_s->cancel) {
                 $result[] = $conn->msg["connecteurs_sync_currentexists"];
                 $is_already_sync = true;
             } else {
                 $recover = true;
                 $recover_env = $rs_s->env;
                 $env = array();
             }
         } else {
             $env = $conn->get_maj_environnement($id_source);
         }
         if (!$is_already_sync) {
             if (!$recover) {
                 $requete = "insert into source_sync (source_id,nrecu,ntotal,date_sync) values({$id_source},0,0,now())";
                 $r = mysql_query($requete, $dbh);
             } else {
                 $requete = "update source_sync set cancel=0 where source_id={$id_source}";
                 $r = mysql_query($requete, $dbh);
             }
             if ($r) {
                 $n_maj = $conn->maj_entrepot($id_source, array(&$this, "callback_progress"), $recover, $recover_env);
                 $result[] = sprintf($msg["connecteurs_count_notices"], $n_maj);
                 $result[] = $conn->error_message;
                 if (!$conn->error) {
                     $this->callback_progress(1, $n_maj, $n_maj);
                     $percent = 1;
                     $requete = "update source_sync set percent=" . round($percent * 100) . " where source_id={$id_source}";
                     $r = mysql_query($requete, $dbh);
                     $requete = "delete from source_sync where source_id=" . $id_source;
                     mysql_query($requete);
                     $requete = "update connectors_sources set last_sync_date=now() where source_id=" . $id_source;
                     mysql_query($requete, $dbh);
                 } else {
                     if ($conn->break_maj($id_source)) {
                         $requete = "delete from source_sync where source_id=" . $id_source;
                     } else {
                         $requete = "update source_sync set cancel=2 where source_id=" . $id_source;
                     }
                     mysql_query($requete, $dbh);
                     $result[] = $conn->error_message;
                 }
             } else {
                 $result[] = mysql_error();
             }
         } else {
             $result[] = $msg["connecteurs_sync_currentexists"];
         }
         //si l'import automatique est activé
         if ($auto_import) {
             //on va chercher les notices non intégrées
             $query = "select distinct entrepot_source_" . $id_source . ".recid from entrepot_source_" . $id_source . " left join notices_externes on notices_externes.recid = concat(connector_id,' " . $id_source . " ',ref) where num_notice is null";
             $result = mysql_query($query);
             if (mysql_num_rows($result)) {
                 while ($row = mysql_fetch_object($result)) {
                     $infos = entrepot_to_unimarc($row->recid);
                     if ($infos['notice']) {
                         $z = new z3950_notice("unimarc", $infos['notice'], $infos['source_id']);
                         if ($pmb_notice_controle_doublons != 0) {
                             $sign = new notice_doublon(true, $infos['source_id']);
                             $signature = $sign->gen_signature($row->recid);
                         } else {
                             $signature = "";
                         }
                         $z->signature = $signature;
                         if ($infos['notice']) {
                             $z->notice = $infos['notice'];
                         }
                         if ($infos['source_id']) {
                             $z->source_id = $infos['source_id'];
                         }
                         $z->var_to_post();
                         $ret = $z->insert_in_database(false);
                         $id_notice = $ret[1];
                         $rqt = "select recid from external_count where rid = '{$row->recid}'";
                         $res = mysql_query($rqt);
                         if (mysql_num_rows($res)) {
                             $recid = mysql_result($res, 0, 0);
                         }
                         $req = "insert into notices_externes set num_notice = '" . $id_notice . "', recid = '" . $recid . "'";
                         mysql_query($req);
                     }
                 }
             }
         }
         return $result;
     } else {
         return array();
     }
 }
Пример #4
0
 function import($unimarc_notice = '', $source_id = '')
 {
     global $deflt_integration_notice_statut;
     global $gestion_acces_active, $gestion_acces_user_notice, $gestion_acces_empr_notice;
     if ($unimarc_notice) {
         $this->converted_notice = $unimarc_notice;
     }
     if ($source_id) {
         $this->source_id = $source_id;
     }
     if ($this->converted_notice) {
         $z = new z3950_notice('unimarc', $this->converted_notice);
         $z->source_id = $this->source_id;
         $z->statut = $deflt_integration_notice_statut;
         $z->var_to_post();
         $retour = $z->insert_in_database();
         if ($retour[0]) {
             //parce que les droits sur une nouvelle ressource se calculent forcément sur le formulare que n'existe pas dans ce cas...
             if ($gestion_acces_active == 1) {
                 $ac = new acces();
                 //traitement des droits acces user_notice
                 if ($gestion_acces_user_notice == 1) {
                     $dom_1 = $ac->setDomain(1);
                     $dom_1->applyRessourceRights($retour[1]);
                 }
                 //traitement des droits acces empr_notice
                 if ($gestion_acces_empr_notice == 1) {
                     $dom_2 = $ac->setDomain(2);
                     $dom_2->applyRessourceRights($retour[1]);
                 }
             }
         }
     }
 }