芝麻web文件管理V1.00
编辑当前文件:/home/mgatv524/www/midiatech/lib/Factory/PlaylistFactory.php
. */ namespace Xibo\Factory; use Xibo\Entity\Playlist; use Xibo\Entity\User; use Xibo\Exception\NotFoundException; use Xibo\Service\ConfigServiceInterface; use Xibo\Service\DateServiceInterface; use Xibo\Service\LogServiceInterface; use Xibo\Service\SanitizerServiceInterface; use Xibo\Storage\StorageServiceInterface; /** * Class PlaylistFactory * @package Xibo\Factory */ class PlaylistFactory extends BaseFactory { /** * @var DateServiceInterface */ public $dateService; /** * @var PermissionFactory */ private $permissionFactory; /** * @var WidgetFactory */ private $widgetFactory; /** @var TagFactory */ private $tagFactory; /** * @var ConfigServiceInterface */ private $config; /** * Construct a factory * @param StorageServiceInterface $store * @param LogServiceInterface $log * @param ConfigServiceInterface $config * @param SanitizerServiceInterface $sanitizerService * @param User $user * @param UserFactory $userFactory * @param DateServiceInterface $date * @param PermissionFactory $permissionFactory * @param WidgetFactory $widgetFactory * @param TagFactory $tagFactory */ public function __construct($store, $log, $config, $sanitizerService, $user, $userFactory, $date, $permissionFactory, $widgetFactory, $tagFactory) { $this->setCommonDependencies($store, $log, $sanitizerService); $this->setAclDependencies($user, $userFactory); $this->config = $config; $this->dateService = $date; $this->permissionFactory = $permissionFactory; $this->widgetFactory = $widgetFactory; $this->tagFactory = $tagFactory; } /** * @return Playlist */ public function createEmpty() { return new Playlist( $this->getStore(), $this->getLog(), $this->config, $this->dateService, $this->permissionFactory, $this, $this->widgetFactory, $this->tagFactory ); } /** * Load Playlists by * @param $regionId * @return Playlist * @throws NotFoundException */ public function getByRegionId($regionId) { $playlists = $this->query(null, array('disableUserCheck' => 1, 'regionId' => $regionId)); if (count($playlists) <= 0) { $this->getLog()->error('Region ' . $regionId . ' does not have a Playlist associated, please try to set a new owner in Permissions.'); throw new NotFoundException(__('One of the Regions on this Layout does not have a Playlist, please contact your administrator.')); } return $playlists[0]; } /** * Get by Id * @param int $playlistId * @return Playlist * @throws NotFoundException */ public function getById($playlistId) { $playlists = $this->query(null, array('disableUserCheck' => 1, 'playlistId' => $playlistId)); if (count($playlists) <= 0) throw new NotFoundException(__('Cannot find playlist')); return $playlists[0]; } /** * Get by OwnerId * @param int $ownerId * @return Playlist[] * @throws NotFoundException */ public function getByOwnerId($ownerId) { return $this->query(null, ['userId' => $ownerId, 'regionSpecific' => 0]); } /** * Create a Playlist * @param string $name * @param int $ownerId * @param int|null $regionId * @return Playlist */ public function create($name, $ownerId, $regionId = null) { $playlist = $this->createEmpty(); $playlist->name = $name; $playlist->ownerId = $ownerId; $playlist->regionId = $regionId; $playlist->isDynamic = 0; $playlist->requiresDurationUpdate = 1; return $playlist; } /** * @param null $sortOrder * @param array $filterBy * @return Playlist[] */ public function query($sortOrder = null, $filterBy = []) { $entries = []; $params = []; $select = ' SELECT `playlist`.playlistId, `playlist`.ownerId, `playlist`.name, `user`.UserName AS owner, `playlist`.regionId, `playlist`.createdDt, `playlist`.modifiedDt, `playlist`.duration, `playlist`.isDynamic, `playlist`.filterMediaName, `playlist`.filterMediaTags, `playlist`.requiresDurationUpdate, `playlist`.enableStat, ( SELECT GROUP_CONCAT(DISTINCT tag) FROM tag INNER JOIN lktagplaylist ON lktagplaylist.tagId = tag.tagId WHERE lktagplaylist.playlistId = playlist.playlistId GROUP BY lktagplaylist.playlistId ) AS tags, ( SELECT GROUP_CONCAT(IFNULL(value, \'NULL\')) FROM tag INNER JOIN lktagplaylist ON lktagplaylist.tagId = tag.tagId WHERE lktagplaylist.playlistId = playlist.playlistId GROUP BY lktagplaylist.playlistId ) AS tagValues, ( SELECT GROUP_CONCAT(DISTINCT `group`.group) FROM `permission` INNER JOIN `permissionentity` ON `permissionentity`.entityId = permission.entityId INNER JOIN `group` ON `group`.groupId = `permission`.groupId WHERE entity = :permissionEntityForGroup AND objectId = playlist.playlistId AND view = 1 ) AS groupsWithPermissions '; $params['permissionEntityForGroup'] = 'Xibo\\Entity\\Playlist'; $body = ' FROM `playlist` LEFT OUTER JOIN `user` ON `user`.userId = `playlist`.ownerId WHERE 1 = 1 '; if ($this->getSanitizer()->getInt('playlistId', $filterBy) !== null) { $body .= ' AND `playlist`.playlistId = :playlistId '; $params['playlistId'] = $this->getSanitizer()->getInt('playlistId', $filterBy); } if ($this->getSanitizer()->getInt('notPlaylistId', $filterBy) !== null) { $body .= ' AND `playlist`.playlistId <> :notPlaylistId '; $params['notPlaylistId'] = $this->getSanitizer()->getInt('notPlaylistId', $filterBy); } if ($this->getSanitizer()->getInt('userId', $filterBy) !== null) { $body .= ' AND `playlist`.ownerId = :ownerId '; $params['ownerId'] = $this->getSanitizer()->getInt('userId', $filterBy); } // User Group filter if ($this->getSanitizer()->getInt('ownerUserGroupId', 0, $filterBy) != 0) { $body .= ' AND `playlist`.ownerId IN (SELECT DISTINCT userId FROM `lkusergroup` WHERE groupId = :ownerUserGroupId) '; $params['ownerUserGroupId'] = $this->getSanitizer()->getInt('ownerUserGroupId', 0, $filterBy); } if ($this->getSanitizer()->getInt('regionId', $filterBy) !== null) { $body .= ' AND `playlist`.regionId = :regionId '; $params['regionId'] = $this->getSanitizer()->getInt('regionId', $filterBy); } if ($this->getSanitizer()->getInt('requiresDurationUpdate', $filterBy) !== null) { // Either 1, or 0 if ($this->getSanitizer()->getInt('requiresDurationUpdate', $filterBy) == 1) { // Not 0 and behind now. $body .= ' AND `playlist`.requiresDurationUpdate <= :requiresDurationUpdate '; $body .= ' AND `playlist`.requiresDurationUpdate <> 0 '; $params['requiresDurationUpdate'] = time(); } else { // Ahead of now means we don't need to update yet, or we are set to 0 and we never update $body .= ' AND (`playlist`.requiresDurationUpdate > :requiresDurationUpdate OR `playlist`.requiresDurationUpdate = 0)'; $params['requiresDurationUpdate'] = time(); } } if ($this->getSanitizer()->getInt('isDynamic', $filterBy) !== null) { $body .= ' AND `playlist`.isDynamic = :isDynamic '; $params['isDynamic'] = $this->getSanitizer()->getInt('isDynamic', $filterBy); } if ($this->getSanitizer()->getInt('childId', $filterBy) !== null) { $body .= ' AND `playlist`.playlistId IN ( SELECT parentId FROM `lkplaylistplaylist` WHERE childId = :childId '; if ($this->getSanitizer()->getInt('depth', $filterBy) !== null) { $body .= ' AND depth = :depth '; $params['depth'] = $this->getSanitizer()->getInt('depth', $filterBy); } $body .= ' ) '; $params['childId'] = $this->getSanitizer()->getInt('childId', $filterBy); } if ($this->getSanitizer()->getInt('regionSpecific', $filterBy) !== null) { if ($this->getSanitizer()->getInt('regionSpecific', $filterBy) === 1) $body .= ' AND `playlist`.regionId IS NOT NULL '; else $body .= ' AND `playlist`.regionId IS NULL '; } // Logged in user view permissions $this->viewPermissionSql('Xibo\Entity\Playlist', $body, $params, 'playlist.playlistId', 'playlist.ownerId', $filterBy); // Playlist Like if ($this->getSanitizer()->getString('name', $filterBy) != '') { $terms = explode(',', $this->getSanitizer()->getString('name', $filterBy)); $this->nameFilter('playlist', 'name', $terms, $body, $params, ($this->getSanitizer()->getCheckbox('useRegexForName', $filterBy) == 1)); } // Playlist exact name if ($this->getSanitizer()->getString('playlistExact', $filterBy) != '') { $body.= " AND playlist.name = :exact "; $params['exact'] = $this->getSanitizer()->getString('playlistExact', $filterBy); } // Not PlaylistId if ($this->getSanitizer()->getInt('notPlaylistId', 0, $filterBy) != 0) { $body .= " AND playlist.playlistId <> :notPlaylistId "; $params['notPlaylistId'] = $this->getSanitizer()->getInt('notPlaylistId', 0, $filterBy); } // Tags if ($this->getSanitizer()->getString('tags', $filterBy) != '') { $tagFilter = $this->getSanitizer()->getString('tags', $filterBy); if (trim($tagFilter) === '--no-tag') { $body .= ' AND `playlist`.playlistID NOT IN ( SELECT `lktagplaylist`.playlistId FROM `tag` INNER JOIN `lktagplaylist` ON `lktagplaylist`.tagId = `tag`.tagId ) '; } else { $operator = $this->getSanitizer()->getCheckbox('exactTags') == 1 ? '=' : 'LIKE'; $body .= " AND `playlist`.playlistID IN ( SELECT lktagplaylist.playlistId FROM tag INNER JOIN lktagplaylist ON lktagplaylist.tagId = tag.tagId "; $tags = explode(',', $tagFilter); $this->tagFilter($tags, $operator, $body, $params); } } // MediaID if ($this->getSanitizer()->getInt('mediaId', $filterBy) !== null) { // TODO: sub-playlists $body .= ' AND `playlist`.playlistId IN ( SELECT DISTINCT `widget`.playlistId FROM `lkwidgetmedia` INNER JOIN `widget` ON `widget`.widgetId = `lkwidgetmedia`.widgetId WHERE `lkwidgetmedia`.mediaId = :mediaId ) '; $params['mediaId'] = $this->getSanitizer()->getInt('mediaId', 0, $filterBy); } // Media Like if ($this->getSanitizer()->getString('mediaLike', $filterBy) !== null) { // TODO: sub-playlists $body .= ' AND `playlist`.playlistId IN ( SELECT DISTINCT `widget`.playlistId FROM `lkwidgetmedia` INNER JOIN `widget` ON `widget`.widgetId = `lkwidgetmedia`.widgetId INNER JOIN `media` ON `lkwidgetmedia`.mediaId = `media`.mediaId WHERE `media`.name LIKE :mediaLike ) '; $params['mediaLike'] = '%' . $this->getSanitizer()->getString('mediaLike', $filterBy) . '%'; } // Sorting? $order = ''; if (is_array($sortOrder)) { $order .= 'ORDER BY ' . implode(',', $sortOrder); } else { $order .= 'ORDER BY `playlist`.name '; } $limit = ''; // Paging if ($filterBy !== null && $this->getSanitizer()->getInt('start', $filterBy) !== null && $this->getSanitizer()->getInt('length', $filterBy) !== null) { $limit = ' LIMIT ' . intval($this->getSanitizer()->getInt('start', $filterBy), 0) . ', ' . $this->getSanitizer()->getInt('length', 10, $filterBy); } $sql = $select . $body . $order . $limit; foreach ($this->getStore()->select($sql, $params) as $row) { $playlist = $this->createEmpty()->hydrate($row, ['intProperties' => ['requiresDurationUpdate', 'isDynamic']]); $entries[] = $playlist; } // Paging if ($limit != '' && count($entries) > 0) { unset($params['permissionEntityForGroup']); $results = $this->getStore()->select('SELECT COUNT(*) AS total ' . $body, $params); $this->_countLast = intval($results[0]['total']); } return $entries; } }