$dms, 'user'=>$user)); /* Check if the form data comes from a trusted request */ if(!checkFormKey('removefolder')) { UI::exitError(getMLText("folder_title", array("foldername" => getMLText("invalid_request_token"))),getMLText("invalid_request_token")); } if (!isset($_POST["folderid"]) || !is_numeric($_POST["folderid"]) || intval($_POST["folderid"])<1) { UI::exitError(getMLText("folder_title", array("foldername" => getMLText("invalid_folder_id"))),getMLText("invalid_folder_id")); } $folderid = $_POST["folderid"]; $folder = $dms->getFolder($folderid); if (!is_object($folder)) { UI::exitError(getMLText("folder_title", array("foldername" => getMLText("invalid_folder_id"))),getMLText("invalid_folder_id")); } if ($folderid == $settings->_rootFolderID || !$folder->getParent()) { UI::exitError(getMLText("folder_title", array("foldername" => $folder->getName())),getMLText("cannot_rm_root")); } if ($folder->getAccessMode($user, 'removeFolder') < M_ALL) { UI::exitError(getMLText("folder_title", array("foldername" => $folder->getName())),getMLText("access_denied")); } /* function removePreviews($arr, $document) { $previewer = $arr[0]; $previewer->deleteDocumentPreviews($document); return null; } require_once("vendor/seeddms/preview/Preview.php"); $previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir); $dms->addCallback('onPreRemoveDocument', 'removePreviews', array($previewer)); */ /* Get the notify list before removing the folder * Also inform the users/groups of the parent folder */ $parent=$folder->getParent(); $foldername = $folder->getName(); $fnl = $folder->getNotifyList(); $pnl = $parent->getNotifyList(); $nl = array( 'users'=>array_unique(array_merge($fnl['users'], $pnl['users']), SORT_REGULAR), 'groups'=>array_unique(array_merge($fnl['groups'], $pnl['groups']), SORT_REGULAR) ); $controller->setParam('folder', $folder); $controller->setParam('fulltextservice', $fulltextservice); if(!$controller()) { UI::exitError(getMLText("folder_title", array("foldername" => htmlspecialchars($foldername))),getMLText("error_remove_folder")); } if ($notifier) { $notifier->sendDeleteFolderMail($folder, $user); } $session->setSplashMsg(array('type'=>'success', 'msg'=>getMLText('splash_rm_folder'))); add_log_line("?folderid=".$folderid."&name=".$foldername); header("Location:../out/out.ViewFolder.php?folderid=".$parent->getID()."&showtree=".$_POST["showtree"]); ?>