aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorz0rglub <z0rglub@piwigo.org>2004-08-21 12:52:43 +0000
committerz0rglub <z0rglub@piwigo.org>2004-08-21 12:52:43 +0000
commitd4519a348fb8d4dd4af9704b8b6494b5f2b6260a (patch)
treea820044d89ad5698b617c78b18b6f5f06846ade5
parent5b35869ada1e42e980f753fb7711b4fa51b0502e (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.php47
-rw-r--r--admin/include/functions_metadata.php363
-rw-r--r--admin/update.php289
-rw-r--r--include/constants.php2
-rw-r--r--install/config.sql2
-rw-r--r--install/phpwebgallery_structure.sql1
-rw-r--r--language/en_UK.iso-8859-1/admin.lang.php6
-rw-r--r--template/default/admin/configuration.tpl29
-rw-r--r--template/default/admin/update.tpl9
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&amp;update=cats'),
'U_ALL_UPDATE'=>add_session_id(PHPWG_ROOT_PATH.'admin.php?page=update&amp;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&amp;metadata=1';
+ if (isset($page['cat']))
+ {
+ $url.= '&amp;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}&nbsp;:</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">&nbsp;</td>
+ </tr>
+ <tr class="admin">
+ <th colspan="2">{L_CONF_METADATA}</th>
+ </tr>
+ <tr>
+ <td colspan="2">&nbsp;</td>
+ </tr>
+ <tr>
+ <td>
+ <strong>{L_USE_EXIF}&nbsp;:</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}&nbsp;&nbsp;
+ <input type="radio" class="radio" name="use_exif" value="false" {USE_EXIF_NO} />{L_NO}
+ </td>
+ </tr>
+ <tr>
+ <td>
+ <strong>{L_USE_IPTC}&nbsp;:</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}&nbsp;&nbsp;
+ <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>