芝麻web文件管理V1.00
编辑当前文件:/home/mgatv524/public_html/shimoda/lib/Controller/DisplayGroup.php
. */ namespace Xibo\Controller; use Xibo\Entity\Display; use Xibo\Exception\AccessDeniedException; use Xibo\Exception\ConfigurationException; use Xibo\Exception\InvalidArgumentException; use Xibo\Exception\XiboException; use Xibo\Factory\CommandFactory; use Xibo\Factory\DisplayFactory; use Xibo\Factory\DisplayGroupFactory; use Xibo\Factory\LayoutFactory; use Xibo\Factory\MediaFactory; use Xibo\Factory\ModuleFactory; use Xibo\Factory\ScheduleFactory; use Xibo\Factory\TagFactory; use Xibo\Service\ConfigServiceInterface; use Xibo\Service\DateServiceInterface; use Xibo\Service\LogServiceInterface; use Xibo\Service\PlayerActionServiceInterface; use Xibo\Service\SanitizerServiceInterface; use Xibo\XMR\ChangeLayoutAction; use Xibo\XMR\CollectNowAction; use Xibo\XMR\CommandAction; use Xibo\XMR\OverlayLayoutAction; use Xibo\XMR\RevertToSchedule; /** * Class DisplayGroup * @package Xibo\Controller */ class DisplayGroup extends Base { /** * @var PlayerActionServiceInterface */ private $playerAction; /** * @var DisplayGroupFactory */ private $displayGroupFactory; /** * @var DisplayFactory */ private $displayFactory; /** * @var ModuleFactory */ private $moduleFactory; /** * @var MediaFactory */ private $mediaFactory; /** * @var LayoutFactory */ private $layoutFactory; /** * @var CommandFactory */ private $commandFactory; /** * @var ScheduleFactory */ private $scheduleFactory; /** * @var TagFactory */ private $tagFactory; /** * Set common dependencies. * @param LogServiceInterface $log * @param SanitizerServiceInterface $sanitizerService * @param \Xibo\Helper\ApplicationState $state * @param \Xibo\Entity\User $user * @param \Xibo\Service\HelpServiceInterface $help * @param DateServiceInterface $date * @param ConfigServiceInterface $config * @param PlayerActionServiceInterface $playerAction * @param DisplayFactory $displayFactory * @param DisplayGroupFactory $displayGroupFactory * @param LayoutFactory $layoutFactory * @param ModuleFactory $moduleFactory * @param MediaFactory $mediaFactory * @param CommandFactory $commandFactory * @param ScheduleFactory $scheduleFactory * @param TagFactory $tagFactory */ public function __construct($log, $sanitizerService, $state, $user, $help, $date, $config, $playerAction, $displayFactory, $displayGroupFactory, $layoutFactory, $moduleFactory, $mediaFactory, $commandFactory, $scheduleFactory, $tagFactory) { $this->setCommonDependencies($log, $sanitizerService, $state, $user, $help, $date, $config); $this->playerAction = $playerAction; $this->displayFactory = $displayFactory; $this->displayGroupFactory = $displayGroupFactory; $this->layoutFactory = $layoutFactory; $this->moduleFactory = $moduleFactory; $this->mediaFactory = $mediaFactory; $this->commandFactory = $commandFactory; $this->scheduleFactory = $scheduleFactory; $this->tagFactory = $tagFactory; } /** * Display Group Page Render */ public function displayPage() { $this->getState()->template = 'displaygroup-page'; $this->getState()->setData([ 'displays' => $this->displayFactory->query() ]); } /** * @SWG\Get( * path="/displaygroup", * summary="Get Display Groups", * tags={"displayGroup"}, * operationId="displayGroupSearch", * @SWG\Parameter( * name="displayGroupId", * in="formData", * description="Filter by DisplayGroup Id", * type="integer", * required=false * ), * @SWG\Parameter( * name="displayGroup", * in="formData", * description="Filter by DisplayGroup Name", * type="string", * required=false * ), * @SWG\Parameter( * name="displayId", * in="formData", * description="Filter by DisplayGroups containing a specific display", * type="integer", * required=false * ), * @SWG\Parameter( * name="nestedDisplayId", * in="formData", * description="Filter by DisplayGroups containing a specific display in there nesting", * type="integer", * required=false * ), * @SWG\Parameter( * name="dynamicCriteria", * in="formData", * description="Filter by DisplayGroups containing a specific dynamic criteria", * type="string", * required=false * ), * @SWG\Response( * response=200, * description="a successful response", * @SWG\Schema( * type="array", * @SWG\Items(ref="#/definitions/DisplayGroup") * ), * @SWG\Header( * header="X-Total-Count", * description="The total number of records", * type="integer" * ) * ) * ) */ public function grid() { $filter = [ 'displayGroupId' => $this->getSanitizer()->getInt('displayGroupId'), 'displayGroup' => $this->getSanitizer()->getString('displayGroup'), 'displayId' => $this->getSanitizer()->getInt('displayId'), 'nestedDisplayId' => $this->getSanitizer()->getInt('nestedDisplayId'), 'dynamicCriteria' => $this->getSanitizer()->getString('dynamicCriteria'), 'tags' => $this->getSanitizer()->getString('tags'), 'exactTags' => $this->getSanitizer()->getCheckbox('exactTags') ]; $displayGroups = $this->displayGroupFactory->query($this->gridRenderSort(), $this->gridRenderFilter($filter)); foreach ($displayGroups as $group) { /* @var \Xibo\Entity\DisplayGroup $group */ if ($this->isApi()) continue; $group->includeProperty('buttons'); if ($this->getUser()->checkEditable($group)) { // Show the edit button, members button if ($group->isDynamic == 0) { // Group Members $group->buttons[] = array( 'id' => 'displaygroup_button_group_members', 'url' => $this->urlFor('displayGroup.members.form', ['id' => $group->displayGroupId]), 'text' => __('Members') ); $group->buttons[] = ['divider' => true]; } // Edit $group->buttons[] = array( 'id' => 'displaygroup_button_edit', 'url' => $this->urlFor('displayGroup.edit.form', ['id' => $group->displayGroupId]), 'text' => __('Edit') ); } if ($this->getUser()->checkDeleteable($group)) { // Show the delete button $group->buttons[] = array( 'id' => 'displaygroup_button_delete', 'url' => $this->urlFor('displayGroup.delete.form', ['id' => $group->displayGroupId]), 'text' => __('Delete') ); } $group->buttons[] = ['divider' => true]; if ($this->getUser()->checkEditable($group)) { // File Associations $group->buttons[] = array( 'id' => 'displaygroup_button_fileassociations', 'url' => $this->urlFor('displayGroup.media.form', ['id' => $group->displayGroupId]), 'text' => __('Assign Files') ); // Layout Assignments $group->buttons[] = array( 'id' => 'displaygroup_button_layout_associations', 'url' => $this->urlFor('displayGroup.layout.form', ['id' => $group->displayGroupId]), 'text' => __('Assign Layouts') ); } if ($this->getUser()->checkPermissionsModifyable($group)) { // Show the modify permissions button $group->buttons[] = array( 'id' => 'displaygroup_button_permissions', 'url' => $this->urlFor('user.permissions.form', ['entity' => 'DisplayGroup', 'id' => $group->displayGroupId]), 'text' => __('Permissions') ); // Version Information $group->buttons[] = array( 'id' => 'display_button_version_instructions', 'url' => $this->urlFor('displayGroup.version.form', ['id' => $group->displayGroupId]), 'text' => __('Version Information') ); } if ($this->getUser()->checkEditable($group)) { $group->buttons[] = ['divider' => true]; $group->buttons[] = array( 'id' => 'displaygroup_button_command', 'url' => $this->urlFor('displayGroup.command.form', ['id' => $group->displayGroupId]), 'text' => __('Send Command') ); $group->buttons[] = array( 'id' => 'displaygroup_button_collectNow', 'url' => $this->urlFor('displayGroup.collectNow.form', ['id' => $group->displayGroupId]), 'text' => __('Collect Now') ); } } $this->getState()->template = 'grid'; $this->getState()->recordsTotal = $this->displayGroupFactory->countLast(); $this->getState()->setData($displayGroups); } /** * Shows an add form for a display group */ public function addForm() { $this->getState()->template = 'displaygroup-form-add'; $this->getState()->setData([ 'help' => $this->getHelp()->link('DisplayGroup', 'Add') ]); } /** * Shows an edit form for a display group * @param int $displayGroupId */ public function editForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->getState()->template = 'displaygroup-form-edit'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'help' => $this->getHelp()->link('DisplayGroup', 'Edit') ]); } /** * Shows the Delete Group Form * @param int $displayGroupId */ function deleteForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkDeleteable($displayGroup)) throw new AccessDeniedException(); $this->getState()->template = 'displaygroup-form-delete'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'help' => $this->getHelp()->link('DisplayGroup', 'Delete') ]); } /** * Display Group Members form * @param int $displayGroupId */ public function membersForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Displays in Group $displaysAssigned = $this->displayFactory->getByDisplayGroupId($displayGroup->displayGroupId); // Get all the DisplayGroups assigned to this Group directly $groupsAssigned = $this->displayGroupFactory->getByParentId($displayGroup->displayGroupId); $this->getState()->template = 'displaygroup-form-members'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'extra' => [ 'displaysAssigned' => $displaysAssigned, 'displayGroupsAssigned' => $groupsAssigned ], 'tree' => $this->displayGroupFactory->getRelationShipTree($displayGroupId), 'help' => $this->getHelp()->link('DisplayGroup', 'Members') ]); } /** * Adds a Display Group * @SWG\Post( * path="/displaygroup", * operationId="displayGroupAdd", * tags={"displayGroup"}, * summary="Add a Display Group", * description="Add a new Display Group to the CMS", * @SWG\Parameter( * name="displayGroup", * in="formData", * description="The Display Group Name", * type="string", * required=true * ), * @SWG\Parameter( * name="description", * in="formData", * description="The Display Group Description", * type="string", * required=false * ), * @SWG\Parameter( * name="tags", * in="formData", * description="A comma separated list of tags for this item", * type="string", * required=false * ), * @SWG\Parameter( * name="isDynamic", * in="formData", * description="Flag indicating whether this DisplayGroup is Dynamic", * type="integer", * required=true * ), * @SWG\Parameter( * name="dynamicContent", * in="formData", * description="The filter criteria for this dynamic group. A command separated set of regular expressions to apply", * type="string", * required=false * ), * @SWG\Response( * response=201, * description="successful operation", * @SWG\Schema(ref="#/definitions/DisplayGroup"), * @SWG\Header( * header="Location", * description="Location of the new DisplayGroup", * type="string" * ) * ) * ) */ public function add() { $displayGroup = $this->displayGroupFactory->createEmpty(); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->displayGroup = $this->getSanitizer()->getString('displayGroup'); $displayGroup->description = $this->getSanitizer()->getString('description'); $displayGroup->tags = $this->tagFactory->tagsFromString($this->getSanitizer()->getString('tags')); $displayGroup->isDynamic = $this->getSanitizer()->getCheckbox('isDynamic'); $displayGroup->dynamicCriteria = $this->getSanitizer()->getString('dynamicCriteria'); $displayGroup->userId = $this->getUser()->userId; $displayGroup->save(); // Return $this->getState()->hydrate([ 'httpState' => 201, 'message' => sprintf(__('Added %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId, 'data' => $displayGroup ]); } /** * Edits a Display Group * @param int $displayGroupId * * @SWG\Put( * path="/displaygroup/{displayGroupId}", * operationId="displayGroupEdit", * tags={"displayGroup"}, * summary="Edit a Display Group", * description="Edit an existing Display Group identified by its Id", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The displayGroupId to edit.", * required=true * ), * @SWG\Parameter( * name="displayGroup", * in="formData", * description="The Display Group Name", * type="string", * required=true * ), * @SWG\Parameter( * name="description", * in="formData", * description="The Display Group Description", * type="string", * required=false * ), * @SWG\Parameter( * name="tags", * in="formData", * description="A comma separated list of tags for this item", * type="string", * required=false * ), * @SWG\Parameter( * name="isDynamic", * in="formData", * description="Flag indicating whether this DisplayGroup is Dynamic", * type="integer", * required=true * ), * @SWG\Parameter( * name="dynamicCriteria", * in="formData", * description="The filter criteria for this dynamic group. A command separated set of regular expressions to apply", * type="string", * required=false * ), * @SWG\Response( * response=200, * description="successful operation", * @SWG\Schema(ref="#/definitions/DisplayGroup") * ) * ) */ public function edit($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->displayGroup = $this->getSanitizer()->getString('displayGroup'); $displayGroup->description = $this->getSanitizer()->getString('description'); $displayGroup->replaceTags($this->tagFactory->tagsFromString($this->getSanitizer()->getString('tags'))); $displayGroup->isDynamic = $this->getSanitizer()->getCheckbox('isDynamic'); $displayGroup->dynamicCriteria = ($displayGroup->isDynamic == 1) ? $this->getSanitizer()->getString('dynamicCriteria') : null; $displayGroup->save(); // Return $this->getState()->hydrate([ 'message' => sprintf(__('Edited %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId, 'data' => $displayGroup ]); } /** * Deletes a Group * @param int $displayGroupId * * @SWG\Delete( * path="/displaygroup/{displayGroupId}", * operationId="displayGroupDelete", * tags={"displayGroup"}, * summary="Delete a Display Group", * description="Delete an existing Display Group identified by its Id", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The displayGroupId to delete", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) */ function delete($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkDeleteable($displayGroup)) throw new AccessDeniedException(); $displayGroup->delete(); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Deleted %s'), $displayGroup->displayGroup) ]); } /** * Sets the Members of a group * @param int $displayGroupId * @throws InvalidArgumentException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/display/assign", * operationId="displayGroupDisplayAssign", * tags={"displayGroup"}, * summary="Assign one or more Displays to a Display Group", * description="Adds the provided Displays to the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to assign to", * required=true * ), * @SWG\Parameter( * name="displayId", * type="array", * in="formData", * description="The Display Ids to assign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Parameter( * name="unassignDisplayId", * in="formData", * description="An optional array of Display IDs to unassign", * type="array", * required=false, * @SWG\Items(type="integer") * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function assignDisplay($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if ($displayGroup->isDisplaySpecific == 1) throw new InvalidArgumentException(__('This is a Display specific Display Group and its assignments cannot be modified.'), 'displayGroupId'); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); if ($displayGroup->isDynamic == 1) throw new \InvalidArgumentException(__('Displays cannot be manually assigned to a Dynamic Group')); $modifiedDisplays = []; $displays = $this->getSanitizer()->getIntArray('displayId'); foreach ($displays as $displayId) { $display = $this->displayFactory->getById($displayId); if (!$this->getUser()->checkViewable($this->displayGroupFactory->getById($display->displayGroupId))) throw new AccessDeniedException(__('Access Denied to Display')); $displayGroup->assignDisplay($display); // Store so that we can flag as incomplete if (!in_array($display, $modifiedDisplays)) $modifiedDisplays[] = $display; } // Have we been provided with unassign id's as well? $displays = $this->getSanitizer()->getIntArray('unassignDisplayId'); foreach ($displays as $displayId) { $display = $this->displayFactory->getById($displayId); if (!$this->getUser()->checkViewable($this->displayGroupFactory->getById($display->displayGroupId))) throw new AccessDeniedException(__('Access Denied to Display')); $displayGroup->unassignDisplay($display); // Store so that we can flag as incomplete if (!in_array($display, $modifiedDisplays)) $modifiedDisplays[] = $display; } // Save the result $displayGroup->save(['validate' => false]); // Save the displays themselves foreach ($modifiedDisplays as $display) { /** @var Display $display */ $display->notify(); } // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Displays assigned to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Unassign displays from a Display Group * @param int $displayGroupId * @throws InvalidArgumentException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/display/unassign", * operationId="displayGroupDisplayUnassign", * tags={"displayGroup"}, * summary="Unassigns one or more Displays to a Display Group", * description="Removes the provided Displays from the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to unassign from", * required=true * ), * @SWG\Parameter( * name="displayId", * type="array", * in="formData", * description="The Display Ids to unassign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function unassignDisplay($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if ($displayGroup->isDisplaySpecific == 1) throw new InvalidArgumentException(__('This is a Display specific Display Group and its assignments cannot be modified.'), 'displayGroupId'); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); if ($displayGroup->isDynamic == 1) throw new \InvalidArgumentException(__('Displays cannot be manually unassigned to a Dynamic Group')); $displays = $this->getSanitizer()->getIntArray('displayId'); foreach ($displays as $displayId) { $display = $this->displayFactory->getById($displayId); if (!$this->getUser()->checkViewable($this->displayGroupFactory->getById($display->displayGroupId))) throw new AccessDeniedException(__('Access Denied to Display')); $this->getLog()->debug('Unassigning ' . $display->display); $displayGroup->unassignDisplay($display); } $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Displays unassigned from %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Sets the Members of a group * @param int $displayGroupId * @throws InvalidArgumentException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/displayGroup/assign", * operationId="displayGroupDisplayGroupAssign", * tags={"displayGroup"}, * summary="Assign one or more DisplayGroups to a Display Group", * description="Adds the provided DisplayGroups to the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to assign to", * required=true * ), * @SWG\Parameter( * name="displayGroupId", * type="array", * in="formData", * description="The displayGroup Ids to assign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Parameter( * name="unassignDisplayGroupId", * in="formData", * description="An optional array of displayGroup IDs to unassign", * type="array", * required=false, * @SWG\Items(type="integer") * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function assignDisplayGroup($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if ($displayGroup->isDisplaySpecific == 1) throw new InvalidArgumentException(__('This is a Display specific Display Group and its assignments cannot be modified.'), 'displayGroupId'); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); if ($displayGroup->isDynamic == 1) throw new \InvalidArgumentException(__('DisplayGroups cannot be manually assigned to a Dynamic Group')); $displayGroups = $this->getSanitizer()->getIntArray('displayGroupId'); foreach ($displayGroups as $assignDisplayGroupId) { $displayGroupAssign = $this->displayGroupFactory->getById($assignDisplayGroupId); if (!$this->getUser()->checkViewable($displayGroupAssign)) throw new AccessDeniedException(__('Access Denied to DisplayGroup')); $displayGroup->assignDisplayGroup($displayGroupAssign); } // Have we been provided with unassign id's as well? $displayGroups = $this->getSanitizer()->getIntArray('unassignDisplayGroupId'); foreach ($displayGroups as $assignDisplayGroupId) { $displayGroupUnassign = $this->displayGroupFactory->getById($assignDisplayGroupId); if (!$this->getUser()->checkViewable($displayGroupUnassign)) throw new AccessDeniedException(__('Access Denied to DisplayGroup')); $displayGroup->unassignDisplayGroup($displayGroupUnassign); } // Save the result $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('DisplayGroups assigned to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Unassign DisplayGroups from a Display Group * @param int $displayGroupId * @throws InvalidArgumentException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/displayGroup/unassign", * operationId="displayGroupDisplayGroupUnassign", * tags={"displayGroup"}, * summary="Unassigns one or more DisplayGroups to a Display Group", * description="Removes the provided DisplayGroups from the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to unassign from", * required=true * ), * @SWG\Parameter( * name="displayGroupId", * type="array", * in="formData", * description="The DisplayGroup Ids to unassign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function unassignDisplayGroup($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if ($displayGroup->isDisplaySpecific == 1) throw new InvalidArgumentException(__('This is a Display specific Display Group and its assignments cannot be modified.'), 'displayGroupId'); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); if ($displayGroup->isDynamic == 1) throw new \InvalidArgumentException(__('DisplayGroups cannot be manually unassigned to a Dynamic Group')); $displayGroups = $this->getSanitizer()->getIntArray('displayGroupId'); foreach ($displayGroups as $assignDisplayGroupId) { $displayGroup->unassignDisplayGroup($this->displayGroupFactory->getById($assignDisplayGroupId)); } $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('DisplayGroups unassigned from %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Media Form (media linked to displays) * @param int $displayGroupId * @throws XiboException */ public function mediaForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $this->getState()->template = 'displaygroup-form-media'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'modules' => $this->moduleFactory->query(null, ['regionSpecific' => 0]), 'media' => $this->mediaFactory->getByDisplayGroupId($displayGroup->displayGroupId), 'help' => $this->getHelp()->link('DisplayGroup', 'FileAssociations') ]); } /** * Assign Media * @param int $displayGroupId * * @SWG\Post( * path="/displaygroup/{displayGroupId}/media/assign", * operationId="displayGroupMediaAssign", * tags={"displayGroup"}, * summary="Assign one or more Media items to a Display Group", * description="Adds the provided Media to the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to assign to", * required=true * ), * @SWG\Parameter( * name="mediaId", * type="array", * in="formData", * description="The Media Ids to assign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Parameter( * name="unassignMediaId", * type="array", * in="formData", * description="Optional array of Media Id to unassign", * required=false, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function assignMedia($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $mediaIds = $this->getSanitizer()->getIntArray('mediaId'); // Loop through all the media foreach ($mediaIds as $mediaId) { $media = $this->mediaFactory->getById($mediaId); if (!$this->getUser()->checkViewable($media)) throw new AccessDeniedException(__('You have selected media that you no longer have permission to use. Please reload the form.')); $displayGroup->assignMedia($media); } // Check for unassign foreach ($this->getSanitizer()->getIntArray('unassignMediaId') as $mediaId) { // Get the media record $media = $this->mediaFactory->getById($mediaId); if (!$this->getUser()->checkViewable($media)) throw new AccessDeniedException(__('You have selected media that you no longer have permission to use. Please reload the form.')); $displayGroup->unassignMedia($media); } $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Files assigned to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Unassign Media * @param int $displayGroupId * * @SWG\Post( * path="/displaygroup/{displayGroupId}/media/unassign", * operationId="displayGroupMediaUnassign", * tags={"displayGroup"}, * summary="Unassign one or more Media items from a Display Group", * description="Removes the provided from the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to unassign from", * required=true * ), * @SWG\Parameter( * name="mediaId", * type="array", * in="formData", * description="The Media Ids to unassign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function unassignMedia($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $mediaIds = $this->getSanitizer()->getIntArray('mediaId'); // Loop through all the media foreach ($mediaIds as $mediaId) { $displayGroup->unassignMedia($this->mediaFactory->getById($mediaId)); } $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Files unassigned from %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Layouts Form (layouts linked to displays) * @param int $displayGroupId * * @throws XiboException */ public function LayoutsForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $this->getState()->template = 'displaygroup-form-layouts'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'modules' => $this->moduleFactory->query(null, ['regionSpecific' => 0]), 'layouts' => $this->layoutFactory->getByDisplayGroupId($displayGroup->displayGroupId), 'help' => $this->getHelp()->link('DisplayGroup', 'FileAssociations') ]); } /** * Assign Layouts * @param int $displayGroupId * * @SWG\Post( * path="/displaygroup/{displayGroupId}/layout/assign", * operationId="displayGroupLayoutsAssign", * tags={"displayGroup"}, * summary="Assign one or more Layouts items to a Display Group", * description="Adds the provided Layouts to the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to assign to", * required=true * ), * @SWG\Parameter( * name="layoutId", * type="array", * in="formData", * description="The Layouts Ids to assign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Parameter( * name="unassignLayoutId", * type="array", * in="formData", * description="Optional array of Layouts Id to unassign", * required=false, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function assignLayouts($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $layoutIds = $this->getSanitizer()->getIntArray('layoutId'); // Loop through all the media foreach ($layoutIds as $layoutId) { $layout = $this->layoutFactory->getById($layoutId); if (!$this->getUser()->checkViewable($layout)) throw new AccessDeniedException(__('You have selected a layout that you no longer have permission to use. Please reload the form.')); $displayGroup->assignLayout($layout); } // Check for unassign foreach ($this->getSanitizer()->getIntArray('unassignLayoutId') as $layoutId) { // Get the layout record $layout = $this->layoutFactory->getById($layoutId); if (!$this->getUser()->checkViewable($layout)) throw new AccessDeniedException(__('You have selected a layout that you no longer have permission to use. Please reload the form.')); $displayGroup->unassignLayout($layout); } $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Layouts assigned to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Unassign Layout * @param int $displayGroupId * * @SWG\Post( * path="/displaygroup/{displayGroupId}/layout/unassign", * operationId="displayGroupLayoutUnassign", * tags={"displayGroup"}, * summary="Unassign one or more Layout items from a Display Group", * description="Removes the provided from the Display Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group to unassign from", * required=true * ), * @SWG\Parameter( * name="layoutId", * type="array", * in="formData", * description="The Layout Ids to unassign", * required=true, * @SWG\Items( * type="integer" * ) * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function unassignLayouts($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Load the groups details $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $layoutIds = $this->getSanitizer()->getIntArray('layoutId'); // Loop through all the media foreach ($layoutIds as $layoutId) { $this->getLog()->debug('Unassign layoutId ' . $layoutId . ' from ' . $displayGroupId); $displayGroup->unassignLayout($this->layoutFactory->getById($layoutId)); } $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Layouts unassigned from %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Version Form * @param int $displayGroupId */ public function versionForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // List of effected displays $displays = $this->displayFactory->getByDisplayGroupId($displayGroupId); // Possible media files to assign $media = $this->mediaFactory->query(['name'], ['type' => 'genericfile']); $this->getState()->template = 'displaygroup-form-version'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'displays' => $displays, 'media' => $media, 'help' => $this->getHelp()->link('DisplayGroup', 'Version') ]); } /** * Version Update * @param int $displayGroupId * * @SWG\Post( * path="/displaygroup/{displayGroupId}/version", * operationId="displayGroupDisplayVersion", * tags={"displayGroup"}, * summary="Set the Version for this Display", * description="Sets the version instructions on all Displays in the Group", * @SWG\Parameter( * name="displayGroupId", * type="integer", * in="path", * description="The Display Group ID", * required=true * ), * @SWG\Parameter( * name="mediaId", * type="integer", * in="formData", * description="The Media Id of the Installer File", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function version($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $media = $this->mediaFactory->getById($this->getSanitizer()->getInt('mediaId')); if (!$this->getUser()->checkViewable($media)) throw new AccessDeniedException(); // Assign the media file $displayGroup->assignMedia($media); $displayGroup->setCollectRequired(true); // Update each display in the group with the new version foreach ($this->displayFactory->getByDisplayGroupId($displayGroupId) as $display) { /* @var Display $display */ $display->versionInstructions = json_encode(['id' => $media->mediaId, 'file' => $media->storedAs]); $display->save(['validate' => false]); } // Save the group (for the file assignment) $displayGroup->save(['manageDisplayLinks' => false]); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Version set for %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * @param int $displayGroupId */ public function collectNowForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->getState()->template = 'displaygroup-form-collect-now'; $this->getState()->setData([ 'displayGroup' => $displayGroup ]); } /** * Cause the player to collect now * @param int $displayGroupId * @throws ConfigurationException when the message cannot be sent * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/collectNow", * operationId="displayGroupActionCollectNow", * tags={"displayGroup"}, * summary="Action: Collect Now", * description="Send the collect now action to this DisplayGroup", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The display group id", * type="integer", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) */ public function collectNow($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->playerAction->sendAction($this->displayFactory->getByDisplayGroupId($displayGroupId), new CollectNowAction()); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Cause the player to collect now * @param int $displayGroupId * @throws ConfigurationException when the message cannot be sent * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/clearStatsAndLogs", * operationId="displayGroupActionClearStatsAndLogs", * tags={"displayGroup"}, * summary="Action: Clear Stats and Logs", * description="Clear all stats and logs on this Group", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The display group id", * type="integer", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) */ public function clearStatsAndLogs($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->playerAction->sendAction($this->displayFactory->getByDisplayGroupId($displayGroupId), new CollectNowAction()); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Change to a new Layout * @param $displayGroupId * @throws ConfigurationException * @throws \Xibo\Exception\NotFoundException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/changeLayout", * operationId="displayGroupActionChangeLayout", * tags={"displayGroup"}, * summary="Action: Change Layout", * description="Send the change layout action to this DisplayGroup", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The Display Group Id", * type="integer", * required=true * ), * @SWG\Parameter( * name="layoutId", * in="formData", * description="The Layout Id", * type="integer", * required=true * ), * @SWG\Parameter( * name="duration", * in="formData", * description="The duration in seconds for this Layout change to remain in effect", * type="integer", * required=false * ), * @SWG\Parameter( * name="downloadRequired", * in="formData", * description="Flag indicating whether the player should perform a collect before playing the Layout", * type="integer", * required=false * ), * @SWG\Parameter( * name="changeMode", * in="formData", * description="Whether to queue or replace with this action", * type="string", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function changeLayout($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Get the layoutId $layoutId = $this->getSanitizer()->getInt('layoutId'); $downloadRequired = ($this->getSanitizer()->getCheckbox('downloadRequired') == 1); if ($layoutId == 0) throw new \InvalidArgumentException(__('Please provide a Layout')); // Check that this user has permissions to see this layout $layout = $this->layoutFactory->getById($layoutId); if (!$this->getUser()->checkViewable($layout)) throw new AccessDeniedException(); // Check to see if this layout is assigned to this display group. if (count($this->layoutFactory->query(null, ['disableUserCheck' => 1, 'layoutId' => $layoutId, 'displayGroupId' => $displayGroupId])) <= 0) { // Assign $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $displayGroup->assignLayout($layout); // Don't collect now, this player action will cause a download. // notify will still occur if the layout isn't already assigned (which is shouldn't be) $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Convert into a download required $downloadRequired = true; } else { // The layout may not be built at this point if ($downloadRequired) { // in this case we should build it and notify before we send the action // notify should NOT collect now, as we will do that during our own action. $layout->xlfToDisk(['notify' => true, 'collectNow' => false]); } } // Create and send the player action $this->playerAction->sendAction($this->displayFactory->getByDisplayGroupId($displayGroupId), (new ChangeLayoutAction())->setLayoutDetails( $layoutId, $this->getSanitizer()->getInt('duration'), $downloadRequired, $this->getSanitizer()->getString('changeMode', 'queue') )); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Cause the player to revert to its scheduled content * @param int $displayGroupId * @throws ConfigurationException when the message cannot be sent * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/revertToSchedule", * operationId="displayGroupActionRevertToSchedule", * tags={"displayGroup"}, * summary="Action: Revert to Schedule", * description="Send the revert to schedule action to this DisplayGroup", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The display group id", * type="integer", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) */ public function revertToSchedule($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->playerAction->sendAction($this->displayFactory->getByDisplayGroupId($displayGroupId), new RevertToSchedule()); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Add an Overlay Layout * @param $displayGroupId * @throws ConfigurationException * @throws \Xibo\Exception\NotFoundException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/overlayLayout", * operationId="displayGroupActionOverlayLayout", * tags={"displayGroup"}, * summary="Action: Overlay Layout", * description="Send the overlay layout action to this DisplayGroup", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The Display Group Id", * type="integer", * required=true * ), * @SWG\Parameter( * name="layoutId", * in="formData", * description="The Layout Id", * type="integer", * required=true * ), * @SWG\Parameter( * name="duration", * in="formData", * description="The duration in seconds for this Overlay to remain in effect", * type="integer", * required=false * ), * @SWG\Parameter( * name="downloadRequired", * in="formData", * description="Flag indicating whether the player should perform a collect before adding the Overlay", * type="integer", * required=false * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) * * @throws XiboException */ public function overlayLayout($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); // Get the layoutId $layoutId = $this->getSanitizer()->getInt('layoutId'); $downloadRequired = ($this->getSanitizer()->getCheckbox('downloadRequired') == 1); if ($layoutId == 0) throw new \InvalidArgumentException(__('Please provide a Layout')); // Check that this user has permissions to see this layout $layout = $this->layoutFactory->getById($layoutId); if (!$this->getUser()->checkViewable($layout)) throw new AccessDeniedException(); // Check to see if this layout is assigned to this display group. if (count($this->layoutFactory->query(null, ['disableUserCheck' => 1, 'layoutId' => $layoutId, 'displayGroupId' => $displayGroupId])) <= 0) { // Assign $displayGroup->setChildObjectDependencies($this->displayFactory, $this->layoutFactory, $this->mediaFactory, $this->scheduleFactory); $displayGroup->load(); $displayGroup->assignLayout($layout); // Don't notify, this player action will cause a download. $displayGroup->setCollectRequired(false); $displayGroup->save(['validate' => false]); // Convert into a download required $downloadRequired = true; } else { // The layout may not be built at this point if ($downloadRequired) { // in this case we should build it and notify before we send the action // notify should NOT collect now, as we will do that during our own action. $layout->xlfToDisk(['notify' => true, 'collectNow' => false]); } } $this->playerAction->sendAction($this->displayFactory->getByDisplayGroupId($displayGroupId), (new OverlayLayoutAction())->setLayoutDetails( $layoutId, $this->getSanitizer()->getInt('duration'), $downloadRequired )); // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } /** * Command Form * @param int $displayGroupId * @throws \Xibo\Exception\NotFoundException */ public function commandForm($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $this->getState()->template = 'displaygroup-form-command'; $this->getState()->setData([ 'displayGroup' => $displayGroup, 'commands' => $this->commandFactory->query() ]); } /** * @param $displayGroupId * @throws ConfigurationException * @throws \Xibo\Exception\NotFoundException * * @SWG\Post( * path="/displaygroup/{displayGroupId}/action/command", * operationId="displayGroupActionCommand", * tags={"displayGroup"}, * summary="Send Command", * description="Send a predefined command to this Group of Displays", * @SWG\Parameter( * name="displayGroupId", * in="path", * description="The display group id", * type="integer", * required=true * ), * @SWG\Parameter( * name="commandId", * in="formData", * description="The Command Id", * type="integer", * required=true * ), * @SWG\Response( * response=204, * description="successful operation" * ) * ) */ public function command($displayGroupId) { $displayGroup = $this->displayGroupFactory->getById($displayGroupId); if (!$this->getUser()->checkEditable($displayGroup)) throw new AccessDeniedException(); $command = $this->commandFactory->getById($this->getSanitizer()->getInt('commandId')); $displays = $this->displayFactory->getByDisplayGroupId($displayGroupId); $this->playerAction->sendAction($displays, (new CommandAction())->setCommandCode($command->code)); // Update the flag foreach ($displays as $display) { /* @var \Xibo\Entity\Display $display */ $display->lastCommandSuccess = 0; $display->save(['validate' => false, 'audit' => false]); } // Return $this->getState()->hydrate([ 'httpStatus' => 204, 'message' => sprintf(__('Command Sent to %s'), $displayGroup->displayGroup), 'id' => $displayGroup->displayGroupId ]); } }