getMLText("invalid_request_token"))),getMLText("invalid_request_token")); } if (!isset($_POST["documentid"]) || !is_numeric($_POST["documentid"]) || intval($_POST["documentid"])<1) { UI::exitError(getMLText("document_title", array("documentname" => getMLText("invalid_doc_id"))),getMLText("invalid_doc_id")); } $documentid = $_POST["documentid"]; $document = $dms->getDocument($documentid); if (!is_object($document)) { UI::exitError(getMLText("document_title", array("documentname" => getMLText("invalid_doc_id"))),getMLText("invalid_doc_id")); } if (!$settings->_enableVersionDeletion && !$user->isAdmin()) { UI::exitError(getMLText("document_title", array("documentname" => htmlspecialchars($document->getName()))),getMLText("access_denied")); } if ($document->getAccessMode($user, 'removeVersion') < M_ALL) { UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("access_denied")); } if (!isset($_POST["version"]) || !is_numeric($_POST["version"]) || intval($_POST["version"])<1) { UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_version")); } $version_num = $_POST["version"]; $version = $document->getContentByVersion($version_num); if (!is_object($version)) { UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_version")); } require_once("SeedDMS/Preview.php"); $previewer = new SeedDMS_Preview_Previewer($settings->_cacheDir); $folder = $document->getFolder(); /* Check if there is just one version. In that case remove the document */ if (count($document->getContent())==1) { $previewer->deleteDocumentPreviews($document); $nl = $document->getNotifyList(); $docname = $document->getName(); if (!$document->remove()) { UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("error_occured")); } else { $nexturl = "../out/out.ViewFolder.php?folderid=".$folder->getId(); /* Remove the document from the fulltext index */ if($fulltextservice && ($index = $fulltextservice->Index())) { $lucenesearch = $fulltextservice->Search(); if($hit = $lucenesearch->getDocument($documentid)) { $index->delete($hit->id); $index->commit(); } } if ($notifier){ $subject = "document_deleted_email_subject"; $message = "document_deleted_email_body"; $params = array(); $params['name'] = $docname; $params['folder_path'] = $folder->getFolderPathPlain(); $params['username'] = $user->getFullName(); $params['sitename'] = $settings->_siteName; $params['http_root'] = $settings->_httpRoot; $params['url'] = getBaseUrl().$settings->_httpRoot."out/out.ViewDocument.php?documentid=".$document->getID(); $notifier->toList($user, $nl["users"], $subject, $message, $params, SeedDMS_NotificationService::RECV_NOTIFICATION); foreach ($nl["groups"] as $grp) { $notifier->toGroup($user, $grp, $subject, $message, $params, SeedDMS_NotificationService::RECV_NOTIFICATION); } } } } else { /* Before deleting the content get a list of all users that should * be informed about the removal. */ $emailUserListR = array(); $emailUserListA = array(); $oldowner = $version->getUser(); $emailGroupListR = array(); $emailGroupListA = array(); $status = $version->getReviewStatus(); foreach ($status as $st) { if ($st["status"]==0 && !in_array($st["required"], $emailUserList)) { if($st['type'] == 0) $emailUserListR[] = $st["required"]; else $emailGroupListR[] = $st["required"]; } } $status = $version->getApprovalStatus(); foreach ($status as $st) { if ($st["status"]==0 && !in_array($st["required"], $emailUserList)) { if($st['type'] == 0) $emailUserListA[] = $st["required"]; else $emailGroupListA[] = $st["required"]; } } $previewer->deletePreview($version, $settings->_previewWidthDetail); $previewer->deletePreview($version, $settings->_previewWidthList); /* Check if the version to be delete is the latest version. This is * later used to set the redirect url. */ $islatest = $version->getVersion() == $document->getLatestContent()->getVersion(); if (!$document->removeContent($version)) { UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("error_occured")); } else { if($islatest || count($document->getContent()) == 1) $nexturl = "../out/out.ViewDocument.php?documentid=".$documentid; else $nexturl = "../out/out.ViewDocument.php?documentid=".$documentid."¤ttab=previous"; /* Remove the document from the fulltext index and reindex latest version */ if($fulltextservice && ($index = $fulltextservice->Indexer())) { $lucenesearch = $fulltextservice->Search(); if($hit = $lucenesearch->getDocument($document->getID())) { $index->delete($hit->id); } $version = $document->getLatestContent(); $index->addDocument($fulltextservice->IndexedDocument($document)); $index->commit(); } // Notify affected users. if ($notifier){ $nl=$document->getNotifyList(); $userrecipientsR = array(); foreach ($emailUserListR as $eID) { $eU = $version->getDMS()->getUser($eID); $userrecipientsR[] = $eU; } $grouprecipientsR = array(); foreach ($emailGroupListR as $eID) { $eU = $version->getDMS()->getGroup($eID); $grouprecipientsR[] = $eU; } $userrecipientsA = array(); foreach ($emailUserListA as $eID) { $eU = $version->getDMS()->getUser($eID); $userrecipientsA[] = $eU; } $grouprecipientsA = array(); foreach ($emailGroupListA as $eID) { $eU = $version->getDMS()->getGroup($eID); $grouprecipientsA[] = $eU; } $subject = "version_deleted_email_subject"; $message = "version_deleted_email_body"; $params = array(); $params['name'] = $document->getName(); $params['version'] = $version->getVersion(); $params['folder_path'] = $document->getFolder()->getFolderPathPlain(); $params['username'] = $user->getFullName(); $params['sitename'] = $settings->_siteName; $params['http_root'] = $settings->_httpRoot; $params['url'] = getBaseUrl().$settings->_httpRoot."out/out.ViewDocument.php?documentid=".$document->getID(); $notifier->toIndividual($user, $oldowner, $subject, $message, $params, SeedDMS_NotificationService::RECV_OWNER); $notifier->toList($user, $userrecipientsR, $subject, $message, $params, SeedDMS_NotificationService::RECV_REVIEWER); $notifier->toList($user, $userrecipientsA, $subject, $message, $params, SeedDMS_NotificationService::RECV_APPROVER); $notifier->toList($user, $nl["users"], $subject, $message, $params, SeedDMS_NotificationService::RECV_NOTIFICATION); foreach($grouprecipientsR as $grp) { $notifier->toGroup($user, $grp, $subject, $message, $params, SeedDMS_NotificationService::RECV_REVIEWER); } foreach($grouprecipientsA as $grp) { $notifier->toGroup($user, $grp, $subject, $message, $params, SeedDMS_NotificationService::RECV_APPROVER); } foreach ($nl["groups"] as $grp) { $notifier->toGroup($user, $grp, $subject, $message, $params, SeedDMS_NotificationService::RECV_NOTIFICATION); } } } } add_log_line("?documentid=".$documentid."&version".$version_num); header("Location:".$nexturl);