setDomain(1);
if($id!=0) $acces_m = $dom_1->getRights($PMBuserid,$id,8);
}
if ($acces_m==0) {
error_message('', htmlentities($dom_1->getComment('mod_noti_error'), ENT_QUOTES, $charset), 1, '');
} else {
//Pour les champs personnalises
require_once($class_path."/parametres_perso.class.php");
require_once($class_path."/notice.class.php");
require_once($class_path."/notice_doublon.class.php");
require_once($class_path."/authperso_notice.class.php");
require_once($class_path."/map/map_edition_controler.class.php");
require_once($class_path."/map_info.class.php");
require_once($class_path."/nomenclature/nomenclature_record_ui.class.php");
//Pour la synchro rdf
require_once($class_path."/synchro_rdf.class.php");
if($pmb_synchro_rdf){
$synchro_rdf = new synchro_rdf();
}
// Pour l'indexation des concepts
require_once($class_path."/index_concept.class.php");
$sign = new notice_doublon();
$signature = $sign->gen_signature();
if ($forcage == 1) {
$tab= unserialize(stripslashes($ret_url));
foreach($tab->GET as $key => $val){
if (get_magic_quotes_gpc())
$GLOBALS[$key] = $val;
else {
add_sl($val);
$GLOBALS[$key] = $val;
}
}
foreach($tab->POST as $key => $val){
if (get_magic_quotes_gpc())
$GLOBALS[$key] = $val;
else {
add_sl($val);
$GLOBALS[$key] = $val;
}
}
$signature = $sign->gen_signature();
} else if( $pmb_notice_controle_doublons != 0 ) {
//Si controle de dedoublonnage active
$signature = $sign->gen_signature();
// En modification de notice, on ne dedoublonne pas
if(!$id) {
$requete="select signature, niveau_biblio ,notice_id from notices where signature='$signature' ";
if($id) $requete.= " and notice_id != '$id' ";
$result=pmb_mysql_query($requete, $dbh);
if ($dbls=pmb_mysql_num_rows($result)) {
//affichage de l'erreur, en passant tous les param postes (serialise) pour l'eventuel forcage
$tab=new stdClass();
$tab->POST = $_POST;
$tab->GET = $_GET;
$ret_url= htmlentities(serialize($tab), ENT_QUOTES,$charset);
require_once("$class_path/mono_display.class.php");
print "
$msg[540]
".$msg["gen_signature_erreur_similaire"]."
";
if($dbls<$nb_per_page_search){
$maxAffiche=$dbls;
echo "".sprintf($msg["gen_signature_erreur_similaire_nb"],$dbls,$dbls)."
";
}else{
$maxAffiche=$nb_per_page_search;
echo "".sprintf($msg["gen_signature_erreur_similaire_nb"],$maxAffiche,$dbls)."
";
}
$enCours=1;
while($enCours<=$maxAffiche){
$r=pmb_mysql_fetch_object($result);
$nt = new mono_display($r->notice_id);
echo "
$nt->result
";
$enCours++;
}
exit();
}
}
} //fin du controle de dedoublonage
//synchro_rdf
if($pmb_synchro_rdf && $id){
$synchro_rdf->delRdf($id,0);
}
// definition de quelques variables
$requete = "INSERT INTO notices SET create_date=sysdate(), update_date=sysdate(), ";
$notitle_message = $msg[279];
$postrequete = "";
if($id) {
$requete = "UPDATE notices SET update_date=sysdate(), ";
$postrequete = " WHERE notice_id=$id ";
$notitle_message = $msg[280];
}
$req_notice_date_is_new="";
if($id) {
$req_new="select notice_is_new, notice_date_is_new from notices where notice_id=$id ";
$res_new=pmb_mysql_query($req_new, $dbh);
if (pmb_mysql_num_rows($res_new)) {
if($r=pmb_mysql_fetch_object($res_new)){
if($r->notice_is_new==$f_notice_is_new){ // pas de changement du flag
$req_notice_date_is_new= "";
}elseif($f_notice_is_new){ // Changement du flag et affecté comme new
$req_notice_date_is_new= ", notice_date_is_new =now() ";
}else{// raz date
$req_notice_date_is_new= ", notice_date_is_new ='' ";
}
}
}
}else{
if($f_notice_is_new){ // flag affecté comme new en création
$req_notice_date_is_new= ", notice_date_is_new =now() ";
}
}
// clean des vieilles nouveautés
if($pmb_newrecord_timeshift){
$req_old="UPDATE notices SET notice_date_is_new ='', notice_is_new=0, update_date=update_date where notice_date_is_new !='0000-00-00 00:00:00' and (notice_date_is_new < now() - interval $pmb_newrecord_timeshift day )";
pmb_mysql_query($req_old, $dbh);
}
$p_perso=new parametres_perso("notices");
$nberrors=$p_perso->check_submited_fields();
if(($f_tit1)&&trim($f_tit1)&&(!$nberrors)) {
// nettoyage des champs du form
$f_tit1 = clean_string($f_tit1);
$f_tit2 = clean_string($f_tit2);
$f_tit3 = clean_string($f_tit3);
$f_tit4 = clean_string($f_tit4);
$f_tparent = clean_string($f_tparent);
$f_tnvol = clean_string($f_tnvol);
$f_ed1 = clean_string($f_ed1);
$f_ed2 = clean_string($f_ed2);
$f_coll = clean_string($f_coll);
$f_subcoll = clean_string($f_subcoll);
$f_year = clean_string($f_year);
$f_nocoll = clean_string($f_nocoll);
$f_mention_edition = clean_string($f_mention_edition);
$f_cb = clean_string($f_cb);
$f_npages = clean_string($f_npages);
$f_ill = clean_string($f_ill);
$f_size = clean_string($f_size);
$f_prix = clean_string($f_prix);
$f_accomp = clean_string($f_accomp);
$f_lien = clean_string($f_lien);
$f_eformat = clean_string($f_eformat);
// le contenu des champs du form est mis dans un tableau
$t_notice['typdoc'] = $typdoc;
$t_notice['statut'] = $form_notice_statut;
$t_notice['notice_is_new'] = $f_notice_is_new+0;
$t_notice['commentaire_gestion'] = $f_commentaire_gestion;
$t_notice['thumbnail_url'] = $f_thumbnail_url;
$t_notice['num_notice_usage'] = $form_num_notice_usage;
$t_notice['tit1'] = $f_tit1;
$t_notice['tit2'] = $f_tit2;
$t_notice['tit3'] = $f_tit3;
$t_notice['tit4'] = $f_tit4;
if ($f_tparent && $f_tparent_id) $t_notice['tparent_id'] = $f_tparent_id ;
else $t_notice['tparent_id'] = 0;
$t_notice['tnvol'] = $f_tnvol;
// Titres uniformes
global $pmb_use_uniform_title;
if ($pmb_use_uniform_title) {
for ($i=0; $i<$max_titre_uniforme ; $i++) {
$var_tu_id = "f_titre_uniforme_code$i" ;
$var_ntu_titre = "ntu_titre$i" ;
$var_ntu_date = "ntu_date$i" ;
$var_ntu_sous_vedette = "ntu_sous_vedette$i" ;
$var_ntu_langue = "ntu_langue$i" ;
$var_ntu_version = "ntu_version$i" ;
$var_ntu_mention = "ntu_mention$i" ;
$titres_uniformes[] = array (
'num_tu' => ${$var_tu_id},
'ntu_titre' => ${$var_ntu_titre},
'ntu_date' => ${$var_ntu_date},
'ntu_sous_vedette' => ${$var_ntu_sous_vedette},
'ntu_langue' => ${$var_ntu_langue},
'ntu_version' => ${$var_ntu_version},
'ntu_mention' => ${$var_ntu_mention} )
;
}
}
// auteur principal
$f_aut[] = array (
'id' => $f_aut0_id,
'fonction' => $f_f0_code,
'type' => '0',
'ordre' => 0 );
// autres auteurs
for ($i=0; $i<$max_aut1; $i++) {
$var_autid = "f_aut1_id$i" ;
$var_autfonc = "f_f1_code$i" ;
$f_aut[] = array (
'id' => ${$var_autid},
'fonction' => ${$var_autfonc},
'type' => '1',
'ordre' => $i );
}
// auteurs secondaires
for ($i=0; $i<$max_aut2 ; $i++) {
$var_autid = "f_aut2_id$i" ;
$var_autfonc = "f_f2_code$i" ;
$f_aut[] = array (
'id' => ${$var_autid},
'fonction' => ${$var_autfonc},
'type' => '2',
'ordre' => $i );
}
$f_ed1 ? $t_notice['ed1_id'] = $f_ed1_id : $t_notice['ed1_id'] = 0;
$f_ed2 ? $t_notice['ed2_id'] = $f_ed2_id : $t_notice['ed2_id'] = 0;
$f_coll && $t_notice['ed1_id'] ? $t_notice['coll_id'] = $f_coll_id : $t_notice['coll_id'] = 0;
$f_subcoll && $t_notice['coll_id'] ? $t_notice['subcoll_id'] = $f_subcoll_id : $t_notice['subcoll_id'] = 0;
$t_notice['year'] = trim($f_year) ;
$f_nocoll && $t_notice['coll_id'] ? $t_notice['nocoll'] = trim($f_nocoll) : $t_notice['nocoll'] = '';
$t_notice['mention_edition'] = trim($f_mention_edition) ;
if ($f_cb) {
// ce controle redondant est la pour le cas ou l'utilisateur aurait change le code
if(isEAN($f_cb)) {
// la saisie est un EAN -> on tente de le formater en ISBN
$code = EANtoISBN($f_cb);
// si echec, on prend l'EAN comme il vient
if(!$code) $code = $f_cb;
} else {
if(isISBN($f_cb)) {
// si la saisie est un ISBN
$code = formatISBN($f_cb,13);
// si echec, ISBN errone on le prend sous cette forme
if(!$code) $code = $f_cb;
} else {
// ce n'est rien de tout ca, on prend la saisie telle quelle
$code = $f_cb;
}
}
$t_notice['code'] = $code;
}
$t_notice['npages'] = $f_npages;
$t_notice['ill'] = $f_ill;
$t_notice['size'] = $f_size;
$t_notice['prix'] = $f_prix;
$t_notice['accomp'] = $f_accomp;
$t_notice['n_gen'] = $f_n_gen;
$t_notice['n_contenu'] = $f_n_contenu;
$t_notice['n_resume'] = $f_n_resume;
// categories
if($tab_categ_order){
$categ_order=explode(",",$tab_categ_order);
$order=0;
foreach($categ_order as $old_order){
$var_categid = "f_categ_id$old_order" ;
if($var_categid){
$f_categ[] = array (
'id' => ${$var_categid},
'ordre' => $order );
$order++;
}
}
}else{
for ($i=0; $i< $max_categ ; $i++) {
$var_categid = "f_categ_id$i" ;
$f_categ[] = array (
'id' => ${$var_categid},
'ordre' => $i );
}
}
$f_indexint ? $t_notice['indexint'] = $f_indexint_id : $t_notice['indexint']= 0;
$f_lien ? $t_notice['lien'] = $f_lien : $t_notice['lien'] = '';
$t_notice['lien'] && $f_eformat ? $t_notice['eformat'] = $f_eformat : $t_notice['eformat'] = '';
$b_level ? $t_notice['b_level'] = $b_level : $t_notice['b_level'] = 'm';
$h_level ? $t_notice['h_level'] = $h_level : $t_notice['h_level'] = '0';
$date_parution_notice = notice::get_date_parution($t_notice['year']);
//Champ signature
$t_notice['signature'] = $signature;
$t_notice['indexation_lang'] = $indexation_lang;
$requete .= " typdoc='${t_notice['typdoc']}'";
$requete .= ", tit1='${t_notice['tit1']}'";
$requete .= ", tit2='${t_notice['tit2']}'";
$requete .= ", tit3='${t_notice['tit3']}'";
$requete .= ", tit4='${t_notice['tit4']}'";
$requete .= ", tparent_id=${t_notice['tparent_id']}";
$requete .= ", tnvol='${t_notice['tnvol']}'";
$requete .= ", ed1_id='${t_notice['ed1_id']}'";
$requete .= ", ed2_id='${t_notice['ed2_id']}'";
$requete .= ", coll_id='${t_notice['coll_id']}'";
$requete .= ", subcoll_id='${t_notice['subcoll_id']}'";
$requete .= ", year='${t_notice['year']}'";
$requete .= ", nocoll='${t_notice['nocoll']}'";
$requete .= ", mention_edition='${t_notice['mention_edition']}'";
$requete .= ", code='${t_notice['code']}'";
$requete .= ", npages='${t_notice['npages']}'";
$requete .= ", ill='${t_notice['ill']}'";
$requete .= ", size='${t_notice['size']}'";
$requete .= ", prix='${t_notice['prix']}'";
$requete .= ", accomp='${t_notice['accomp']}'";
$requete .= ", n_gen='${t_notice['n_gen']}'";
$requete .= ", n_contenu='${t_notice['n_contenu']}'";
$requete .= ", n_resume='$t_notice[n_resume]'";
$requete .= ", indexint='${t_notice['indexint']}'";
$requete .= ", index_l='".clean_tags($f_indexation)."'";
$requete .= ", lien='${t_notice['lien']}'";
$requete .= ", eformat='${t_notice['eformat']}'";
$requete .= ", niveau_biblio='${t_notice['b_level']}'";
$requete .= ", niveau_hierar='${t_notice['h_level']}'";
$requete .= ", statut='${t_notice['statut']}'";
$requete .= ", commentaire_gestion='${t_notice['commentaire_gestion']}'";
$requete .= ", thumbnail_url='${t_notice['thumbnail_url']}'";
$requete .= ", signature='${t_notice['signature']}'";
$requete .= ", date_parution='$date_parution_notice'";
$requete .= ", indexation_lang='${t_notice['indexation_lang']}'";
$requete .= ", notice_is_new='${t_notice['notice_is_new']}'";
$requete .= ", num_notice_usage='${t_notice['num_notice_usage']}'";
$requete .= $req_notice_date_is_new;
$requete .= $postrequete;
$result = pmb_mysql_query($requete, $dbh);
//traitement audit
if (!$id) {
$sav_id=0;
$id=pmb_mysql_insert_id($dbh);
audit::insert_creation (AUDIT_NOTICE, $id) ;
} else {
$sav_id=$id;
audit::insert_modif (AUDIT_NOTICE, $id) ;
}
// autorité personnalisées
$authperso = new authperso_notice($id);
$authperso->save_form();
// map
global $pmb_map_activate;
if($pmb_map_activate){
$map = new map_edition_controler(TYPE_RECORD, $id);
$map->save_form();
$map_info = new map_info($id);
$map_info->save_form();
}
// vignette de la notice uploadé dans un répertoire
$uploaded_thumbnail_url = thumbnail::create($id);
if($uploaded_thumbnail_url) {
$query = "update notices set thumbnail_url='".$uploaded_thumbnail_url."' where notice_id ='".$id."'";
pmb_mysql_query($query);
}
// Traitement des titres uniformes
if ($pmb_use_uniform_title) {
$ntu=new tu_notice($id);
$ntu->update($titres_uniformes);
}
//traitement des droits acces user_notice
if ($gestion_acces_active==1 && $gestion_acces_user_notice==1) {
if ($sav_id) {
$dom_1->storeUserRights(1, $id, $res_prf, $chk_rights, $prf_rad, $r_rad);
} else {
$dom_1->storeUserRights(0, $id, $res_prf, $chk_rights, $prf_rad, $r_rad);
}
}
//traitement des droits acces empr_notice
if ($gestion_acces_active==1 && $gestion_acces_empr_notice==1) {
$dom_2= $ac->setDomain(2);
if ($sav_id) {
$dom_2->storeUserRights(1, $id, $res_prf, $chk_rights, $prf_rad, $r_rad);
} else {
$dom_2->storeUserRights(0, $id, $res_prf, $chk_rights, $prf_rad, $r_rad);
}
}
//Traitement des liens
$notice_relations = notice_relations_collection::get_object_instance($id);
$notice_relations->set_properties_from_form();
$notice_relations->save();
// nomenclature
global $pmb_nomenclature_activate;
if($pmb_nomenclature_activate){
$nomenclature= new nomenclature_record_ui($id);
$nomenclature->save_form();
}
// Clean des vedettes
$id_vedettes_links_deleted=notice::delete_vedette_links($id);
// traitement des auteurs
$rqt_del = "delete from responsability where responsability_notice='$id' ";
$res_del = pmb_mysql_query($rqt_del);
$rqt_ins = "INSERT INTO responsability (responsability_author, responsability_notice, responsability_fonction, responsability_type, responsability_ordre) VALUES ";
$i=0;
$var_name='notice_role_composed';
$role_composed=${$var_name};
$var_name='notice_role_autre_composed';
$role_composed_autre=${$var_name};
$var_name='notice_role_secondaire_composed';
$role_composed_secondaire=${$var_name};
$id_vedettes_used=array();
while ($i<=count ($f_aut)-1) {
$id_aut=$f_aut[$i]['id'];
if ($id_aut) {
$fonc_aut = $f_aut[$i]['fonction'];
$type_aut = $f_aut[$i]['type'];
$ordre_aut = $f_aut[$i]['ordre'];
$rqt = $rqt_ins . " ('$id_aut','$id','$fonc_aut','$type_aut', $ordre_aut) " ;
$res_ins = @pmb_mysql_query($rqt);
$id_responsability=pmb_mysql_insert_id();
if($pmb_authors_qualification){
$id_vedette=0;
switch($type_aut){
case 0:
$id_vedette=update_vedette(stripslashes_array($role_composed[$ordre_aut]),$id_responsability,TYPE_NOTICE_RESPONSABILITY_PRINCIPAL);
break;
case 1:
$id_vedette=update_vedette(stripslashes_array($role_composed_autre[$ordre_aut]),$id_responsability,TYPE_NOTICE_RESPONSABILITY_AUTRE);
break;
case 2:
$id_vedette=update_vedette(stripslashes_array($role_composed_secondaire[$ordre_aut]),$id_responsability,TYPE_NOTICE_RESPONSABILITY_SECONDAIRE);
break;
}
if($id_vedette)$id_vedettes_used[]=$id_vedette;
}
}
$i++;
}
foreach ($id_vedettes_links_deleted as $id_vedette){
if(!in_array($id_vedette,$id_vedettes_used)){
$vedette_composee = new vedette_composee($id_vedette);
$vedette_composee->delete();
}
}
// traitement des categories
$rqt_del = "DELETE FROM notices_categories WHERE notcateg_notice='$id' ";
$res_del = pmb_mysql_query($rqt_del, $dbh);
$rqt_ins = "INSERT INTO notices_categories (notcateg_notice, num_noeud, ordre_categorie) VALUES ";
if(!isset($f_categ)) $f_categ = array();
while (list ($key, $val) = each ($f_categ)) {
$id_categ=$val['id'];
if ($id_categ) {
$ordre_categ = $val['ordre'];
$rqt = $rqt_ins . " ('$id','$id_categ',$ordre_categ) " ;
$res_ins = @pmb_mysql_query($rqt, $dbh);
}
}
// traitement des concepts
if($thesaurus_concepts_active == 1){
$index_concept = new index_concept($id, TYPE_NOTICE);
$index_concept->save();
}
// traitement des langues
// langues
$f_lang_form = array();
$f_langorg_form = array() ;
for ($i=0; $i< $max_lang ; $i++) {
$var_langcode = "f_lang_code$i" ;
if (${$var_langcode}) $f_lang_form[] = array ('code' => ${$var_langcode},'ordre' => $i);
}
// langues originales
for ($i=0; $i< $max_langorg ; $i++) {
$var_langorgcode = "f_langorg_code$i" ;
if (${$var_langorgcode}) $f_langorg_form[] = array ('code' => ${$var_langorgcode},'ordre' => $i);
}
$rqt_del = "delete from notices_langues where num_notice='$id' ";
$res_del = pmb_mysql_query($rqt_del, $dbh);
$rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue, ordre_langue) VALUES ";
while (list ($key, $val) = each ($f_lang_form)) {
$tmpcode_langue=$val['code'];
if ($tmpcode_langue) {
$tmpordre_langue = $val['ordre'];
$rqt = $rqt_ins . " ('$id',0, '$tmpcode_langue', $tmpordre_langue) " ;
$res_ins = pmb_mysql_query($rqt, $dbh);
}
}
// traitement des langues originales
$rqt_ins = "insert into notices_langues (num_notice, type_langue, code_langue, ordre_langue) VALUES ";
while (list ($key, $val) = each ($f_langorg_form)) {
$tmpcode_langue=$val['code'];
if ($tmpcode_langue) {
$tmpordre_langue = $val['ordre'];
$rqt = $rqt_ins . " ('$id',1, '$tmpcode_langue', $tmpordre_langue) " ;
$res_ins = @pmb_mysql_query($rqt, $dbh);
}
}
//Traitement des champs personnalises
$p_perso->rec_fields_perso($id);
if($result) {
} else {
// echec de la requete
error_message($libelle, $msg[281], 1, "./acquisition.php?categ=sug&action=modif&id_bibli=0&id_sug=".$id_sug);
}
//Recherche du titre uniforme automatique
global $opac_enrichment_bnf_sparql;
//$opac_enrichment_bnf_sparql=1;
$titre_uniforme=notice::getAutomaticTu($id);//ATTENTION si on récupère le titre uniforme ici alors il est bien ajoué à la notice mais pas affiché
// Mise à jour de tous les index de la notice
notice::majNoticesTotal($id);
//synchro_rdf
if($pmb_synchro_rdf){
$synchro_rdf->addRdf($id,0);
}
//Mise a jour de la suggestion
$sug = new suggestions($id_sug);
$sug->titre = stripslashes($t_notice['tit1']);
$f_aut[] = array (
'id' => $f_aut0_id,
'fonction' => $f_f0_code,
'type' => '0' );
if ($f_aut0_id) {
$auteur = new auteur($f_aut0_id);
$sug->auteur = $auteur->display;
}
if ($f_ed1_id) $sug->editeur = stripslashes($f_ed1);
$sug->code = $t_notice['code'];
$t_notice['prix'] = str_replace(',','.',$t_notice['prix']); //float(8,2)
$sug->prix = $t_notice['prix'];
$sug->num_notice = $id;
$sug->save();
} else {
if ($f_tit1=="") {
// erreur : le champ tit1 est vide
error_message($libelle, $notitle_message, 1, "./acquisition.php?categ=sug&action=modif&id_bibli=0&id_sug=".$id_sug);
} else {
error_message_history($msg["notice_champs_perso"],$p_perso->error_message,1);
}
}
}
function update_vedette($data,$id,$type){
if ($data["elements"]) {
$vedette_composee = new vedette_composee($data["id"],'notice_authors');
if ($data["value"]) {
$vedette_composee->set_label($data["value"]);
}
// On commence par réinitialiser le tableau des éléments de la vedette composée
$vedette_composee->reset_elements();
// On remplit le tableau des éléments de la vedette composée
$vedette_composee_id=0;
$tosave=false;
foreach ($data["elements"] as $subdivision => $elements) {
if ($elements["elements_order"] !== "") {
$elements_order = explode(",", $elements["elements_order"]);
foreach ($elements_order as $position => $num_element) {
if ($elements[$num_element]["id"] && $elements[$num_element]["label"]) {
$tosave=true;
$velement = $elements[$num_element]["type"];
if(strpos($velement,"vedette_ontologies") === 0){
$velement = "vedette_ontologies";
}
$available_field_class_name = $vedette_composee->get_at_available_field_class_name($velement, $elements[$num_element]["id"]);
if($available_field_class_name['params']){
$vedette_element = new $velement($available_field_class_name['params'],$available_field_class_name["num"],$elements[$num_element]["id"], $elements[$num_element]["label"]);
}else{
$vedette_element = new $velement($available_field_class_name["num"],$elements[$num_element]["id"], $elements[$num_element]["label"]);
}
$vedette_composee->add_element($vedette_element, $subdivision, $position);
}
}
}
}
if($tosave)$vedette_composee_id = $vedette_composee->save();
}
if ($vedette_composee_id) {
vedette_link::save_vedette_link($vedette_composee, $id, $type);
}
return $vedette_composee_id;
}