*/ /** * This controller handles rewriting URLs from Gallery1 to the new style Gallery2 locations * * @package Migrate * @subpackage Redirect */ class RedirectController extends GalleryController { /** * @see GalleryController::handleRequest() */ function handleRequest($form) { GalleryCoreApi::requireOnce(dirname(__FILE__) . '/classes/G1MigrateHelper.class'); global $gallery; list($file, $full, $page) = GalleryUtilities::getRequestVariables('file', 'full', 'page'); $path = preg_split('|/|', $file, -1, PREG_SPLIT_NO_EMPTY); $view = 'core:ShowItem'; if (count($path) > 1) { // Check for direct link to image file (name.type, name.thumb.type, name.sized.type) $file = explode('.', $path[1]); switch (count($file)) { case 3: if ($file[1] == 'sized') { $derivative = DERIVATIVE_TYPE_IMAGE_RESIZE; } else if ($file[1] == 'thumb') { $derivative = DERIVATIVE_TYPE_IMAGE_THUMBNAIL; } case 2: $view = 'core:DownloadItem'; $path[1] = $file[0]; if (!isset($derivative)) { $derivative = DERIVATIVE_TYPE_IMAGE_PREFERRED; } } list ($ret, $id) = G1MigrateHelper::fetchMapping($path[0], $path[1]); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } if (isset($id) && isset($derivative)) { switch ($derivative) { case DERIVATIVE_TYPE_IMAGE_PREFERRED: list ($ret, $data) = GalleryCoreApi::fetchPreferredsByItemIds(array($id)); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } break; case DERIVATIVE_TYPE_IMAGE_RESIZE: list ($ret, $data) = GalleryCoreApi::fetchResizesByItemIds(array($id)); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } break; case DERIVATIVE_TYPE_IMAGE_THUMBNAIL: list ($ret, $data) = GalleryCoreApi::fetchThumbnailsByItemIds(array($id)); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } break; } if (!empty($data)) { $item = $data[$id]; if (is_array($item)) { $item = array_shift($item); } $id = $item->getId(); } } } else { list ($ret, $id) = G1MigrateHelper::fetchMapping($path[0]); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } } /* Redirect browser */ $scriptName = GalleryUtilities::getServerVar('SCRIPT_NAME'); $results = array('redirect' => array('href' => GalleryUrlGenerator::makeUrl($scriptName), 'view' => $view), 'status' => array(), 'error' => array()); if (isset($id)) { $results['redirect']['itemId'] = $id; if (!empty($full)) { $results['redirect']['imageViewsIndex'] = 1; } if (!empty($page)) { $results['redirect']['page'] = $page; } } return array(GalleryStatus::success(), $results); } } /** * View returns .htaccess file */ class RedirectView extends GalleryView { /** * @see GalleryView::loadTemplate */ function loadTemplate(&$template, &$form) { global $gallery; $ret = GalleryCoreApi::assertUserIsSiteAdministrator(); if ($ret->isError()) { return array($ret->wrap(__FILE__, __LINE__), null); } $urlGenerator =& $gallery->getUrlGenerator(); $urlComponents = parse_url($urlGenerator->getCurrentUrl()); $template->setVariable('uriBase', $urlComponents['path']); header('Content-type: text/plain'); return array(GalleryStatus::success(), array('html' => 'modules/migrate/templates/Htaccess.tpl')); } } ?>