*/ /** * Create a private top level album for new users. * * @package UserAlbum */ class UserAlbumModule extends GalleryModule /* and GalleryEventListener */ { function UserAlbumModule() { global $gallery; $this->setId('useralbum'); $this->setName($gallery->i18n('User Albums')); $this->setDescription($gallery->i18n('Create an album for each new user')); $this->setVersion('1.0.3'); $this->setGroup('gallery', $gallery->i18n('Gallery')); $this->setCallbacks('registerEventListeners|getSiteAdminViews|getSystemLinks'); $this->setRequiredCoreApi(array(7, 0)); $this->setRequiredModuleApi(array(3, 0)); } /** * @see GalleryModule::registerEventListeners() */ function registerEventListeners() { $listener = new UserAlbumModule(); GalleryCoreApi::registerEventListener('GalleryEntity::save', $listener, true); GalleryCoreApi::registerEventListener('GalleryEntity::delete', $listener); GalleryCoreApi::registerEventListener('Gallery::Login', $listener); } /** * @see GalleryModule::upgrade() */ function upgrade($currentVersion) { list ($ret, $params) = GalleryCoreApi::fetchAllPluginParameters('module', 'useralbum'); if ($ret) { return $ret->wrap(__FILE__, __LINE__); } list($ret, $rootId) = GalleryCoreApi::getPluginParameter('module', 'core', 'id.rootAlbum'); if ($ret) { return $ret->wrap(__FILE__, __LINE__); } foreach (array('view' => 'everybody', 'fullSize' => '1', 'targetLocation' => $rootId, 'loginRedirect' => 0, 'homeLink' => 0, 'create' => 'access') as $key => $value) { if (!isset($params[$key])) { $ret = $this->setParameter($key, $value); if ($ret) { return $ret->wrap(__FILE__, __LINE__); } } } return null; } /** * @see GalleryModule::getSiteAdminViews() */ function getSiteAdminViews() { return array(null, array(array('name' => $this->translate('User Albums'), 'view' => 'useralbum.UserAlbumSiteAdmin'))); } /** * @see GalleryModule::getSystemLinks */ function getSystemLinks() { global $gallery; $links = array(); list ($ret, $params) = GalleryCoreApi::fetchAllPluginParameters('module', 'useralbum'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } /* Check if link is enabled */ if (!empty($params['homeLink'])) { $userId = $gallery->getActiveUserId(); list ($ret, $anonymousUserId) = GalleryCoreApi::getPluginParameter('module', 'core', 'id.anonymousUser'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } if ($userId != $anonymousUserId) { list ($ret, $albumId) = GalleryCoreApi::getPluginParameter('module', 'useralbum', 'albumId', $userId); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } if (!empty($albumId) || $params['create'] == 'access') { $links['YourAlbum'] = array('text' => $this->translate('Your Album'), 'params' => empty($albumId) ? array('controller' => 'useralbum.UserAlbum') : array('view' => 'core.ShowItem', 'itemId' => $albumId)); } } } return array(null, $links); } /** * Event handler for GalleryEntity::save, ::delete and Gallery::Login events * Create new top level album with appropriate permissions when a GalleryUser is created * Reset the targetAlbum to root if the target is ever deleted * Remove albumId param if the user's album is deleted * Redirect to user album after login, if enabled in site admin * * @see GalleryEventListener::handleEvent */ function handleEvent($event) { $result = null; switch ($event->getEventName()) { case 'GalleryEntity::save': $user = $event->getEntity(); if (GalleryUtilities::isA($user, 'GalleryUser') && $user->testPersistentFlag(STORAGE_FLAG_NEWLY_CREATED)) { list ($ret, $createMode) = $this->getParameter('create'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } if ($createMode == 'immediate') { GalleryCoreApi::requireOnce( 'modules/useralbum/classes/UserAlbumHelper.class'); $ret = UserAlbumHelper::createUserAlbum($user); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } } } break; case 'GalleryEntity::delete': $entity = $event->getEntity(); /* We don't care unless it's an album */ if (!GalleryUtilities::isA($entity, 'GalleryAlbumItem')) { break; } list ($ret, $targetId) = $this->getParameter('targetLocation'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } if ($entity->getId() == $targetId) { list ($ret, $rootId) = GalleryCoreApi::getPluginParameter('module', 'core', 'id.rootAlbum'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } $ret = $this->setParameter('targetLocation', $rootId); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } } else { /* * Delete the albumid value from the ParameterMap so we don't get * MISSING_OBJECT errors when the user clicks their 'Your Album' link */ $ret = GalleryCoreApi::removePluginParameterByValue('module', 'useralbum', 'albumId', $entity->getId()); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } } break; case 'Gallery::Login': /* Check if redirect is enabled.. */ list ($ret, $loginRedirect) = $this->getParameter('loginRedirect'); if ($ret) { return array($ret->wrap(__FILE__, __LINE__), null); } if (!empty($loginRedirect)) { /* Return a redirect to the user album.. */ $result = array('controller' => 'useralbum.UserAlbum'); } break; } return array(null, $result); } } ?>