".$msg['import_expl_form_titre']."



 
".gen_liste_multiple ("select id_notice_statut, gestion_libelle from notice_statut order by 2", "id_notice_statut", "gestion_libelle", "id_notice_statut", "statutnot", "", 1, "", "","","",0)."

 
 
 

 
 
 

".origin::gen_combo_box("authorities")."

". lender::gen_combo_box($book_lender_id)."  ". docs_statut::gen_combo_box($book_statut_id)."
". docs_location::gen_combo_box($deflt_docs_location)."



"; $tpl_beforeupload_notices = "

".$msg['import_noti_form_titre']."



 
".gen_liste_multiple ("select id_notice_statut, gestion_libelle from notice_statut order by 2", "id_notice_statut", "gestion_libelle", "id_notice_statut", "statutnot", "", 1, "", "","","",0)."

 
 
 

 
 
 

".origin::gen_combo_box("authorities","authorities_default_origin")."
 
"; //------------------------------------- L L I U R E X 02/02/2015 -------------------------------------- $tpl_beforeupload_reb = "

".$msg['import_reb_form_titre']."

"; //------------------------------------- FIN L L I U R E X 02/02/2015 -------------------------------------- // PRELOAD function loadfile_in_table () { global $msg ; global $sub, $book_lender_name ; global $noticenumber, $filename, $from_file, $pb_fini, $recharge ; global $pmb_import_limit_read_file ; //------------------------------------- L L I U R E X 02/02/2015-------------------------------------- //en principio parece que no le hace falta, pero lo dejo comentado porque puede servir de referencia para futuras modificaciones // if ((stripos($filename, "/temp/"))==false){ // $filename="../../temp/".$filename; //} //-------------------------------------FIN L L I U R E X 02/02/2015 -------------------------------------- if ($noticenumber=="") $noticenumber=0; if (!file_exists($filename)) { printf ($msg[506],$from_file); /* The file %s doesn't exist... */ return; } if (filesize($filename)==0) { printf ($msg[507],$from_file); /* The file % is empty, it's going to be deleted */ unlink ($filename); return; } $handle = fopen ($filename, "rb"); if (!$handle) { printf ($msg[508],$from_file); /* Unable to open the file %s ... */ return; } if ($sub=="import_expl") { printf ($msg[509], $from_file) ; printf ($msg[511], "\"".$book_lender_name."\"") ; } $file_size=filesize ($filename); $contents = fread ($handle, $file_size); fclose ($handle); /* First load of the shot, let's empty the import table */ if ($recharge=="") { $sql = "DELETE FROM import_marc WHERE origine='".addslashes(SESSid)."' "; $sql_result = mysql_query($sql) or die ("Couldn't delete import table !"); $sql = "DELETE FROM error_log WHERE error_origin LIKE '%_".addslashes(SESSid).".%' "; $sql_result = mysql_query($sql) or die ("Couldn't delete error_log table !"); } /* The whole file is in $contents, let's read it */ $str_lu=""; $j=0; $i=0; $pb_fini=""; $txt=""; while ( ($i<=strlen($contents)) && ($pb_fini=="") ) { $car_lu=substr($contents,$i,1) ; $i++; if ($i<=strlen($contents)) { if ($car_lu != chr(0x1d)) { /* the read car isn't the end of the notice */ $str_lu = $str_lu.$car_lu; } else { /* the read car is the end of a notice */ $str_lu = $str_lu.$car_lu; $j++; $sql = "INSERT INTO import_marc (notice,origine) VALUES('".addslashes($str_lu)."','".addslashes(SESSid)."')"; $sql_result = mysql_query($sql) or die ("Couldn't insert record!"); if ($j>=$pmb_import_limit_read_file && $i=$pmb_import_limit_read_file && $i>=strlen($contents)){ $pb_fini = "EOF"; } $str_lu=""; } } else { /* the wole file has been read */ $pb_fini="EOF"; } } /* end while red file */ if ($pb_fini=="NOTEOF") $recharge="YES"; else $recharge="NO" ; if ($pb_fini=="EOF") { /* The file has been read, we can delete it */ unlink ($filename); } } // fin fonction de load function recup_noticeunimarc($notice) { global $id_unimarc; global $doc_type ; global $hierarchic_level; global $bibliographic_level ; global $bibliographic_level_origine; global $hierarchic_level_origine; global $isbn ; global $issn_011 ; global $prix ; global $prix_cd ; global $cb ; global $lang_code ; global $org_lang_code ; global $tit_200a ; global $tit_200c ; global $tit_200d ; global $tit_200e ; global $tit_200v ; global $serie_200 ; global $editeur_lieu ; global $editeur_adr ; global $editeur_nom ; global $editeur_date ; global $editeur_pays ; global $editeur_pmbfields ; global $no_edition ; global $npages ; global $ill ; global $size ; global $accomp ; global $collection_225 ; global $n_contenu ; global $n_resume ; global $n_gen ; global $EAN ; global $collection_410 ; global $collection_411 ; global $serie ; global $index_sujets ; global $dewey ; global $dewey_l ; global $tu_500 ; global $tu_500_r ; global $tu_500_s ; global $tu_500_j ; global $aut_700 ; global $aut_701 ; global $aut_702 ; global $aut_710 ; global $aut_711 ; global $aut_712 ; global $origine_notice ; global $lien, $eformat ; global $info_995 ; global $info_996 ; global $info_852 ; global $analytique ; global $info_600_a, $info_600_j, $info_600_x, $info_600_y, $info_600_z ; global $info_601_a, $info_601_j, $info_601_x, $info_601_y, $info_601_z ; global $info_602_a, $info_602_j, $info_602_x, $info_602_y, $info_602_z ; global $info_605_a, $info_605_j, $info_605_x, $info_605_y, $info_605_z ; global $info_606_a, $info_606_j, $info_606_x, $info_606_y, $info_606_z ; global $info_607_a, $info_607_j, $info_607_x, $info_607_y, $info_607_z ; global $info_686; global $indicateur; global $link_generate; $id_import=array(); $id_unimarc=0; $indicateur=array(); $doc_type = ""; $hierarchic_level = '0'; $bibliographic_level = 'm'; $isbn = array(); $issn_011 = array(); $prix = array(); $prix_cd = array(); $cb = ""; $lang_code = array(); $org_lang_code = array(); $tit_200a = array(); $tit_200c = array(); $tit_200d = array(); $tit_200e = array(); $tit_200v = array(); $serie_200 = array(); $editeur_lieu = array(); $editeur_adr = array(); $editeur_nom = array(); $editeur_date = array(); $editeur_pays = array(); $editeur_pmbfields = array(); $npages = array(); $no_edition = array(); $ill = array(); $size = array(); $accomp = array(); $collection_225 = array(); $collection_410 = array(); $collection_411 = array(); $n_contenu = array(); $n_resume = array(); $n_gen = array(); $EAN = array(); $serie = array(); $index_sujets = array(); $dewey = array(); $dewey_l = array(); $tu_500 = array(); $tu_500_r = array(); $tu_500_s = array(); $tu_500_j = array(); $aut_700 = array(); $aut_701 = array(); $aut_702 = array(); $aut_710 = array(); $aut_711 = array(); $aut_712 = array(); $origine_notice = array() ; $lien = array(); $eformat = array(); $info_995 = array(); $info_852 = array(); $analytique = array() ; $info_600_a = array(); $info_600_j = array(); $info_600_x = array(); $info_600_y = array(); $info_600_z = array(); $info_601_a = array(); $info_601_j = array(); $info_601_x = array(); $info_601_y = array(); $info_601_z = array(); $info_602_a = array(); $info_602_j = array(); $info_602_x = array(); $info_602_y = array(); $info_602_z = array(); $info_605_a = array(); $info_605_j = array(); $info_605_x = array(); $info_605_y = array(); $info_605_z = array(); $info_606_a = array(); $info_606_j = array(); $info_606_x = array(); $info_606_y = array(); $info_606_z = array(); $info_607_a = array(); $info_607_j = array(); $info_607_x = array(); $info_607_y = array(); $info_607_z = array(); $info_686 = array(); $info_996 = array(); $record = new iso2709_record($notice, AUTO_UPDATE); if(!$record->valid("import_notice")){ // On ne traite pas les notices invalides /*echo "
";
		print_r($record->inner_data);
		echo "
