*/ /** * This ItemAddOption uses the EXIF description value for the * gallery item summary/description when the image is uploaded. * * @package Exif * @subpackage UserInterface */ class ExifDescriptionOption extends ItemAddOption { /** * @see ItemAddOption::isAppropriate */ function isAppropriate() { list ($ret, $addOption) = GalleryCoreApi::getPluginParameter('module', 'exif', 'addOption'); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } return array(GalleryStatus::success(), $addOption > 0); } /** * @see ItemAddOption::handleRequestAfterAdd */ function handleRequestAfterAdd($form, &$item) { GalleryCoreApi::requireOnce(dirname(__FILE__) . '/classes/ExifExtractor.class'); GalleryCoreApi::requireOnce(dirname(__FILE__) . '/classes/ExifHelper.class'); $itemId = $item->getId(); list ($ret, $exifData) = ExifExtractor::getMetaData(array($itemId), array('ImageDescription')); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } if (!empty($exifData[$itemId]['ImageDescription']['value'])) { $exifDescription = $exifData[$itemId]['ImageDescription']['value']; list ($ret, $addOption) = GalleryCoreApi::getPluginParameter('module', 'exif', 'addOption'); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } list ($ret, $lockId) = GalleryCoreApi::acquireWriteLock($itemId); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } if ($addOption & EXIF_ITEM_SUMMARY) { $item->setSummary($exifDescription); } if ($addOption & EXIF_ITEM_DESCRIPTION) { $item->setDescription($exifDescription); } $ret = $item->save(); if ($ret->isError()) { GalleryCoreApi::releaseLocks($lockId); return array($ret->wrap(__FILE__, __LINE__), null); } $ret = GalleryCoreApi::releaseLocks($lockId); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } } return array(GalleryStatus::success(), array(), array()); } } ?>