diff options
author | z0rglub <z0rglub@piwigo.org> | 2004-08-21 12:52:43 +0000 |
---|---|---|
committer | z0rglub <z0rglub@piwigo.org> | 2004-08-21 12:52:43 +0000 |
commit | d4519a348fb8d4dd4af9704b8b6494b5f2b6260a (patch) | |
tree | a820044d89ad5698b617c78b18b6f5f06846ade5 | |
parent | 5b35869ada1e42e980f753fb7711b4fa51b0502e (diff) |
- add files metadata support : use info for database fields
- distinction between directories synchronization and metadata synchronization
git-svn-id: http://piwigo.org/svn/trunk@486 68402e56-0260-453c-a942-63ccdbb3a9ee
Diffstat (limited to '')
-rw-r--r-- | admin/configuration.php | 47 | ||||
-rw-r--r-- | admin/include/functions_metadata.php | 363 | ||||
-rw-r--r-- | admin/update.php | 289 | ||||
-rw-r--r-- | include/constants.php | 2 | ||||
-rw-r--r-- | install/config.sql | 2 | ||||
-rw-r--r-- | install/phpwebgallery_structure.sql | 1 | ||||
-rw-r--r-- | language/en_UK.iso-8859-1/admin.lang.php | 6 | ||||
-rw-r--r-- | template/default/admin/configuration.tpl | 29 | ||||
-rw-r--r-- | template/default/admin/update.tpl | 9 |
9 files changed, 596 insertions, 152 deletions
diff --git a/admin/configuration.php b/admin/configuration.php index 871784758..1d8356444 100644 --- a/admin/configuration.php +++ b/admin/configuration.php @@ -166,24 +166,38 @@ if ( isset( $_POST['submit'] ) ) array_push( $error, $lang['err_maxheight'] ); }*/ // updating configuraiton if no error found - if ( count( $error ) == 0 ) + if (count($error) == 0) { - $result = mysql_query( "SELECT * FROM ".CONFIG_TABLE ); - while ( $row = mysql_fetch_array( $result ) ) - { - $config_name = $row['param']; - $conf[$config_name] = ( isset($_POST[$config_name]) ) ? $_POST[$config_name] : $row['value']; - if ( isset( $_POST[$config_name] ) ) + $result = mysql_query('SELECT * FROM '.CONFIG_TABLE); + while ($row = mysql_fetch_array($result)) + { + $config_name = $row['param']; + if (isset($_POST[$config_name])) + { + $conf[$config_name] = $_POST[$config_name]; + } + else { - $query = 'UPDATE '.CONFIG_TABLE; - $query.= " SET value = '". str_replace("\'", "''", $conf[$config_name]) ; - $query.= "' WHERE param = '$config_name'"; - mysql_query( $query ); + $conf[$config_name] = $row['value']; + } + + if (isset($_POST[$config_name])) + { + $query = ' +UPDATE '.CONFIG_TABLE.' + SET value = \''. str_replace("\'", "''", $conf[$config_name]).'\' + WHERE param = \''.$config_name.'\' +;'; + mysql_query($query); } } } } +// echo '<pre>'; +// print_r($conf); +// echo '</pre>'; + $access = ($conf['access']=='free')?'ACCESS_FREE':'ACCESS_RESTRICTED'; $log = ($conf['log']=='true')?'HISTORY_YES':'HISTORY_NO'; $mail_notif = ($conf['mail_notification']=='true')?'MAIL_NOTIFICATION_YES':'MAIL_NOTIFICATION_NO'; @@ -194,6 +208,8 @@ $expand = ($conf['auto_expand']=='true')?'EXPAND_TREE_YES':'EXPAND_TREE_NO'; $nb_comments = ($conf['show_nb_comments']=='true')?'NB_COMMENTS_YES':'NB_COMMENTS_NO'; $upload = ($conf['upload_available']=='true')?'UPLOAD_YES':'UPLOAD_NO'; $cookie = ($conf['authorize_cookies']=='true')?'COOKIE_YES':'COOKIE_NO'; +$use_exif = ($conf['use_exif']=='true')?'USE_EXIF_YES':'USE_EXIF_NO'; +$use_iptc = ($conf['use_iptc']=='true')?'USE_IPTC_YES':'USE_IPTC_NO'; //----------------------------------------------------- template initialization $template->set_filenames( array('config'=>'admin/configuration.tpl') ); @@ -226,6 +242,8 @@ $template->assign_vars(array( $nb_comments=>'checked="checked"', $upload=>'checked="checked"', $cookie=>'checked="checked"', + $use_exif=>'checked="checked"', + $use_iptc=>'checked="checked"', 'L_CONFIRM'=>$lang['conf_confirmation'], 'L_CONF_GENERAL'=>$lang['conf_general_title'], @@ -290,9 +308,14 @@ $template->assign_vars(array( 'L_YES'=>$lang['yes'], 'L_NO'=>$lang['no'], 'L_SUBMIT'=>$lang['submit'], + 'L_CONF_METADATA'=>$lang['conf_metadata_title'], + 'L_USE_EXIF'=>$lang['conf_use_exif'], + 'L_USE_EXIF_INFO'=>$lang['conf_use_exif_info'], + 'L_USE_IPTC'=>$lang['conf_use_iptc'], + 'L_USE_IPTC_INFO'=>$lang['conf_use_iptc_info'], 'F_ACTION'=>add_session_id(PHPWG_ROOT_PATH.'admin.php?page=configuration') - )); + )); //-------------------------------------------------------------- errors display if ( sizeof( $error ) != 0 ) diff --git a/admin/include/functions_metadata.php b/admin/include/functions_metadata.php new file mode 100644 index 000000000..9a7d45193 --- /dev/null +++ b/admin/include/functions_metadata.php @@ -0,0 +1,363 @@ +<?php +// +-----------------------------------------------------------------------+ +// | functions_metadata.php | +// +-----------------------------------------------------------------------+ +// | application : PhpWebGallery <http://phpwebgallery.net> | +// | branch : BSF (Best So Far) | +// +-----------------------------------------------------------------------+ +// | file : $RCSfile$ +// | last update : $Date$ +// | last modifier : $Author$ +// | revision : $Revision$ +// +-----------------------------------------------------------------------+ +// | This program is free software; you can redistribute it and/or modify | +// | it under the terms of the GNU General Public License as published by | +// | the Free Software Foundation | +// | | +// | This program is distributed in the hope that it will be useful, but | +// | WITHOUT ANY WARRANTY; without even the implied warranty of | +// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | +// | General Public License for more details. | +// | | +// | You should have received a copy of the GNU General Public License | +// | along with this program; if not, write to the Free Software | +// | Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, | +// | USA. | +// +-----------------------------------------------------------------------+ + +/** + * returns informations from IPTC metadata, mapping is done at the beginning + * of the function + * + * @param string $filename + * @return array + */ +function get_iptc_data($filename) +{ + global $getimagesize_time; + + $map = array( + 'keywords' => '2#025', + 'date_creation' => '2#055', + 'author' => '2#122', + 'name' => '2#085', + 'comment' => '2#120' + ); + $datefields = array('date_creation', 'date_available'); + + $result = array(); + + // Read IPTC data + $iptc = array(); + + $start = get_moment(); + getimagesize($filename, &$imginfo); + $getimagesize_time+= get_moment() - $start; + + if (is_array($imginfo) and isset($imginfo['APP13'])) + { + $iptc = iptcparse($imginfo['APP13']); + if (is_array($iptc)) + { + $rmap = array_flip($map); + foreach (array_keys($rmap) as $iptc_key) + { + if (isset($iptc[$iptc_key][0]) and $value = $iptc[$iptc_key][0]) + { + // strip leading zeros (weird Kodak Scanner software) + while ($value[0] == chr(0)) + { + $value = substr($value, 1); + } + // remove binary nulls + $value = str_replace(chr(0x00), ' ', $value); + + foreach (array_keys($map, $iptc_key) as $pwg_key) + { + if (in_array($pwg_key, $datefields)) + { + if ( preg_match('/(\d{4})(\d{2})(\d{2})/', $value, $matches)) + { + $value = $matches[1].'-'.$matches[2].'-'.$matches[3]; + } + else + { + continue; + } + } + $result[$pwg_key] = $value; + } + } + } + } + } + return $result; +} + +function update_metadata($files) +{ + global $conf; + +// $conf['use_iptc'] = true; +// $conf['use_exif'] = true; + + $inserts = array(); + + foreach ($files as $id => $file) + { + $insert = array(); + $insert['id'] = $id; + $insert['filesize'] = floor(filesize($file)/1024); + + if ($image_size = @getimagesize($file)) + { + $insert['width'] = $image_size[0]; + $insert['height'] = $image_size[1]; + } + + if ($conf['use_exif']) + { + if ($exif = @read_exif_data($file)) + { + if (isset($exif['DateTime'])) + { + preg_match('/^(\d{4}).(\d{2}).(\d{2})/' + ,$exif['DateTime'] + ,$matches); + $insert['date_creation'] = + "'".$matches[1].'-'.$matches[2].'-'.$matches[3]."'"; + } + } + } + + if ($conf['use_iptc']) + { + $iptc = get_iptc_data($file); + foreach (array_keys($iptc) as $key) + { + $insert[$key] = "'".addslashes($iptc[$key])."'"; + } + } + + $insert['date_metadata_update'] = CURRENT_DATE; + + array_push($inserts, $insert); + } + + if (count($inserts) > 0) + { + $dbfields = array( + 'id','filesize','width','height','name','author','comment' + ,'date_creation','keywords','date_metadata_update' + ); + + // depending on the MySQL version, we use the multi table update or N + // update queries + $query = 'SELECT VERSION() AS version;'; + $row = mysql_fetch_array(mysql_query($query)); + if (version_compare($row['version'],'4.0.4') < 0) + { + // MySQL is prior to version 4.0.4, multi table update feature is not + // available + echo 'MySQL is prior to version 4.0.4, multi table update feature is not available<br />'; + foreach ($inserts as $insert) + { + $query = ' +UPDATE '.IMAGES_TABLE.' + SET '; + foreach (array_diff(array_keys($insert),array('id')) as $num => $key) + { + if ($num > 1) + { + $query.= ', '; + } + $query.= $key.' = '.$insert[$key]; + } + $query.= ' + WHERE id = '.$insert['id'].' +;'; + // echo '<pre>'.$query.'</pre>'; + mysql_query($query); + } + } + else + { + // creation of the temporary table + $query = ' +DESCRIBE '.IMAGES_TABLE.' +;'; + $result = mysql_query($query); + $columns = array(); + while ($row = mysql_fetch_array($result)) + { + if (in_array($row['Field'], $dbfields)) + { + $column = $row['Field']; + $column.= ' '.$row['Type']; + if (!isset($row['Null']) or $row['Null'] == '') + { + $column.= ' NOT NULL'; + } + if (isset($row['Default'])) + { + $column.= " default '".$row['Default']."'"; + } + array_push($columns, $column); + } + } + $query = ' +CREATE TEMPORARY TABLE '.IMAGE_METADATA_TABLE.' +( +'.implode(",\n", $columns).', +PRIMARY KEY (id) +) +;'; + // echo '<pre>'.$query.'</pre>'; + mysql_query($query); + // inserts all found pictures + $query = ' +INSERT INTO '.IMAGE_METADATA_TABLE.' + ('.implode(',', $dbfields).') + VALUES + '; + foreach ($inserts as $insert_id => $insert) + { + $query.= ' +'; + if ($insert_id > 0) + { + $query.= ','; + } + $query.= '('; + foreach ($dbfields as $field_id => $dbfield) + { + if ($field_id > 0) + { + $query.= ','; + } + + if (!isset($insert[$dbfield]) or $insert[$dbfield] == '') + { + $query.= 'NULL'; + } + else + { + $query.= $insert[$dbfield]; + } + } + $query.=')'; + } + $query.= ' +;'; + // echo '<pre>'.$query.'</pre>'; + mysql_query($query); + // update of images table by joining with temporary table + $query = ' +UPDATE '.IMAGES_TABLE.' AS images, '.IMAGE_METADATA_TABLE.' as metadata + SET '.implode("\n , ", + array_map( + create_function('$s', 'return "images.$s = metadata.$s";') + , array_diff($dbfields, array('id')))).' + WHERE images.id = metadata.id +;'; + echo '<pre>'.$query.'</pre>'; + mysql_query($query); + } + } +} + +/** + * returns an array associating element id (images.id) with its complete + * path in the filesystem + * + * @param int id_uppercat + * @param boolean recursive ? + * @param boolean only newly added files ? + * @return array + */ +function get_filelist($category_id = '', $recursive = false, $only_new = false) +{ + $files = array(); + + $query = ' +SELECT id, dir + FROM '.CATEGORIES_TABLE.' +;'; + $result = mysql_query($query); + $cat_dirs = array(); + while ($row = mysql_fetch_array($result)) + { + $cat_dirs[$row['id']] = $row['dir']; + } + + // filling $uppercats_array : to each category id the uppercats list is + // associated + $uppercats_array = array(); + + $query = ' +SELECT id, uppercats + FROM '.CATEGORIES_TABLE; + if (is_numeric($category_id)) + { + if ($recursive) + { + $query.= ' + WHERE uppercats REGEXP \'(^|,)'.$category_id.'(,|$)\' +'; + } + else + { + $query.= ' + WHERE id = '.$category_id.' +'; + } + } + $query.= ' +;'; + $result = mysql_query($query); + while ($row = mysql_fetch_array($result)) + { + $uppercats_array[$row['id']] = $row['uppercats']; + } + + $query = ' +SELECT galleries_url + FROM '.SITES_TABLE.' + WHERE id = 1 +'; + $row = mysql_fetch_array(mysql_query($query)); + $basedir = $row['galleries_url']; + + // filling $cat_fulldirs + $cat_fulldirs = array(); + foreach ($uppercats_array as $cat_id => $uppercats) + { + $uppercats = str_replace(',', '/', $uppercats); + $cat_fulldirs[$cat_id] = $basedir.preg_replace('/(\d+)/e', + "\$cat_dirs['$1']", + $uppercats); + } + + $query = ' +SELECT id, file, storage_category_id + FROM '.IMAGES_TABLE.' + WHERE storage_category_id IN ('.implode(',' + ,array_keys($uppercats_array)).')'; + if ($only_new) + { + $query.= ' + AND date_metadata_update IS NULL +'; + } + $query.= ' +;'; + $result = mysql_query($query); + while ($row = mysql_fetch_array($result)) + { + $files[$row['id']] + = $cat_fulldirs[$row['storage_category_id']].'/'.$row['file']; + } + + return $files; +} +?>
\ No newline at end of file diff --git a/admin/update.php b/admin/update.php index ba4f823ac..a99b58e62 100644 --- a/admin/update.php +++ b/admin/update.php @@ -26,33 +26,43 @@ // +-----------------------------------------------------------------------+ include_once( PHPWG_ROOT_PATH.'admin/include/isadmin.inc.php'); + +define('CURRENT_DATE', "'".date('Y-m-d')."'"); //------------------------------------------------------------------- functions -function ordering( $id_uppercat) +/** + * order categories (update categories.rank database field) + * + * the purpose of this function is to give a rank for all categories + * (insides its sub-category), even the newer that have none at te + * beginning. For this, ordering function selects all categories ordered by + * rank ASC then name ASC for each uppercat. + * + * @returns void + */ +function ordering() { - $rank = 1; + $current_rank = 0; + $current_uppercat = ''; - $query = 'SELECT id'; - $query.= ' FROM '.CATEGORIES_TABLE; - if ( !is_numeric( $id_uppercat)) - { - $query.= ' WHERE id_uppercat IS NULL'; - } - else - { - $query.= ' WHERE id_uppercat = '.$id_uppercat; - } - $query.= ' ORDER BY rank ASC, dir ASC'; - $query.= ';'; - $result = mysql_query( $query); - while ( $row = mysql_fetch_array( $result)) + $query = ' +SELECT id, if(id_uppercat is null,\'\',id_uppercat) AS id_uppercat + FROM '.CATEGORIES_TABLE.' + ORDER BY id_uppercat,rank,name +;'; + $result = mysql_query($query); + while ($row = mysql_fetch_array($result)) { - $query = 'UPDATE '.CATEGORIES_TABLE; - $query.= ' SET rank = '.$rank; - $query.= ' WHERE id = '.$row['id']; - $query.= ';'; - mysql_query( $query); - $rank++; - ordering( $row['id']); + if ($row['id_uppercat'] != $current_uppercat) + { + $current_rank = 0; + $current_uppercat = $row['id_uppercat']; + } + $query = ' +UPDATE '.CATEGORIES_TABLE.' + SET rank = '.++$current_rank.' + WHERE id = '.$row['id'].' +;'; + mysql_query($query); } } @@ -110,7 +120,7 @@ SELECT id,dir FROM '.CATEGORIES_TABLE.' } } - $sub_dirs = get_category_directories($cat_directory); + $fs_subdirs = get_category_directories($cat_directory); $sub_category_dirs = array(); $query = ' @@ -136,29 +146,34 @@ SELECT id,dir FROM '.CATEGORIES_TABLE.' } // 3. we have to remove the categories of the database not present anymore + $to_delete_categories = array(); foreach ($sub_category_dirs as $id => $dir) { - if (!in_array($dir, $sub_dirs)) + if (!in_array($dir, $fs_subdirs)) { - delete_category($id); + array_push($to_delete_categories,$id); } } + if (count($to_delete_categories) > 0) + { + delete_categories($to_delete_categories); + } // array of new categories to insert $inserts = array(); - foreach ($sub_dirs as $sub_dir) + foreach ($fs_subdirs as $fs_subdir) { // 5. Is the category already existing ? we create a subcat if not // existing - $category_id = array_search($sub_dir, $sub_category_dirs); + $category_id = array_search($fs_subdir, $sub_category_dirs); if (!is_numeric($category_id)) { - if (preg_match('/^[a-zA-Z0-9-_.]+$/', $sub_dir)) + if (preg_match('/^[a-zA-Z0-9-_.]+$/', $fs_subdir)) { - $name = str_replace('_', ' ', $sub_dir); + $name = str_replace('_', ' ', $fs_subdir); - $value = "('".$sub_dir."','".$name."',1"; + $value = "('".$fs_subdir."','".$name."',1"; if (!is_numeric($id_uppercat)) { $value.= ',NULL'; @@ -173,7 +188,7 @@ SELECT id,dir FROM '.CATEGORIES_TABLE.' } else { - $output.= '<span style="color:red;">"'.$sub_dir.'" : '; + $output.= '<span style="color:red;">"'.$fs_subdir.'" : '; $output.= $lang['update_wrong_dirname'].'</span><br />'; } } @@ -250,7 +265,7 @@ SELECT id function insert_local_element($dir, $category_id) { - global $lang,$conf,$count_new, $count_deleted; + global $lang,$conf,$count_new; $output = ''; @@ -308,8 +323,7 @@ SELECT id,file,tn_ext } $to_delete_elements = array_unique($to_delete_elements); - $count_deleted+= count($to_delete_elements); - if ($count_deleted > 0) + if (count($to_delete_elements) > 0) { delete_elements($to_delete_elements); } @@ -325,27 +339,20 @@ SELECT file FROM '.IMAGES_TABLE.' array_push($registered_elements, $row['file']); } - // validated pictures are picture uploaded by users, validated by an admin - // and not registered (visible) yet - $validated_pictures = array(); + // unvalidated pictures are picture uploaded by users, but not validated + // by an admin (so not registered truly visible yet) $unvalidated_pictures = array(); $query = ' -SELECT file,infos,validated +SELECT file FROM '.WAITING_TABLE.' WHERE storage_category_id = '.$category_id.' + AND validated = \'false\' ;'; $result = mysql_query($query); while ($row = mysql_fetch_array($result)) { - if ($row['validated'] == 'true') - { - $validated_pictures[$row['file']] = $row['infos']; - } - else - { - array_push($unvalidated_pictures, $row['file']); - } + array_push($unvalidated_pictures, $row['file']); } // we only search among the picture present in the filesystem and not @@ -385,64 +392,23 @@ SELECT file,infos,validated // if we found a thumnbnail corresponding to our picture... if ($tn_ext != '') { - $image_size = @getimagesize($dir.$unregistered_element); - // (file, storage_category_id, date_available, tn_ext, filesize, - // width, height, name, author, comment, date_creation, - // representative_ext)' - $value = '('; - $value.= "'".$unregistered_element."'"; - $value.= ','.$category_id; - $value.= ",'".date('Y-m-d')."'"; - $value.= ",'".$tn_ext."'"; - $value.= ','.floor(filesize($dir.$unregistered_element) / 1024); - $value.= ','.$image_size[0]; - $value.= ','.$image_size[1]; - if (isset($validated_pictures[$unregistered_element])) - { - // retrieving infos from the XML description from waiting table - $infos = nl2br($validated_pictures[$unregistered_element]); - - $unixtime = getAttribute($infos, 'date_creation'); - if ($unixtime != '') - { - $date_creation ="'".date('Y-m-d',$unixtime)."'"; - } - else - { - $date_creation = 'NULL'; - } - - $value.= ",'".getAttribute($infos, 'name')."'"; - $value.= ",'".getAttribute($infos, 'author')."'"; - $value.= ",'".getAttribute($infos, 'comment')."'"; - $value.= ','.$date_creation; - - // deleting the waiting element - $query = ' -DELETE FROM '.WAITING_TABLE.' - WHERE file = \''.$unregistered_element.'\' - AND storage_category_id = '.$category_id.' -;'; - mysql_query($query); - } - else - { - $value.= ",'','','',NULL"; - } - $value.= ',NULL'; // representative_ext - $value.= ')'; - + $insert = array(); + $insert['file'] = "'".$unregistered_element."'"; + $insert['storage_category_id'] = $category_id; + $insert['date_available'] = CURRENT_DATE; + $insert['tn_ext'] = "'".$tn_ext."'"; + $count_new++; $output.= $unregistered_element; $output.= ' <span style="font-weight:bold;">'; $output.= $lang['update_research_added'].'</span>'; $output.= ' ('.$lang['update_research_tn_ext'].' '.$tn_ext.')'; $output.= '<br />'; - array_push($inserts, $value); + array_push($inserts, $insert); } else { - $output.= '<span style="color:red;">'; + $output.= '<span style="color:orange;">'; $output.= $lang['update_missing_tn'].' : '.$unregistered_element; $output.= ' (<span style="font-weight:bold;">'; $output.= $conf['prefix_thumbnail']; @@ -470,44 +436,25 @@ DELETE FROM '.WAITING_TABLE.' } } - // (file, storage_category_id, date_available, tn_ext, filesize, - // width, height, name, author, comment, date_creation, - // representative_ext)' - $value = '('; - $value.= "'".$unregistered_element."'"; - $value.= ','.$category_id; - $value.= ",'".date('Y-m-d')."'"; + $insert = array(); + $insert['file'] = "'".$unregistered_element."'"; + $insert['storage_category_id'] = $category_id; + $insert['date_available'] = CURRENT_DATE; if ( $tn_ext != '' ) { - $value.= ",'".$tn_ext."'"; - } - else - { - $value.= ',NULL'; + $insert['tn_ext'] = "'".$tn_ext."'"; } - $value.= ','.floor(filesize($dir.$unregistered_element) / 1024); - $value.= ',NULL'; - $value.= ',NULL'; - $value.= ',NULL'; - $value.= ',NULL'; - $value.= ',NULL'; - $value.= ',NULL'; if ( $representative_ext != '' ) { - $value.= ",'".$representative_ext."'"; - } - else - { - $value.= ',NULL'; + $insert['representative_ext'] = "'".$representative_ext."'"; } - $value.= ')'; $count_new++; $output.= $unregistered_element; $output.= ' <span style="font-weight:bold;">'; $output.= $lang['update_research_added'].'</span>'; $output.= '<br />'; - array_push($inserts, $value); + array_push($inserts, $insert); } } else @@ -520,13 +467,45 @@ DELETE FROM '.WAITING_TABLE.' if (count($inserts) > 0) { // inserts all found pictures + $dbfields = array( + 'file','storage_category_id','date_available','tn_ext' + ,'representative_ext' + ); $query = ' INSERT INTO '.IMAGES_TABLE.' - (file,storage_category_id,date_available,tn_ext,filesize,width,height - ,name,author,comment,date_creation,representative_ext) + ('.implode(',', $dbfields).') VALUES - '.implode(',', $inserts).' + '; + foreach ($inserts as $insert_id => $insert) + { + $query.= ' +'; + if ($insert_id > 0) + { + $query.= ','; + } + $query.= '('; + foreach ($dbfields as $field_id => $dbfield) + { + if ($field_id > 0) + { + $query.= ','; + } + + if (!isset($insert[$dbfield]) or $insert[$dbfield] == '') + { + $query.= 'NULL'; + } + else + { + $query.= $insert[$dbfield]; + } + } + $query.=')'; + } + $query.= ' ;'; + mysql_query($query); // what are the ids of the pictures in the $category_id ? @@ -575,11 +554,11 @@ $template->assign_vars(array( 'L_RESULT_UPDATE'=>$lang['update_part_research'], 'L_NEW_CATEGORY'=>$lang['update_research_conclusion'], 'L_DEL_CATEGORY'=>$lang['update_deletion_conclusion'], + 'L_UPDATE_SYNC_METADATA_QUESTION'=>$lang['update_sync_metadata_question'], 'U_CAT_UPDATE'=>add_session_id(PHPWG_ROOT_PATH.'admin.php?page=update&update=cats'), 'U_ALL_UPDATE'=>add_session_id(PHPWG_ROOT_PATH.'admin.php?page=update&update=all') )); - //-------------------------------------------- introduction : choices of update // Display choice if "update" var is not specified if (!isset($_GET['update'])) @@ -587,7 +566,7 @@ if (!isset($_GET['update'])) $template->assign_block_vars('introduction',array()); } //-------------------------------------------------- local update : ./galleries -else +else if (!isset($_GET['metadata'])) { check_cat_id($_GET['update']); $start = get_moment(); @@ -602,25 +581,63 @@ else { $categories = insert_local_category('NULL'); } - $end = get_moment(); - //echo get_elapsed_time($start, $end).' for update <br />'; + echo get_elapsed_time($start,get_moment()).' for scanning directories<br />'; $template->assign_block_vars('update',array( 'CATEGORIES'=>$categories, 'NEW_CAT'=>$count_new, 'DEL_CAT'=>$count_deleted )); + if ($count_new > 0) + { + $url = PHPWG_ROOT_PATH.'admin.php?page=update&metadata=1'; + if (isset($page['cat'])) + { + $url.= '&update='.$page['cat']; + } + $template->assign_block_vars( + 'update.sync_metadata', + array( + 'U_URL' => add_session_id($url) + )); + } } //---------------------------------------- update informations about categories -if (isset($_GET['update']) - or isset($page['cat']) - or @is_file('./listing.xml') && DEBUG) +if (!isset($_GET['metadata']) + and (isset($_GET['update']) + or isset($page['cat']) + or @is_file('./listing.xml') && DEBUG)) { $start = get_moment(); update_category('all'); - ordering('NULL'); - $end = get_moment(); - echo get_elapsed_time($start, $end).' for update_category(all)<br />'; + echo get_elapsed_time($start,get_moment()).' for update_category(all)<br />'; + $start = get_moment(); + ordering(); + echo get_elapsed_time($start, get_moment()).' for ordering categories<br />'; +} +//---------------------------------------------------- metadata synchronization +if (isset($_GET['metadata'])) +{ + if (isset($_GET['update'])) + { + check_cat_id($_GET['update']); + } + + $start = get_moment(); + // $files = get_filelist(1464); + if (isset($page['cat'])) + { + $files = get_filelist($page['cat'],true,true); + } + else + { + $files = get_filelist('',true,true); + } + echo get_elapsed_time($start, get_moment()).' for get_filelist<br />'; + + $start = get_moment(); + update_metadata($files); + echo get_elapsed_time($start, get_moment()).' for metadata update<br />'; } //----------------------------------------------------------- sending html code $template->assign_var_from_handle('ADMIN_CONTENT', 'update'); -?> +?>
\ No newline at end of file diff --git a/include/constants.php b/include/constants.php index 3ac5816f4..483965a9e 100644 --- a/include/constants.php +++ b/include/constants.php @@ -57,5 +57,5 @@ define('USER_ACCESS_TABLE', $table_prefix.'user_access'); define('USER_GROUP_TABLE', $table_prefix.'user_group'); define('USERS_TABLE', $table_prefix.'users'); define('WAITING_TABLE', $table_prefix.'waiting'); - +define('IMAGE_METADATA_TABLE', $table_prefix.'image_metadata'); ?> diff --git a/install/config.sql b/install/config.sql index f23f29ff6..987c8a4a5 100644 --- a/install/config.sql +++ b/install/config.sql @@ -27,3 +27,5 @@ INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('nb_line_page','3 INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('recent_period','7','Period within which pictures are displayed as new (in days)'); INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('auto_expand','false','Auto expand of the category tree'); INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('show_nb_comments','true','Show the number of comments under the thumbnails'); +INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('use_iptc','false','Use IPTC data during database synchronization with files metadata'); +INSERT INTO phpwebgallery_config (param,value,comment) VALUES ('use_exif','true','Use EXIF data during database synchronization with files metadata'); diff --git a/install/phpwebgallery_structure.sql b/install/phpwebgallery_structure.sql index f2072281b..06ea1cebf 100644 --- a/install/phpwebgallery_structure.sql +++ b/install/phpwebgallery_structure.sql @@ -136,6 +136,7 @@ CREATE TABLE phpwebgallery_images ( keywords varchar(255) default NULL, storage_category_id smallint(5) unsigned default NULL, representative_ext varchar(4) default NULL, + date_metadata_update date default NULL, PRIMARY KEY (id), KEY images_i2 (date_available), KEY images_i1 (storage_category_id) diff --git a/language/en_UK.iso-8859-1/admin.lang.php b/language/en_UK.iso-8859-1/admin.lang.php index e1de65703..5741b5d34 100644 --- a/language/en_UK.iso-8859-1/admin.lang.php +++ b/language/en_UK.iso-8859-1/admin.lang.php @@ -154,6 +154,11 @@ $lang['conf_default_maxwidth_info'] = 'Maximum width for display pictures : pict $lang['conf_default_maxheight_info'] = 'Just as the maximum width, but for the height'; $lang['conf_session_cookie'] = 'Authorize cookies'; $lang['conf_session_cookie_info'] = 'users won\'t have to log on each visit any more. Less secure.'; +$lang['conf_metadata_title'] = 'Files metadata'; +$lang['conf_use_exif'] = 'Use EXIF'; +$lang['conf_use_exif_info'] = 'Use EXIF data during metadata synchronization into PhpWebGallery database'; +$lang['conf_use_iptc'] = 'Use IPTC'; +$lang['conf_use_iptc_info'] = 'Use IPTC data during metadata synchronization into PhpWebGallery database'; //FAQ $lang['help_images_title'] = 'Adding pictures'; @@ -260,6 +265,7 @@ $lang['update_research_conclusion'] = 'pictures added to the database'; $lang['update_default_title'] = 'Choose an option'; $lang['update_only_cat'] = 'update categories, not pictures'; $lang['update_all'] = 'update all'; +$lang['update_sync_metadata_question'] = 'Do you want to synchronize new elements informations with files metadata ?'; $lang['tn_width'] = 'width'; $lang['tn_height'] = 'height'; $lang['tn_no_support'] = 'Picture unreachable or no support'; diff --git a/template/default/admin/configuration.tpl b/template/default/admin/configuration.tpl index 5c1bef87d..b2eb8f22b 100644 --- a/template/default/admin/configuration.tpl +++ b/template/default/admin/configuration.tpl @@ -168,6 +168,35 @@ <td><strong>{L_SESSION_ID_SIZE} :</strong><br /><span class="small">{L_SESSION_ID_SIZE_INFO}</span></td> <td class="row1"><input type="text" size="2" maxlength="3" name="session_id_size" value="{SESSION_ID_SIZE}" /></td> </tr> + <tr> + <td colspan="2"> </td> + </tr> + <tr class="admin"> + <th colspan="2">{L_CONF_METADATA}</th> + </tr> + <tr> + <td colspan="2"> </td> + </tr> + <tr> + <td> + <strong>{L_USE_EXIF} :</strong> + <br /><span class="small">{L_USE_EXIF_INFO}</span> + </td> + <td class="row1"> + <input type="radio" class="radio" name="use_exif" value="true" {USE_EXIF_YES} />{L_YES} + <input type="radio" class="radio" name="use_exif" value="false" {USE_EXIF_NO} />{L_NO} + </td> + </tr> + <tr> + <td> + <strong>{L_USE_IPTC} :</strong> + <br /><span class="small">{L_USE_IPTC_INFO}</span> + </td> + <td class="row1"> + <input type="radio" class="radio" name="use_iptc" value="true" {USE_IPTC_YES} />{L_YES} + <input type="radio" class="radio" name="use_iptc" value="false" {USE_IPTC_NO} />{L_NO} + </td> + </tr> <!-- BEGIN remote_sites --> <tr> <th colspan="2" align="center">{#remote_site}</th> diff --git a/template/default/admin/update.tpl b/template/default/admin/update.tpl index 97ba87963..01cfeaabb 100644 --- a/template/default/admin/update.tpl +++ b/template/default/admin/update.tpl @@ -7,9 +7,12 @@ <!-- END introduction --> <!-- BEGIN update --> <div class="admin">{L_RESULT_UPDATE}</div> - {update.CATEGORIES} - <br /><span style="color:blue;">{update.NEW_CAT} {L_NEW_CATEGORY}</span> - <br /><span style="color:red;">{update.DEL_CAT} {L_DEL_CATEGORY}</span> +<br /><span style="color:#9cb4ce;">{update.NEW_CAT} {L_NEW_CATEGORY}</span> +<br /><span style="color:#ffe1e1;">{update.DEL_CAT} {L_DEL_CATEGORY}</span> +<!-- BEGIN sync_metadata --> +<br />[ <a href="{update.sync_metadata.U_URL}">{L_UPDATE_SYNC_METADATA_QUESTION}</a> ] +<!-- END sync_metadata --> +{update.CATEGORIES} <!-- END update --> <!-- BEGIN remote_update --> <table> |