Project import generated by Copybara.
GitOrigin-RevId: 63746295f1a5ab5a619056791995793d65529e62
diff --git a/src/doaddincident.php b/src/doaddincident.php
new file mode 100644
index 0000000..645a9f9
--- /dev/null
+++ b/src/doaddincident.php
@@ -0,0 +1,65 @@
+<?php
+require_once("core.php");
+security::checkType(security::WORKER);
+
+$url = (security::isAllowed(security::ADMIN) ? "incidents.php" : "userincidents.php?id=".(int)$_SESSION["id"]);
+
+if (!security::checkParams("POST", [
+ ["type", security::PARAM_ISINT],
+ ["worker", security::PARAM_ISINT],
+ ["day", security::PARAM_ISDATE]
+])) {
+ security::go(visual::getContinueUrl($url, "empty", "POST"));
+}
+
+$type = (int)$_POST["type"];
+$worker = (int)$_POST["worker"];
+$day = $_POST["day"];
+$details = ((isset($_POST["details"]) && is_string($_POST["details"])) ? $_POST["details"] : "");
+
+if (isset($_POST["allday"]) && $_POST["allday"] == 1) {
+ $begins = incidents::STARTOFDAY;
+ $ends = incidents::ENDOFDAY;
+} else {
+ if (!security::checkParams("POST", [
+ ["begins", security::PARAM_ISTIME],
+ ["ends", security::PARAM_ISTIME]
+ ])) {
+ security::go(visual::getContinueUrl($url, "empty", "POST"));
+ }
+
+ $begins = schedules::time2sec($_POST["begins"]);
+ $ends = schedules::time2sec($_POST["ends"]);
+}
+
+$verified = ((isset($_POST["autoverify"]) && $_POST["autoverify"] == 1 && security::isAllowed(security::ADMIN)) ? 1 : 0);
+$isAdminView = security::isAdminView();
+
+$incidentPerson = people::workerData("id", $worker);
+
+$status = incidents::add($worker, $type, $details, $day, $begins, $ends, "ME", $verified, false, !$isAdminView, true, ($incidentPerson == people::userData("id")));
+
+switch ($status) {
+ case 0:
+ security::go(visual::getContinueUrl($url, "added", "POST"));
+ break;
+
+ case 2:
+ security::go(visual::getContinueUrl($url, "overlap", "POST"));
+ break;
+
+ case 3:
+ security::go(visual::getContinueUrl($url, "order", "POST"));
+ break;
+
+ case 4:
+ security::go(visual::getContinueUrl($url, "addedemailnotsent", "POST"));
+ break;
+
+ case 5:
+ security::go(visual::getContinueUrl($url, "addednotautovalidated", "POST"));
+ break;
+
+ default:
+ security::go(visual::getContinueUrl($url, "unexpected", "POST"));
+}