diff --git a/op/op.OverrideContentStatus.php b/op/op.OverrideContentStatus.php index 7c49e02f7..eecd90073 100644 --- a/op/op.OverrideContentStatus.php +++ b/op/op.OverrideContentStatus.php @@ -1,76 +1,77 @@ - 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")); -} - +include("../inc/inc.Utils.php"); +include("../inc/inc.Language.php"); +include("../inc/inc.ClassUI.php"); +include("../inc/inc.Authentication.php"); + +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 ($document->getAccessMode($user) < M_ALL) { - UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("access_denied")); -} - + 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")); + UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_version")); } - -$version = $_POST["version"]; + +$version = $_POST["version"]; $content = $document->getContentByVersion($version); - -if (!is_object($content)) { - UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_version")); + +if (!is_object($content)) { + UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_version")); } - -if (!isset($_POST["overrideStatus"]) || !is_numeric($_POST["overrideStatus"]) || + +if (!isset($_POST["overrideStatus"]) || !is_numeric($_POST["overrideStatus"]) || (intval($_POST["overrideStatus"])<-3 && intval($_POST["overrideStatus"])>2)) { - UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_status")); + UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("invalid_status")); } - + $overallStatus = $content->getStatus(); // status change control -if ($overallStatus["status"] == S_REJECTED || $overallStatus["status"] == S_EXPIRED || $overallStatus["status"] == S_DRAFT_REV || $overallStatus["status"] == S_DRAFT_APP ) { - UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("cannot_change_final_states")); +if ($overallStatus["status"] == S_REJECTED || $overallStatus["status"] == S_EXPIRED || $overallStatus["status"] == S_DRAFT_REV || $overallStatus["status"] == S_DRAFT_APP || $overallStatus["status"] == S_IN_WORKFLOW) { + UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("cannot_change_final_states")); } - -$reviewStatus = $content->getReviewStatus(); -$approvalStatus = $content->getApprovalStatus(); -$overrideStatus = $_POST["overrideStatus"]; -$comment = $_POST["comment"]; - + +$reviewStatus = $content->getReviewStatus(); +$approvalStatus = $content->getApprovalStatus(); +$overrideStatus = $_POST["overrideStatus"]; +$comment = $_POST["comment"]; + if ($overrideStatus != $overallStatus["status"]) { if (!$content->setStatus($overrideStatus, $comment, $user)) { - UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("error_occured")); + UI::exitError(getMLText("document_title", array("documentname" => $document->getName())),getMLText("error_occured")); } else { $nl=$document->getNotifyList(); // Send notification to subscribers. @@ -96,8 +97,8 @@ if ($overrideStatus != $overallStatus["status"]) { // TODO: if user os not owner send notification to owner } -} +} add_log_line("?documentid=".$documentid); header("Location:../out/out.DocumentVersionDetail.php?documentid=".$documentid."&version=".$version); - -?> + +?>