"; die();*/ $num_notice=$record->get_subfield("001"); $titr=$record->get_subfield_array("200", 'a'); $requete="insert into error_log(error_origin,error_text) values('import_func_".addslashes(SESSid).".inc.php','".addslashes("La notice (numéro : ".$num_notice[0].", titre : ".$titr[0].") n'a pas été reprise.
Erreur(s):".implode("
",$record->errors)."
")."')"; mysql_query($requete); return false; } $doc_type=$record->inner_guide['dt']; $bibliographic_level_origine=$record->inner_guide['bl']; $hierarchic_level_origine=$record->inner_guide['hl']; // traitements particuliers, solution d'urgence pour les pério et autres. if($link_generate){ //Si on choisit d'importer les liens on reprend le niveau switch ($bibliographic_level_origine) { case 'a': $hierarchic_level = '2'; $bibliographic_level = 'a'; break; case 's': if($hierarchic_level_origine <= '1'){ $hierarchic_level = '1'; $bibliographic_level = 's'; } else { $hierarchic_level = '2'; $bibliographic_level = 'b'; } break; case 'm': case 'c': default : // suite à pb d'export Orphée : si inconnu, non conforme, on force à 0 et m $hierarchic_level = '0'; $bibliographic_level = 'm'; break; } }else{ //Sinon on reprend tous en temps que monographie $hierarchic_level = '0'; $bibliographic_level = 'm'; } for ($i=0;$iinner_directory);$i++) { $cle=$record->inner_directory[$i]['label']; //$length=$record->inner_directory[$i]['length']; //$adress=$record->inner_directory[$i]['adress']; $flag_cle=0; if(!array_key_exists($cle,$indicateur)) { $flag_cle=1; } // memo indicateur de champ $indicateur[$cle][]=substr($record->inner_data[$i]['content'],0,2); if($flag_cle) { switch($cle) { case "001" : $id_import=$record->get_subfield($cle); $id_unimarc = $id_import[0]; break; case "010": /* isbn */ $isbn=$record->get_subfield($cle,'a'); $prix=$record->get_subfield($cle,'d'); break; case "011": /* issn_011 */ $issn_011=$record->get_subfield($cle,'a'); break; case "071": /* barcode */ $cb=$record->get_subfield($cle,"a"); break; case "101": /* language */ $lang_code=$record->get_subfield_array($cle,"a"); $org_lang_code=$record->get_subfield_array($cle,"c"); break; case "200": /* titles */ $tit_200a=$record->get_subfield_array($cle, 'a'); $tit_200c=$record->get_subfield_array($cle, 'c'); $tit_200d=$record->get_subfield_array($cle, 'd'); $tit_200e=$record->get_subfield_array($cle, 'e'); $tit_200v=$record->get_subfield_array($cle, 'v'); $serie_200=$record->get_subfield($cle,"h","i"); break; case "205": /* no_edition */ $no_edition=$record->get_subfield_array($cle,"a"); break; case "210": /* publisher */ // b: adr $editeur_lieu=$record->get_subfield_array_array($cle, "a"); $editeur_adr=$record->get_subfield_array_array($cle, "b"); $editeur_nom=$record->get_subfield_array_array($cle, "c"); $editeur_date=$record->get_subfield_array($cle, "d"); $editeur_pays=$record->get_subfield_array_array($cle, "z"); $editeur_pmbfields=$record->get_subfield_array_array($cle, "9"); break; case "215": /* description */ $npages=$record->get_subfield_array($cle,"a"); $ill=$record->get_subfield_array($cle,"c"); $size=$record->get_subfield_array($cle,"d"); $accomp=$record->get_subfield_array($cle,"e"); break; case "225": /* collection */ $collection_225=$record->get_subfield($cle,"a","i","v","x"); break; case "300": /* inside */ $n_gen=$record->get_subfield_array($cle,"a"); break; case "327": /* inside */ $n_contenu=$record->get_subfield_array($cle,"a"); break; case "330": /* abstract */ $n_resume=$record->get_subfield_array($cle,"a"); break; case "345": /* EAN */ $EAN=$record->get_subfield($cle,"b"); $prix_cd=$record->get_subfield($cle,"d"); break; case "410": /* collection */ $collection_410=$record->get_subfield($cle,"v","t","x","3"); break; case "411": /* sub-collection */ $collection_411=$record->get_subfield($cle,"v","t","x","3"); break; case "461": /* series */ $serie=$record->get_subfield($cle,"t","v"); break; case "464": /* analytique */ // $a pour le tout-venant le reste pour les périodiques bretons ! C'est un periodique donc un depouillement ou une notice objet $analytique=$record->get_subfield_array_array($cle); $info_464=$record->get_subfield($cle,"t","v","p","d","z","e"); break; case "500": // titres uniformes $tu_500=$record->get_subfield($cle,"a","i","k","l","m","n","q","u","w","3"); $tu_500_r=$record->get_subfield_array_array($cle,"r"); $tu_500_s=$record->get_subfield_array_array($cle,"s"); $tu_500_j=$record->get_subfield_array_array($cle,"j"); break; case "600": // 600 PERSONAL NAME USED AS SUBJECT $info_600_a=$record->get_subfield_array_array($cle,"a"); $info_600_j=$record->get_subfield_array_array($cle,"j"); $info_600_x=$record->get_subfield_array_array($cle,"x"); $info_600_y=$record->get_subfield_array_array($cle,"y"); $info_600_z=$record->get_subfield_array_array($cle,"z"); break; case "601": // 601 CORPORATE BODY NAME USED AS SUBJECT $info_601_a=$record->get_subfield_array_array($cle,"a"); $info_601_j=$record->get_subfield_array_array($cle,"j"); $info_601_x=$record->get_subfield_array_array($cle,"x"); $info_601_y=$record->get_subfield_array_array($cle,"y"); $info_601_z=$record->get_subfield_array_array($cle,"z"); break; case "602": // 602 FAMILY NAME USED AS SUBJECT $info_602_a=$record->get_subfield_array_array($cle,"a"); $info_602_j=$record->get_subfield_array_array($cle,"j"); $info_602_x=$record->get_subfield_array_array($cle,"x"); $info_602_y=$record->get_subfield_array_array($cle,"y"); $info_602_z=$record->get_subfield_array_array($cle,"z"); break; case "605": // 605 TITLE USED AS SUBJECT $info_605_a=$record->get_subfield_array_array($cle,"a"); $info_605_j=$record->get_subfield_array_array($cle,"j"); $info_605_x=$record->get_subfield_array_array($cle,"x"); $info_605_y=$record->get_subfield_array_array($cle,"y"); $info_605_z=$record->get_subfield_array_array($cle,"z"); break; case "606": // RAMEAU / TOPICAL NAME USED AS SUBJECT $info_606_a=$record->get_subfield_array_array($cle,"a"); $info_606_j=$record->get_subfield_array_array($cle,"j"); $info_606_x=$record->get_subfield_array_array($cle,"x"); $info_606_y=$record->get_subfield_array_array($cle,"y"); $info_606_z=$record->get_subfield_array_array($cle,"z"); break; case "607": // 607 GEOGRAPHICAL NAME USED AS SUBJECT $info_607_a=$record->get_subfield_array_array($cle,"a"); $info_607_j=$record->get_subfield_array_array($cle,"j"); $info_607_x=$record->get_subfield_array_array($cle,"x"); $info_607_y=$record->get_subfield_array_array($cle,"y"); $info_607_z=$record->get_subfield_array_array($cle,"z"); break; case "610": /* mots clé */ $index_sujets=$record->get_subfield_array($cle,"a"); break; case "676": /* Dewey */ $dewey=$record->get_subfield_array($cle,"a"); $dewey_l=$record->get_subfield_array($cle,"l"); $dewey_num=$record->get_subfield_array($cle,"l","3"); break; case "686": /* pcdm3 */ $info_686=$record->get_subfield($cle,"a","l","3"); break; case "700": $aut_700=$record->get_subfield($cle,"a","b","c","d","4","f","N","3"); break; case "701": $aut_701=$record->get_subfield($cle,"a","b","c","d","4","f","N","3"); break; case "702": $aut_702=$record->get_subfield($cle,"a","b","c","d","4","f","N","3"); break; case "710": $aut_710=$record->get_subfield($cle,"a","b","c","g","d","4","f","e","k","l","m","n","3"); break; case "711": $aut_711=$record->get_subfield($cle,"a","b","c","g","d","4","f","e","k","l","m","n","3"); break; case "712": $aut_712=$record->get_subfield($cle,"a","b","c","g","d","4","f","e","k","l","m","n","3"); break; case "801": /* origine du catalogage */ $origine_notice=$record->get_subfield($cle,"a","b"); break; case "852": /* infos du SCD de Lyon 3 */ $info_852=$record->get_subfield($cle, "b", "h", "p", "y"); break; case "856": /* url */ $lien=$record->get_subfield($cle,"u"); $eformat=$record->get_subfield($cle,"q"); break; case "995": /* infos de la BDP */ $info_995=$record->get_subfield($cle, "a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z", "0","1","2","3","4","5","6","7","8","9","A","B","C","D","M","N","O","P","R","S","T","U","V","W","Z"); break; case "996": /* infos supplémentaires... ? */ $info_996=$record->get_subfield($cle, "a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z", "0","1","2","3","4","5","6","7","8","9","A","B","C","D","M","N","O","P","R","S","T","U","V","W","Z"); break; default: break; } /* end of switch */ } } /* end of for */ //Récupération des catégories en lien avec le fichier xml category_auto::get_info_categ($record); return true ; } // fin recup_noticeunimarc = fin récupération des variables lues dans la notice UNIMARC /* * Récupération des liens des notices */ function recup_noticeunimarc_link($notice){ global $notices_liees, $titre_ppal_200, $titre_perio_530a, $champ_210 ; $record = new iso2709_record($notice,AUTO_UPDATE); $titre_ppal_200 = $record->get_subfield('200','a','h','i'); $champ_210 = $record->get_subfield('210','d','h'); $titre_perio_530a = $record->get_subfield('530','a'); $notices_liees=$record->get_all_fields('4..'); } /* * Import d'une nouvelle notice */ function import_new_notice() { global $dbh ; global $notice_id ; global $bulletin_ex;//Identifiant du bulletin $bulletin_ex=0; global $id_unimarc; global $notices_crees; global $bulletins_crees; global $notices_a_creer; global $bulletins_a_creer; global $base_path; global $pmb_keyword_sep; global $link_generate; global $doc_type ; global $hierarchic_level ; global $bibliographic_level ; global $isbn_OK ; global $prix ; global $prix_cd ; global $cb ; global $tit_200a ; global $tit_200c ; global $tit_200d ; global $tit_200e ; global $tit_200v ; global $serie_200 ; global $editor ; global $editeur_lieu ; global $editeur_adr ; global $editeur_nom ; global $editeur_date ; global $editeur_pays ; global $editeur_pmbfields ; global $no_edition ; global $npages ; global $ill ; global $size ; global $accomp ; global $collection_225 ; global $n_contenu ; global $n_resume ; global $n_gen ; global $EAN ; global $collection_410 ; global $collection_411 ; global $tu_500 ; global $tu_500_r ; global $tu_500_s ; global $tu_500_j ; global $serie ; global $index_sujets ; global $dewey ; global $dewey_l ; global $aut_700 ; global $aut_701 ; global $aut_702 ; global $aut_710 ; global $aut_711 ; global $aut_712 ; global $origine_notice ; global $lien ; global $eformat ; global $analytique ; global $statutnot ; global $indicateur; global $add_explnum; global $info_686; global $authorities_notices; global $authorities_default_origin; $origin_authority= $authorities_default_origin; $add_explnum=FALSE; /* traitement des éditeurs */ $coll_id=0; $subcoll_id=0; $serie_id=0; $tnvol_ins=""; $ed1_id=0; $ed2_id=0; $year=""; $date_parution="0000-00-00"; //On récupère le tableau des notices créées à partir du fichier temporaire (rechargement d'iframe) if($link_generate && !isset($notices_crees)){ $tabimport_id= file_get_contents("$base_path/temp/liste_id".SESSid.".txt"); if($tabimport_id){ $tabimport_id = unserialize($tabimport_id); $notices_crees = $tabimport_id['notices_existantes']; $notices_a_creer = $tabimport_id['notices_a_creer']; $bulletins_crees = $tabimport_id['bulletins_crees']; $bulletins_a_creer = $tabimport_id['bulletins_a_creer']; } } if(!is_array($notices_crees)) $notices_crees = array(); //Pour le cas ou on est sur une notice (bidon) d'article juste pour les exemplaires de bulletin if($bibliographic_level == "a" && $tit_200d[0] == "Article_expl_bulletin"){ //On importe rien return; }elseif($tit_200d[0] == "Article_expl_bulletin"){ //Pour le cas ou on import sans les liens un fichier exporter avec les exemplaires et les liens $tit_200d[0]=""; } if($bibliographic_level != "a" && $bibliographic_level != "b"){ //Pour les articles et les bulletins on ne garde pas les informations suivantes $year=clean_string($editeur_date[0]); $date_parution=notice::get_date_parution($year); //traitement des éditeurs $editor=array(); foreach ( $editeur_nom as $key_nom1 => $nom1 ) { foreach ( $nom1 as $key_nom2 => $nom2 ) { $mon_ed=array(); $mon_ed["c"]=$nom2; if($editeur_adr[$key_nom1][$key_nom2]){ $mon_ed["b"]=$editeur_adr[$key_nom1][$key_nom2]; } if($editeur_lieu[$key_nom1][$key_nom2]){ $mon_ed["a"]=$editeur_lieu[$key_nom1][$key_nom2]; } if($editeur_pays[$key_nom1][$key_nom2]){ $mon_ed["z"]=$editeur_pays[$key_nom1][$key_nom2]; } if($editeur_pmbfields[$key_nom1][$key_nom2]){//Si j'ai ces informations c'est un export PMB donc je n'ai pas deux editeurs dans le même 210 foreach ( $editeur_pmbfields[$key_nom1] as $val9 ) { if(preg_match("/^(.+?):(.+)$/",$val9,$matches)){ $mon_ed[trim($matches[1])]=$matches[2]; } } } $editor[]=$mon_ed; } } $ed=array(); $ed['name']=clean_string($editor[0]['c']); $ed['adr']=clean_string($editor[0]['b']); if($editor[0]['adr1'])$ed['adr']=clean_string($editor[0]['adr1']);//Si cela vient de PMB dans $b j'ai un concat $ed['ville']=clean_string($editor[0]['a']); $ed['adr2']=clean_string($editor[0]['adr2']); $ed['cp']=clean_string($editor[0]['cp']); $ed['pays']=clean_string($editor[0]['z']); $ed['web']=clean_string($editor[0]['web']); $ed['ed_comment']=clean_string($editor[0]['comment']); $ed1_id = editeur::import($ed); $ed=array(); $ed['name']=clean_string($editor[1]['c']); $ed['adr']=clean_string($editor[1]['b']); if($editor[1]['adr1'])$ed['adr']=clean_string($editor[1]['adr1']);//Si cela vient de PMB dans $b j'ai un concat $ed['ville']=clean_string($editor[1]['a']); $ed['adr2']=clean_string($editor[1]['adr2']); $ed['cp']=clean_string($editor[1]['cp']); $ed['pays']=clean_string($editor[1]['z']); $ed['web']=clean_string($editor[1]['web']); $ed['ed_comment']=clean_string($editor[1]['comment']); $ed2_id = editeur::import($ed); if($bibliographic_level != "s"){ //Pour les periodiques on ne garde pas les informations suivantes /* traitement des collections */ $coll_name=""; $subcoll_name=""; $coll_issn=""; $subcoll_issn=""; $nocoll_ins=""; /* traitement de 225$a, si rien alors 410$t pour la collection */ if ($collection_225[0]['a']!="") { $coll_name=$collection_225[0]['a']; $coll_issn=$collection_225[0]['x']; } elseif ($collection_410[0]['t']!="") { $coll_name=$collection_410[0]['t']; $coll_issn=$collection_410[0]['x']; $coll_aut_number = $collection_410[0]['3']; } /* traitement de 225$i, si rien alors 411$t pour la sous-collection */ if ($collection_225[0]['i']!="") { $subcoll_name=$collection_225[0]['i']; $subcoll_issn=$collection_225[1]['x']; } elseif ($collection_411[0]['t']!="") { $subcoll_name=$collection_411[0]['t']; $subcoll_issn=$collection_411[0]['x']; $coll_aut_number = $collection_411[0]['3']; } /* gaffe au nocoll, en principe en 225$v selon FL sinon en 410$v ou 411$v*/ if ($collection_225[0]['v']!="") $nocoll_ins=$collection_225[0]['v']; elseif($collection_410[0]['v']!="") $nocoll_ins=$collection_410[0]['v']; elseif($collection_411[0]['v']!="") $nocoll_ins=$collection_411[0]['v']; else $nocoll_ins=""; $collec['name']=clean_string($coll_name); $collec['parent']=$ed1_id; $collec['issn']=clean_string($coll_issn); $collec['authority_number'] = $coll_aut_number; if($collec['authority_number']){ $coll_id = keep_authority_infos($collec['authority_number'],"collection",$origin_authority,0,$collec); }else{ $coll_id = collection::import($collec); } /* sous collection */ $subcollec['name']=clean_string($subcoll_name); $subcollec['coll_parent']=$coll_id; $subcollec['issn']=clean_string($subcoll_issn); $subcollec['authority_number'] = $subcoll_aut_number; if($subcollec['authority_number']){ $subcoll_id = keep_authority_infos($subcollec['authority_number'],"subcollection",$origin_authority,0,$subcollec); }else{ $subcoll_id = collection::import($subcollec); } $subcoll_id = subcollection::import($subcollec); /* traitement des séries */ $serie_id = serie::import(clean_string($serie[0]['t'])); $tnvol_ins=$serie[0]['v']; if(!$serie_id){ $serie_id = serie::import(clean_string($serie_200[0]['i'])); $serie[0]['t'] = $serie_200[0]['i']; //$tnvol_ins=$serie_200[0]['h']; } if(!$tnvol_ins){ $tnvol_ins=$serie_200[0]['h']; } } } /* traitement de Dewey */ $indexint_id = indexint::import(clean_string($dewey[0]),$dewey_l[0]); if(!$indexint_id and count($info_686)){ $indexint_id = indexint::import(clean_string($info_686[0]["a"]),$info_686[0]["l"],99); } /* Traitement des notes */ $n_resume_total = ""; $n_gen_total = ""; $n_contenu_total = ""; if (!$n_resume) $n_resume=array(); $n_resume_total= implode("\n",$n_resume); if (!$n_gen) $n_gen=array(); $n_gen_total= implode("\n",$n_gen); if (!$n_contenu) $n_contenu=array(); $n_contenu_total= implode("\n",$n_contenu); // ajout : les 464$a sont ajouté aux notes de contenu à déporter éventuellement dans func_bdp41 si besoin for ($i = 0; $i< count($analytique); $i++) { $ana=array(); for ($j = 0; $j< count($analytique[$i]); $j++) { $ana[$analytique[$i][$j]["label"]][]=$analytique[$i][$j]["content"]; } for ($j=0; $j $aut_700[0]['a'], "rejete" => $aut_700[0]['b'], "author_comment" => $aut_700[0]['c']." ".$aut_700[0]['d'], "date" => $aut_700[0]['f'], "type_auteur" => "70", "fonction" => $aut_700[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, 'authority_number' => $aut_700[0][3] ) ; } elseif ($aut_710[0]['a']!="") { /* auteur principal en 710 ? */ if(substr($indicateur["710"][0],0,1)=="1") $type_auteur="72"; else $type_auteur="71"; $lieu=$aut_710[0]['e']; if(!$lieu)$lieu=$aut_710[0]['k']; $aut_array[] = array( "entree" => $aut_710[0]['a'], "rejete" => $aut_710[0]['g'], "subdivision" => $aut_710[0]['b'], "author_comment" => $aut_710[0]['c'], "numero" => $aut_710[0]['d'], "lieu" => $lieu, "ville" => $aut_710[0]['l'], "pays" => $aut_710[0]['m'], "web" => $aut_710[0]['n'], "date" => $aut_710[0]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_710[0][4], "id" => 0, "responsabilite" => 0, "ordre" => 0, 'authority_number' => $aut_710[0][3] ) ; } /* renseignement de aut1 */ for ($i=0 ; $i < $nb_repet_701 ; $i++) { $aut_array[] = array( "entree" => $aut_701[$i]['a'], "rejete" => $aut_701[$i]['b'], "author_comment" => $aut_701[$i]['c']." ".$aut_701[$i]['d'], "date" => $aut_701[$i]['f'], "type_auteur" => "70", "fonction" => $aut_701[$i][4], "id" => 0, "responsabilite" => 1, "ordre" => ($i+1), 'authority_number' => $aut_701[$i][3] ) ; } for ($i=0 ; $i < $nb_repet_711 ; $i++) { if(substr($indicateur["711"][$i],0,1)=="1") $type_auteur="72"; else $type_auteur="71"; $lieu=$aut_711[$i]['e']; if(!$lieu)$lieu=$aut_711[$i]['k']; $aut_array[] = array( "entree" => $aut_711[$i]['a'], "rejete" => $aut_711[$i]['g'], "subdivision" => $aut_711[$i]['b'], "author_comment" => $aut_711[$i]['c'], "numero" => $aut_711[$i]['d'], "lieu" => $lieu, "ville" => $aut_711[$i]['l'], "pays" => $aut_711[$i]['m'], "web" => $aut_711[$i]['n'], "date" => $aut_711[$i]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_711[$i][4], "id" => 0, "responsabilite" => 1, "ordre" => ($i+1), 'authority_number' => $aut_711[$i][3] ) ; } /* renseignement de aut2 */ for ($i=0 ; $i < $nb_repet_702 ; $i++) { $aut_array[] = array( "entree" => $aut_702[$i]['a'], "rejete" => $aut_702[$i]['b'], "author_comment" => $aut_702[$i]['c']." ".$aut_702[$i]['d'], "date" => $aut_702[$i]['f'], "type_auteur" => "70", "fonction" => $aut_702[$i][4], "id" => 0, "responsabilite" => 2, "ordre" => ($i+1), 'authority_number' => $aut_702[$i][3] ) ; } for ($i=0 ; $i < $nb_repet_712 ; $i++) { if(substr($indicateur["712"][$i],0,1)=="1") $type_auteur="72"; else $type_auteur="71"; $lieu=$aut_712[$i]['e']; if(!$lieu)$lieu=$aut_712[$i]['k']; $aut_array[] = array( "entree" => $aut_712[$i]['a'], "rejete" => $aut_712[$i]['g'], "subdivision" => $aut_712[$i]['b'], "author_comment" => $aut_712[$i]['c'], "numero" => $aut_712[$i]['d'], "lieu" => $lieu, "ville" => $aut_712[$i]['l'], "pays" => $aut_712[$i]['m'], "web" => $aut_712[$i]['n'], "date" => $aut_712[$i]['f'], "type_auteur" => $type_auteur, "fonction" => $aut_712[$i][4], "id" => 0, "responsabilite" => 2, "ordre" => ($i+1), 'authority_number' => $aut_712[$i][3] ) ; } // récup des infos auteurs et mise en tableau : // appel de la fonction membre d'importation et insertion en table $rqt_ins = "insert into responsability (responsability_author, responsability_notice, responsability_fonction, responsability_type, responsability_ordre) VALUES "; $values=""; if(count($aut_array)){ for ($i=0 ; $igen_signature($notice_id); mysql_query("update notices set signature='$val' where notice_id=".$notice_id, $dbh); //Si on a un id de notice et qu'il n'est pas dans le tableau des notices créées, on l'ajoute if($link_generate && trim($id_unimarc) !== "" && !$notices_crees[$id_unimarc]){ $notices_crees[$id_unimarc]=$notice_id; }elseif($link_generate && trim($id_unimarc) !== "" && $notices_crees[$id_unimarc]){ //Si la notice a déjà été créé (Export des liens dans les notices liées) on remplace celle précédemment par celle en cour de traitement $niveau_biblio=$bibliographic_level.$hierarchic_level; switch ($niveau_biblio) { case 'm0': //On a une notice de monographie $notice_a_supp=$notices_crees[$id_unimarc]; //On garde les liens $requete = "UPDATE notices_relations SET num_notice='".$notice_id."' WHERE num_notice='".$notice_a_supp."' "; @mysql_query($requete, $dbh); $requete = "UPDATE notices_relations SET linked_notice='".$notice_id."' WHERE linked_notice='".$notice_a_supp."' "; @mysql_query($requete, $dbh); $ma_notice= new notice($notice_a_supp); $ma_notice->replace($notice_id); break; case 's1': //On a une notice de periodique $notice_a_supp=$notices_crees[$id_unimarc]; $ma_notice= new serial($notice_a_supp); $ma_notice->replace($notice_id); break; case 'b2': //On a une notice de bulletin $notice_a_supp=$notices_crees[$id_unimarc]; //Dans les bulletins $requete="update bulletins set num_notice='".$notice_id."' where num_notice='".$notice_a_supp."' "; mysql_query($requete,$dbh); //Dans les relations entre notice $requete="update notices_relations set num_notice='".$notice_id."' where num_notice='".$notice_a_supp."'"; mysql_query($requete,$dbh); $requete="update notices_relations set linked_notice='".$notice_id."' where linked_notice='".$notice_a_supp."'"; mysql_query($requete,$dbh); notice::del_notice($notice_a_supp); break; case 'a2': //On a une notice d'article $notice_a_supp=$notices_crees[$id_unimarc]; //Dans les bulletins $requete="update analysis set analysis_notice='".$notice_id."' where analysis_notice='".$notice_a_supp."' "; mysql_query($requete,$dbh); //Dans les relations entre notice $requete="update notices_relations set num_notice='".$notice_id."' where num_notice='".$notice_a_supp."'"; mysql_query($requete,$dbh); $requete="update notices_relations set linked_notice='".$notice_id."' where linked_notice='".$notice_a_supp."'"; mysql_query($requete,$dbh); notice::del_notice($notice_a_supp); break; } $notices_crees[$id_unimarc]=$notice_id; } } // fin import_new_notice /* * Importer les liens entre les notices */ function import_notice_link(){ global $notices_liees, $notices_a_creer, $id_unimarc, $dbh, $notices_crees, $bulletins_crees; global $notice_id, $titre_ppal_200, $titre_perio_530a, $champ_210, $bulletins_a_creer; global $hierarchic_level, $bibliographic_level, $tit_200d,$bulletin_ex; if($bibliographic_level == "a" && $hierarchic_level == "2" && $tit_200d[0] == "Article_expl_bulletin"){ //Quand on est sur le cas de la reconstruction d'un exemplaire de bulletin $tab_bull= array(); $tab_bull = get_infos_notices_liees($notices_liees,'463','bull_expl'); $id_perio=creer_notice_periodique($tab_bull[0]["0"][0],$tab_bull[0]["t"][1],$tab_bull[0]["x"][0]); $bulletin=array(); $bulletin=array("titre"=>$tab_bull[0]["t"][0],"date"=>$tab_bull[0]["d"][0],"mention"=>$tab_bull[0]["e"][0],"num"=>$tab_bull[0]["v"][0]); $bulletin_ex=creer_bulletin($id_perio,$bulletin); return; } //Traitements des liens entre notices $requete = "SELECT * FROM notices WHERE notice_id='".$notice_id."'"; $res = mysql_query($requete,$dbh); while(($notice_creee=mysql_fetch_object($res))){ $niveau_biblio = $notice_creee->niveau_biblio.$notice_creee->niveau_hierar; $tab_field = $tab_art = $tab_bull = $tab_perio = array(); switch($niveau_biblio){ case 's1' : //Lien(s) vers Périodique $tab_art = get_infos_notices_liees($notices_liees,'464','art'); $tab_bull = get_infos_notices_liees($notices_liees,'462','bull'); creer_bulletinage_et_articles($tab_bull,$tab_art); break; case 'b2' : //Lien(s) vers Notice de bulletin creer_liens_pour_bull_notice($titre_ppal_200, $titre_perio_530a, $champ_210, get_infos_notices_liees($notices_liees,'461','parent','b')); break; case 'a2' : //Lien(s) vers Article $tab_perio = get_infos_notices_liees($notices_liees,'461','perio'); $tab_bull = get_infos_notices_liees($notices_liees,'463','bull'); $tab_field = array("id_base"=>$id_unimarc, "titre"=> $titre_ppal_200); /*print "xxxxxxxxxxxxxxxxxxxxxxxx".$notice_id; print "
";
				print_r($tab_bull);
				print_r($tab_perio);
				print_r($tab_field);
				print "

";*/ creer_liens_pour_articles($tab_bull,$tab_perio, $tab_field); break; default: break; } } //Traitement des relations mères/filles $parents = get_infos_notices_liees($notices_liees,'','parent'); if(count($parents)){ foreach($parents as $key=>$parent){ //Si pas de titre, on évite de créer une notice sans titre if(!isset($parent["t"])){ unset($parents[$key]); } } //Reste-t-il des relations à créer après nettoyage ci-dessus ? if(count($parents)){ creer_relation_notice($parents); } } $enfants = get_infos_notices_liees($notices_liees,'','child'); if(count($enfants)){ foreach($enfants as $key=>$enfant){ //Si pas de titre, on évite de créer une notice sans titre if(!isset($enfant["t"])){ unset($enfants[$key]); } } //Reste-t-il des relations à créer après nettoyage ci-dessus ? if(count($enfants)){ creer_relation_notice($enfants); } } //On traite les notices qui ont été mises en attente de création if($notices_a_creer[$id_unimarc]) { for($i=0;$i$notices_a_creer[$id_unimarc][$i]['titre'],"date"=>$notices_a_creer[$id_unimarc][$i]['date'],"mention"=>$notices_a_creer[$id_unimarc][$i]['mention'],"num"=>$notices_a_creer[$id_unimarc][$i]['num']); creer_notice_article("","","",$id_art?$id_art:$notice_id,$bulletin,"","",$id_perio); } elseif($notices_a_creer[$id_unimarc][$i]['lnk'] == 'perio'){ //On a un lien d'un periodique vers un article if(!$notices_crees[$id_unimarc]){//On ne peut pas passer par la $req_insert_perio = "insert into notices (tit1, code, niveau_biblio, niveau_hierar) values( '".addslashes($notices_a_creer[$id_unimarc][$i]['titre_perio'])."', '".addslashes($notices_a_creer[$id_unimarc][$i]['code']).", 's', '1' )"; mysql_query($req_insert_perio,$dbh); $id_perio = mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_perio); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($id_perio); $notices_crees[$id_unimarc] = $id_perio; }else{ $id_perio=$notices_crees[$id_unimarc]; } $bulletin=array(); $bulletin=array("titre"=>$notices_a_creer[$id_unimarc][$i]['titre_bull'],"date"=>$notices_a_creer[$id_unimarc][$i]['date'],"mention"=>$notices_a_creer[$id_unimarc][$i]['mention'],"num"=>$notices_a_creer[$id_unimarc][$i]['num']); creer_notice_article("","","",$notices_a_creer[$id_unimarc][$i]['id_asso'],$bulletin,"","",$id_perio); } } unset($notices_a_creer[$id_unimarc]); } //On rattache le perio a ses notices de bulletin if ($bulletins_a_creer[$id_unimarc]){ $id_perio=$notice_id; for($i=0;$i$bulletins_a_creer[$id_unimarc][$i]['titre'],"date"=>$bulletins_a_creer[$id_unimarc][$i]['date_date'],"mention"=>$bulletins_a_creer[$id_unimarc][$i]['mention'],"num"=>$bulletins_a_creer[$id_unimarc][$i]['bull_num']); $id_bulletin= creer_bulletin($id_perio,$bulletin,"",""); creer_lien_notice_bulletin("",$id_perio,$id_bulletin,$bulletins_a_creer[$id_unimarc][$i]['bull_notice'],"",$bulletin); } unset($bulletins_a_creer[$id_unimarc]); } } /* * Récupération de sous tableaux correspondant aux critères */ function get_infos_notices_liees($notices_liees=array(), $cle_uni='', $lien='', $type_lien=''){ $result_tab = array(); $link_tab = array(); $type_link_tab = array(); if($cle_uni){ $result_tab = $notices_liees[$cle_uni]; if($lien && $result_tab){ foreach($result_tab as $field){ //on récupère toutes les options du $9 dans un tableau $options=array(); for($i=0;$itrim($titre200[0]['i']),"date"=>trim($champ210[0]['h']),"mention"=>trim($champ210[0]['d']),"num"=>trim($titre200[0]['h'])); $id_bull=creer_bulletin($id_perio,$bulletin); creer_lien_notice_bulletin($id_unimarc,$id_perio,$id_bull,$notice_id,"",$bulletin); } } else { if(!$notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')] && !$tab_perio[0]['0']['0']){ //On créé le periodique car il n'est pas créé et n'est pas à créé if(!trim($titre530[0]))$titre530[0]="Sans titre"; if($tmp=get_valeur_champ9($tab_perio[0]['9'],'id')){ $id_perio=creer_notice_periodique($tmp,trim($titre530[0]),$tab_perio[0]['x']['0']); }else{ $id_perio=creer_notice_periodique(0,trim($titre530[0]),$tab_perio[0]['x']['0']); } $bulletin=array(); $bulletin=array("titre"=>trim($titre200[0]['i']),"date"=>trim($champ210[0]['h']),"mention"=>trim($champ210[0]['d']),"num"=>trim($titre200[0]['h'])); $id_bull=creer_bulletin($id_perio,$bulletin); creer_lien_notice_bulletin($id_unimarc,$id_perio,$id_bull,$notice_id,"",$bulletin); }elseif($notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')]){ //La notice de perio est déja créé $id_perio=$notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')]; $bulletin=array(); $bulletin=array("titre"=>trim($titre200[0]['i']),"date"=>trim($champ210[0]['h']),"mention"=>trim($champ210[0]['d']),"num"=>trim($titre200[0]['h'])); $id_bull=creer_bulletin($id_perio,$bulletin); creer_lien_notice_bulletin($id_unimarc,$id_perio,$id_bull,$notice_id,"",$bulletin); }elseif($tab_perio[0]['0']['0']){ //Le lien sera a refaire plus tard $bulletins_a_creer[$tab_perio[0]['0'][0]][] = array ("bull_notice"=>$notices_crees[$id_unimarc], "bull_num"=>$titre200[0]['h'], "date_date"=>$champ210[0]['h'],"mention"=>$champ210[0]['d'],"titre"=>$titre200[0]['i']); }else{ //Si j'ai un bulletin avec un 461 qui ne rentre pas dans les autres cas je passe le bulletin en monographie (cas très peu probable) $requete="select bulletin_id from bulletins where num_notice='".addslashes($notice_id)."' "; $res = mysql_query($requete,$dbh); if (!mysql_num_rows($res)) { //Si il n'est pas déja relié je le passe en monographie sinon je n'y touche pas $requete="update notices set niveau_biblio='m', niveau_hierar='0' where notice_id='".$notice_id."' "; mysql_query($requete,$dbh); } } } } /* * Génère la création des liens pour les articles */ function creer_liens_pour_articles($tab_bull=array(),$tab_perio=array(), $tab_field=array()){ global $notice_id, $dbh, $notices_crees, $bulletins_crees, $notices_a_creer,$serie,$champ_210; if(!$tab_bull && !$tab_perio){ //On regarde si on a les informations de bulletinage dans le 461 if(trim($serie[0]["t"]) and trim($serie[0]["v"])){ //J'ai les informations pour recréer le bulletinage $bulletin=array(); $bulletin=array("titre"=>"Bulletin N°".trim($serie[0]["v"]),"date"=>"","mention"=>trim($champ_210[0]['d']),"num"=>trim($serie[0]["v"])); creer_notice_article("","","",$notice_id,$bulletin,trim($serie[0]["t"]),"",0); }else{ //Si elle a été créée mais qu'elle n'est pas a créer if( !$tab_field['id_base'] || ($notices_crees[$tab_field['id_base']] && !$notices_a_creer[$tab_field['id_base']])){ //On regarde si elle n'est pas reliée a un bulletin $requete="select analysis_bulletin from analysis where analysis_notice='".addslashes($notices_crees[$tab_field['id_base']])."' "; $res=mysql_query($requete,$dbh); if(!mysql_num_rows($res)){ //Si elle n'est pas reliée on la passe en monographie, sinon c'est bien un article $requete="update notices set niveau_biblio='m', niveau_hierar='0' where notice_id='".addslashes($notice_id)."' "; mysql_query($requete,$dbh); } }elseif(!$notices_crees[$tab_field['id_base']] && !$notices_a_creer[$tab_field['id_base']]){ //on ne doit pas passer par là $req_insert_art = "insert into notices (tit1, niveau_biblio, niveau_hierar) values( '".addslashes($tab_field['titre'][0]['a'])."', 'm', '0' )"; mysql_query($req_insert_art,$dbh); $notices_crees[$tab_field['id_base']] = mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$notices_crees[$tab_field['id_base']]); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($notices_crees[$tab_field['id_base']]); } } } elseif($tab_bull && !$tab_perio){ //On créé un periodique sans titre (On regarde avant si on en a pas déja créé une) $bulletin=array(); $bulletin=array("titre"=>$tab_bull[0]['v'][0],"date"=>$tab_bull[0]['d'][0],"mention"=>$tab_bull[0]['e'][0],"num"=>$tab_bull[0]['v'][0]); creer_notice_article("","","",$notice_id,$bulletin,"Sans titre","",0); } elseif(!$tab_bull && $tab_perio){ //On créé un bulletin générique pour rattacher les articles au pério if(!$notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')] && !$tab_perio[0]['0'][0]){// Si le periodique n'est pas déja créé et si il ne sera pas a créer $id_perio=creer_notice_periodique(get_valeur_champ9($tab_perio[0]['9'],'id'),$tab_perio[0]['t'][0],$tab_perio[0]['x'][0]); $bulletin=array(); $bulletin=array("titre"=>"bull_générique","date"=>"0000-00-00","mention"=>"00/00/0000","num"=>"0"); creer_notice_article("","","",$notice_id,$bulletin,"","",$id_perio); }elseif($notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')]){//Si il est déja créé $id_perio=$notices_crees[get_valeur_champ9($tab_perio[0]['9'],'id')]; $bulletin=array(); $bulletin=array("titre"=>"bull_générique","date"=>"0000-00-00","mention"=>"00/00/0000","num"=>"0"); creer_notice_article("","","",$notice_id,$bulletin,"","",$id_perio); }else{ // Les liens seront à creer plus tard pour cet article $id=get_valeur_champ9($tab_perio[0]['9'],'id'); $type_lien =get_valeur_champ9($tab_perio[0]['9'],'type_lnk'); $lien=get_valeur_champ9($tab_perio[0]['9'],'lnk'); $rank=get_valeur_champ9($tab_perio[0]['9'],'rank')*1; $notices_a_creer[$id][] = array( "type_lnk"=> $type_lien, "lnk"=> $lien, "rank"=>$rank, "titre_perio"=>$tab_perio[0]['t'][0], "code"=>$tab_perio[0]['x'][0], "id_asso"=>$notice_id, "num"=>"0", "mention"=>"00/00/0000","date"=>"0000-00-00","titre_bull"=>"bull_générique"); } } else { for($i=0;$i$tab_bull[$i]['t'][0],"date"=>$tab_bull[$i]['d'][0],"mention"=>$tab_bull[$i]['e'][0],"num"=>$tab_bull[$i]['v'][0]); creer_notice_article("","","",$notice_id,$bulletin,"","",$id_perio); } else{ if($notices_crees[get_valeur_champ9($tab_perio[$i]['9'],'id')]){ //Si il est créé on récupère son identifiant $id_perio= $notices_crees[get_valeur_champ9($tab_perio[$i]['9'],'id')]; //On regarde si le bulletin est déja créé $bulletin=array(); $bulletin=array("titre"=>$tab_bull[$i]['t'][0],"date"=>$tab_bull[$i]['d'][0],"mention"=>$tab_bull[$i]['e'][0],"num"=>$tab_bull[$i]['v'][0]); creer_notice_article("","","",$notice_id,$bulletin,"","",$id_perio); } else { $id=get_valeur_champ9($tab_perio[$i]['9'],'id'); $type_lien =get_valeur_champ9($tab_perio[$i]['9'],'type_lnk'); $lien=get_valeur_champ9($tab_perio[$i]['9'],'lnk'); $rank=get_valeur_champ9($tab_perio[$i]['9'],'rank')*1; $notices_a_creer[$id][] = array( "type_lnk"=> $type_lien, "lnk"=> $lien, "rank"=>$rank, "titre_perio"=>$tab_perio[$i]['t'][0], "code"=>$tab_perio[$i]['x'][0], "id_asso"=>$notice_id, "num"=>$tab_bull[$i]['v'][0], "mention"=>$tab_bull[$i]['e'][0],"date"=>$tab_bull[$i]['d'][0],"titre_bull"=>$tab_bull[$i]['t'][0]); } } } } } /* * Fonction qui génère la création du bulletinage et les articles pour les périos */ function creer_bulletinage_et_articles($bull=array(), $art=array()){ global $notice_id, $dbh, $notices_a_creer, $bulletins_crees, $notices_crees,$tit_200a,$isbn_OK,$id_unimarc,$msg; global $force_creation_notice_perio; //On regarde si la notice n'existe pas déjà dans la base $requete="select notice_id from notices where tit1 LIKE '".addslashes(clean_string(implode (" ; ",$tit_200a)))."' and niveau_biblio='s' and niveau_hierar='1' and notice_id !='".addslashes($notice_id)."' "; if($isbn_OK) $requete.= "and code = '".addslashes($isbn_OK)."'"; $res=mysql_query($requete,$dbh); if((!isset($force_creation_notice_perio) || !$force_creation_notice_perio) && mysql_num_rows($res)){ $id_perio_garde=0; while (($r=mysql_fetch_object($res)) && !$id_perio_garde) { if(!array_search($r->notice_id,$notices_crees)){ //Si le periodique ne fait pas parti des notices créées (il était déja dans la base) $id_perio_garde=$r->notice_id; } } if($id_perio_garde){ mysql_query("insert into error_log (error_origin, error_text) values ('import_".addslashes(SESSid).".inc', '".$msg[542]." $id_unimarc "." $isbn_OK ".addslashes(clean_string(implode (" ; ",$tit_200a)))."') ",$dbh) ; //Si j'ai déja une notice dans la base avec ce titre et ce code je supprime celle que je suis en train d'importer $perio_traite = new serial($notice_id); $perio_traite->replace($id_perio_garde); $perio_traite->serial_delete(); //Je travail avec le periodique qui était dans la base $notice_id=$id_perio_garde; $notices_crees[$id_unimarc]=$id_perio_garde; } } if($bull){ for($i=0;$i$bull[$i]['t'][0],"date"=>$bull[$i]['d'][0],"mention"=>$bull[$i]['e'][0],"num"=>$bull[$i]['v'][0]); creer_bulletin($notice_id,$bulletin,"",""); } } if($art){ for($i=0;$i$art[$i]['t'][1],"date"=>$art[$i]['d'][0],"mention"=>$art[$i]['e'][0],"num"=>$art[$i]['v'][0]); creer_notice_article(get_valeur_champ9($art[$i]['9'],'id'),$art[$i]['t'][0],get_valeur_champ9($art[$i]['9'],'page'),0,$bulletin,"","",$notice_id); }elseif($art[$i]['0'][0]){ $id=get_valeur_champ9($art[$i]['9'],'id'); $type_lien =get_valeur_champ9($art[$i]['9'],'type_lnk'); $lien=get_valeur_champ9($art[$i]['9'],'lnk'); $rank=get_valeur_champ9($art[$i]['9'],'rank')*1; $page=get_valeur_champ9($art[$i]['9'],'page'); //On enregistre les informations pour créer l'article plus tard $notices_a_creer[$id][] = array( "type_lnk"=> $type_lien, "lnk"=> $lien, "rank"=>$rank, "titre_art"=>$art[$i]['t'][0], "titre"=>$art[$i]['t'][1], "num"=>$art[$i]['v'][0], "mention"=>$art[$i]['e'][0], "date"=>$art[$i]['d'][0], "id_asso"=>$notice_id, "page"=>$page); } } } } /* * Récupère la valeur du champ $9 en fonction du critère */ function get_valeur_champ9($champ9=array(),$crit=''){ $options=array(); $options[$crit]=''; for($i=0;$i $value ) { $id=get_valeur_champ9($value['9'],'id'); $type_lien =get_valeur_champ9($value['9'],'type_lnk'); $lien=get_valeur_champ9($value['9'],'lnk'); $rank=get_valeur_champ9($value['9'],'rank')*1; $id_mere=0; $id_fille=0; $id_notice_liee=0; $ancien_id=get_valeur_champ9($value['9'],'id'); if($notices_crees[$ancien_id]){ //Si la notice lié est créé $id_notice_liee=$notices_crees[$ancien_id]; }elseif($value['0'][0]){ //Le lien sera a creer plus tard $notices_a_creer[$ancien_id][] = array( "type_lnk"=> $type_lien, "lnk"=> $lien, "rank"=>$rank, "id_asso"=>$notice_id); }else{ //Il faut la créer $niveau_bilio=get_valeur_champ9($value['9'],'bl'); switch ( $niveau_bilio ) { case 'm0': $id_notice_liee=creer_notice_monographie($ancien_id,$value['t'][0],$value['y'][0]); break; case 's1': $id_notice_liee=creer_notice_periodique($ancien_id,$value['t'][0],$value['x'][0]); break; case 'a2': $bulletin=array("titre"=>$value['t'][1],"date"=>$value['d'][0],"mention"=>$value['e'][0],"num"=>$value['v'][0]); $id_notice_liee=creer_notice_article($ancien_id,$value['t'][0],"","",$bulletin,$value['t'][2],$value['x'][0],""); break; case 'b2': $bulletin=array("titre"=>$value['t'][1],"date"=>$value['d'][0],"mention"=>$value['e'][0],"num"=>$value['v'][0]); $id_notice_liee=creer_notice_bulletin($ancien_id,$value['t'][0],$bulletin,$value['t'][2],$value['x'][0]); break; } } if($lien == 'child'){ //Si on a un lien mere -> fille $id_mere=$notice_id; $id_fille=$id_notice_liee; }elseif($lien == 'parent'){ //Sinon on a un lien fille -> mere $id_mere=$id_notice_liee; $id_fille=$notice_id; } if($id_mere && $id_fille && ($id_mere != $id_fille)){ //Je créer le lien entre les deux notices $requete="insert into notices_relations(num_notice,linked_notice,relation_type,rank) values ('".$id_fille."','".$id_mere."','".addslashes($type_lien)."','".addslashes($rank)."')"; mysql_query($requete); } } } /* * Créer les notices de monographie */ function creer_notice_monographie($ancien_id=0,$titre="",$code=""){ global $notices_crees,$dbh,$statutnot; global $isbn_dedoublonnage,$isbn_only; if((($isbn_dedoublonnage)&&(!$isbn_only))||(($isbn_dedoublonnage)&&($isbn_only)&&(isISBN($code)))){// Si dédoublonnage sur ISBN activé $requete="SELECT notice_id FROM notices WHERE niveau_biblio='m' and niveau_hierar='0' AND code='".addslashes($code)."' "; $res=mysql_query($requete,$dbh); if($res && (mysql_num_rows($res) == 1)){//J'ai déjà une notice dans la base avec ce code barre $id=mysql_result($res,0,0); $notices_crees[$ancien_id]=$id; return $id; } } $requete="insert into notices (tit1, code, niveau_biblio, niveau_hierar,statut) values ('".addslashes($titre)."','".addslashes($code)."', 'm', '0','".$statutnot."')"; mysql_query($requete,$dbh); $id=mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id); // Mise à jour des index de la notice notice::majNotices($id); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id); $notices_crees[$ancien_id]=$id; return $id; } /* * Créer les notices de periodique */ function creer_notice_periodique($ancien_id=0,$titre="",$code=""){ global $notices_crees,$dbh,$force_creation_notice_perio,$statutnot; //On regarde si il existe if($ancien_id){ if($notices_crees[$ancien_id]){ $id_perio=$notices_crees[$ancien_id]; }else{ $requete="select notice_id from notices where tit1 LIKE '".addslashes(clean_string($titre))."' and niveau_biblio='s' and niveau_hierar='1'"; if($code) $requete.=" and code='".addslashes($code)."'"; $res_perio = mysql_query($requete,$dbh); if ((!isset($force_creation_notice_perio) || !$force_creation_notice_perio) && mysql_num_rows($res_perio)) { $id_perio = mysql_result($res_perio,0,0); }else{ $requete="insert into notices (tit1,code, niveau_biblio, niveau_hierar,statut) values('".addslashes(clean_string($titre))."','".addslashes($code)."', 's', '1','".$statutnot."')"; mysql_query($requete, $dbh); $id_perio = mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_perio); // Mise à jour des index de la notice notice::majNotices($id_perio); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id_perio); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id_perio); } $notices_crees[$ancien_id]=$id_perio; } }else{ $requete="select notice_id from notices where tit1 LIKE '".addslashes(clean_string($titre))."' and niveau_biblio='s' and niveau_hierar='1'"; if($code) $requete.=" and code='".addslashes($code)."'"; $res_perio = mysql_query($requete,$dbh); if ((!isset($force_creation_notice_perio) || !$force_creation_notice_perio) && mysql_num_rows($res_perio)) { $id_perio = mysql_result($res_perio,0,0); }else{ $requete="insert into notices (tit1,code, niveau_biblio, niveau_hierar,statut) values('".addslashes(clean_string($titre))."','".addslashes($code)."', 's', '1','".$statutnot."')"; mysql_query($requete, $dbh); $id_perio = mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_perio); // Mise à jour des index de la notice notice::majNotices($id_perio); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id_perio); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id_perio); } } return $id_perio; } /* * Créer les bulletins * Bulletin est un tableau avec les clés : titre, date, mention, num */ function creer_bulletin($id_perio=0,$bulletin=array(),$titre_perio="",$code_perio=""){ global $bulletins_crees,$dbh; if(!$id_perio){ //Si je n'ai pas d'identifiant de periodique je vais en chercher un ou le créer $id_perio=creer_notice_periodique(0,$titre_perio,$code_perio); } if(!$bulletins_crees[$id_perio][$bulletin["num"]][$bulletin["date"].$bulletin["mention"]]){ //Si il n'est pas déja créé, on regarde si le bulletin est présent dans la base avant de le créer $requete="select bulletin_id from bulletins where bulletin_notice='".addslashes($id_perio)."' and bulletin_numero='".addslashes($bulletin["num"])."' and mention_date='".addslashes($bulletin["mention"])."'"; if($bulletin["date"])$requete.=" and date_date='".addslashes($bulletin["date"])."' "; $res=mysql_query($requete, $dbh); if(mysql_num_rows($res)){ $id_bull = mysql_result($res,0,0); }else{ $requete_bulletin = "insert into bulletins (bulletin_numero, bulletin_notice, mention_date, date_date, bulletin_titre) values ('".addslashes($bulletin["num"])."', '".addslashes($id_perio)."', '".addslashes($bulletin["mention"])."', '".addslashes($bulletin["date"])."', '".addslashes($bulletin["titre"])."')"; mysql_query($requete_bulletin, $dbh); $id_bull = mysql_insert_id(); audit::insert_creation(AUDIT_BULLETIN,$id_bull); } $bulletins_crees[$id_perio][$bulletin["num"]][$bulletin["date"].$bulletin["mention"]] = $id_bull; } else { $id_bull = $bulletins_crees[$id_perio][$bulletin["num"]][$bulletin["date"].$bulletin["mention"]]; } return $id_bull; } /* * Créer les notices d'article * Bulletin est un tableau avec les clés : titre, date, mention, num */ function creer_notice_article($ancien_id=0,$titre_article="",$npage_article="",$id_article=0,$bulletin=array(),$titre_perio="",$code_perio="",$id_perio=0){ global $notices_crees,$dbh,$msg,$statutnot; if($ancien_id){ if($notices_crees[$ancien_id]){ $id_article=$notices_crees[$ancien_id]; }else{ //On va chercher le bulletin if($id_perio){ $id_bulletin=creer_bulletin($id_perio,$bulletin,$titre_perio,$code_perio); }else{ $id_bulletin=creer_bulletin(0,$bulletin,$titre_perio,$code_perio); } //On créer l'article if(!$id_article){ $requete="insert into notices (tit1, npages, niveau_biblio, niveau_hierar,statut) values ('".addslashes(clean_string($titre_article))."','".addslashes($npage_article)."', 'a', '2','".$statutnot."')"; mysql_query($requete,$dbh); $id_article=mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_article); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($id_article); // Mise à jour des index de la notice notice::majNotices($id_article); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id_article); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id_article); } //Je regarde si je n'ai pas un autre article avec ce titre $requete="SELECT old.notice_id,old.tit1 FROM notices new, notices old JOIN analysis ON analysis_notice=old.notice_id WHERE new.notice_id='".addslashes($id_article)."' AND new.notice_id!=old.notice_id AND analysis_bulletin='".addslashes($id_bulletin)."' AND new.tit1=old.tit1 "; $res_doubl=mysql_query($requete); if(mysql_num_rows($res_doubl)){ notice::del_notice($id_article); mysql_query("insert into error_log (error_origin, error_text) values ('import_".addslashes(SESSid).".inc', '".$msg[542]." $id_unimarc "." $isbn_OK ".addslashes(mysql_result($res_doubl,0,1))."') ",$dbh) ; $id_article=mysql_result($res_doubl,0,0);//A voir pr modif }else{ $requete="SELECT notice_id FROM notices WHERE notice_id='".addslashes($id_article)."'"; $res_art=mysql_query($requete); if(mysql_num_rows($res_art)){ //On créer le lien entre le bulletin et l'article $requete="insert into analysis (analysis_bulletin, analysis_notice) values ( '".addslashes($id_bulletin)."', '".addslashes($id_article)."' )"; mysql_query($requete,$dbh); } } $notices_crees[$ancien_id]=$id_article; } }else{ //On va chercher le bulletin if($id_perio){ $id_bulletin=creer_bulletin($id_perio,$bulletin,$titre_perio,$code_perio); }else{ $id_bulletin=creer_bulletin(0,$bulletin,$titre_perio,$code_perio); } //On créer l'article if(!$id_article){ $requete="insert into notices (tit1, npages, niveau_biblio, niveau_hierar,statut) values ('".addslashes(clean_string($titre_article))."','".addslashes($npage_article)."', 'a', '2','".$statutnot."')"; mysql_query($requete,$dbh); $id_article=mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_article); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($id_article); // Mise à jour des index de la notice notice::majNotices($id_article); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id_article); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id_article); } //Je regarde si je n'ai pas un autre article avec ce titre $requete="SELECT old.notice_id,old.tit1 FROM notices new, notices old JOIN analysis ON analysis_notice=old.notice_id WHERE new.notice_id='".addslashes($id_article)."' AND new.notice_id!=old.notice_id AND analysis_bulletin='".addslashes($id_bulletin)."' AND new.tit1=old.tit1 "; $res_doubl=mysql_query($requete); if(mysql_num_rows($res_doubl)){ notice::del_notice($id_article); mysql_query("insert into error_log (error_origin, error_text) values ('import_".addslashes(SESSid).".inc', '".$msg[542]." $id_unimarc "." $isbn_OK ".addslashes(mysql_result($res_doubl,0,1))."') ",$dbh) ; $id_article=mysql_result($res_doubl,0,0);//A voir pr modif }else{ $requete="SELECT notice_id FROM notices WHERE notice_id='".addslashes($id_article)."'"; $res_art=mysql_query($requete); if(mysql_num_rows($res_art)){ //On créer le lien entre le bulletin et l'article $requete="insert into analysis (analysis_bulletin, analysis_notice) values ( '".addslashes($id_bulletin)."', '".addslashes($id_article)."' )"; mysql_query($requete,$dbh); } } } if($id_article && ($bulletin["date"])){ $requete="UPDATE notices SET year='".addslashes(substr($bulletin["date"],0,4))."', date_parution='".addslashes($bulletin["date"])."' WHERE notice_id='".$id_article."'"; mysql_query($requete); } return $id_article; } /* * Créer les notices de bulletin * Bulletin est un tableau avec les clés : titre, date, mention, num */ function creer_notice_bulletin($ancien_id=0,$titre_notice_bulletin="",$bulletin=array(),$titre_perio="",$code_perio=""){ global $notices_crees,$dbh; if($ancien_id){ if($notices_crees[$ancien_id]){ $id_notice_bulletin=$notices_crees[$ancien_id]; }else{ //On va chercher le bulletin $id_perio=creer_notice_periodique(0,$titre_perio,$code_perio); $id_bulletin=creer_bulletin($id_perio,$bulletin,$titre_perio,$code_perio); $id_notice_bulletin= creer_lien_notice_bulletin($ancien_id,$id_perio,$id_bulletin,0,$titre_notice_bulletin,$bulletin); } }else{ //On va chercher le bulletin $id_perio=creer_notice_periodique(0,$titre_perio,$code_perio); $id_bulletin=creer_bulletin($id_perio,$bulletin,$titre_perio,$code_perio); $id_notice_bulletin= creer_lien_notice_bulletin($ancien_id,$id_perio,$id_bulletin,0,$titre_notice_bulletin,$bulletin); } return $id_notice_bulletin; } /* * Faire les liens d'une notice de bulletin */ function creer_lien_notice_bulletin($ancien_id=0,$id_perio=0,$id_bulletin=0,$id_not_bull=0,$titre_not_bull="",$bulletin){ global $dbh, $msg,$isbn_OK,$tit_200a,$notice_id,$notices_crees,$statutnot; //On control que ce bulletin n'a pas déjà une notice $requete="select num_notice from bulletins where bulletin_id='".$id_bulletin."'"; if($id_not_bull)$requete.=" and num_notice!='".$id_not_bull."'"; $res=mysql_query($requete,$dbh); if(mysql_num_rows($res) && mysql_result($res,0,0)){ //Si j'ai déja une notice associé à ce bulletin je la récupère if($id_not_bull){ //Si j'ai aussi un identifiant de notice de bulletin, je supprime le plus récent notice::del_notice($id_not_bull); mysql_query("insert into error_log (error_origin, error_text) values ('import_".addslashes(SESSid).".inc', '".$msg[542]." $id_unimarc "." $isbn_OK ".addslashes(clean_string(implode (" ; ",$tit_200a)))."') ",$dbh) ; $id_notice_bulletin=mysql_result($res,0,0);//A voir pr modif }else{ $id_notice_bulletin= mysql_result($res,0,0); } $notice_id=$id_notice_bulletin; }else{ if($titre_not_bull){ //Si j'ai un titre je créé la notice de bulletin $requete="insert into notices (tit1,niveau_biblio, niveau_hierar,statut) values ('".addslashes(clean_string($titre_not_bull))."', 'b', '2','".$statutnot."')"; mysql_query($requete,$dbh); $id_notice_bulletin=mysql_insert_id(); audit::insert_creation(AUDIT_NOTICE,$id_notice_bulletin); //calcul des droits d'accès s'ils sont activés calc_notice_acces_rights($id_notice_bulletin); // Mise à jour des index de la notice notice::majNotices($id_notice_bulletin); // Mise à jour de la table "notices_global_index" notice::majNoticesGlobalIndex($id_notice_bulletin); // Mise à jour de la table "notices_mots_global_index" notice::majNoticesMotsGlobalIndex($id_notice_bulletin); }else{ $id_notice_bulletin=$id_not_bull; } //On créer le lien entre le bulletin et la notice de bulletin $requete="update bulletins set num_notice='".$id_notice_bulletin."' where bulletin_id='".$id_bulletin."'"; mysql_query($requete,$dbh); } $notices_crees[$ancien_id]=$id_notice_bulletin; //Lien entre la notice de bulletin et la notice de periodique $requete="insert into notices_relations(num_notice,linked_notice,relation_type) values ('".$id_notice_bulletin."','".$id_perio."','b')"; mysql_query($requete); if($id_notice_bulletin && ($bulletin["date"])){ $requete="UPDATE notices SET year='".addslashes(substr($bulletin["date"],0,4))."', date_parution='".addslashes($bulletin["date"])."' WHERE notice_id='".$id_notice_bulletin."'"; mysql_query($requete); } return $id_notice_bulletin; } function keep_authority_infos($authority_number,$type,$origin_authority,$notice_id,$authority_infos=array()){ //on a un numéro d'autorité, on regarde si on l'a déjà rencontré $query = "select id_authority_source,num_authority from authorities_sources where authority_number = '".$authority_number."' and num_origin_authority='".$origin_authority."' and authority_type = '".$type."'"; $result = mysql_query($query); if(mysql_num_rows($result)){ $row = mysql_fetch_object($result); $num_authority = $row->num_authority; $num_authority_source= $row->id_authority_source; // on cherche la préférence... dès fois que... $query = "select id_authority_source, num_authority from authorities_sources where authority_number = '".$authority_number."' and authority_type = '".$type."' and authority_favorite = 1"; $result = mysql_query($query); if(mysql_num_rows($result)){ $row = mysql_fetch_object($result); $num_authority = $row->num_authority; $num_authority_source= $row->id_authority_source; } }else{ // c'est un petit nouveau switch($type){ case "author" : $num_authority = auteur::import($authority_infos); break; case "uniform_title" : $num_authority = titre_uniforme::import($authority_infos); break; case "category" : $num_authority = category::import($authority_infos); break; case "collection" : $num_authority = collection::import($authority_infos); break; case "subcollection" : $num_authority = subcollection::import($authority_infos); break; case "serie" : break; } $query = "insert into authorities_sources set num_authority = '$num_authority', authority_number = '".$authority_number."', authority_type = '$type', num_origin_authority = ".$origin_authority.", import_date = now()"; mysql_query($query); $num_authority_source = mysql_insert_id(); } //certaines autorités sont créés avant la notice... if($notice_id!=0){ $query = "insert into notices_authorities_sources set num_authority_source = ".$num_authority_source.", num_notice = ".$notice_id; mysql_query($query); } return $num_authority; } function calc_notice_acces_rights($id) { global $gestion_acces_active; global $gestion_acces_user_notice; global $gestion_acces_empr_notice; 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->storeUserRights(0, $id); } //traitement des droits acces empr_notice if ($gestion_acces_empr_notice==1) { $dom_2= $ac->setDomain(2); $dom_2->storeUserRights(0, $id); } } }