0; } /* * Log an error, warning, or notice */ function logError(string $level, string $error) : void { global $_SCROTT; $_SCROTT[$level][] = $error; } /* * Get an array of all errors, warnings, or notices */ function getErrors(string $level) : array { global $_SCROTT; return $_SCROTT[$level]; } /* * Set the page object for the current request. */ function setPageObj(obj $obj) : void { global $_SCROTT; $_SCROTT['PAGE_OBJECT'] = $obj; } /* * Get the page object for the current request. */ function getPageObj() : ?obj { global $_SCROTT; return $_SCROTT['PAGE_OBJECT']; } /* * Set the page name string. */ function setPageName(string $name) : void { global $_SCROTT; $_SCROTT['PAGE_NAME'] = $name; } /* * Get the page name string. */ function getPageName() : string { global $_SCROTT; return $_SCROTT['PAGE_NAME']; } /* * Produce a string, but only once. This function is useful * when dealing with some variable collection of markup and * you want to affect only the first one with a modifier. * $state should be initialized to false prior to first call. */ function oneStr(string $str, bool &$state) : string { if ($state) return ""; $state = true; return $str; } /* * Save an uploaded file and impose some constraints on supplied * data. Caller can optionally pass some strings by reference to * be given the supplied file's original name and mime-type. * Maxsize is in bytes. If this function returns false, the * appropriate error will be logged. */ function saveFile(array $file, string $path, int $maxsize, ?array $allowedMime = NULL, ?string &$origName = NULL, ?string &$origMime = NULL) : bool { if ($file['error'] > 0) { if ($file['error'] != UPLOAD_ERR_NO_FILE) logError(ERROR, "An unknown error occurred"); return false; } if ($file['size'] > $maxsize) { logError(ERROR, "File must be no larger than " . $maxsize . " bytes"); return false; } if (is_array($allowedMime) && array_search($file['type'], $allowedMime) === false) { logError(ERROR, "File type is not supported"); return false; } if (!move_uploaded_file($file['tmp_name'], $path)) { logError(ERROR, "Error saving uploaded file"); return false; } $origName = $file['name']; $origMime = $file['type']; return true; } /* * Similar to saveFile, but takes the uploaded file field name, * rather than the array directly. The file is looked up in * $_FILES. If it does not exist, an exception is thrown. */ function saveIfFile(string $file, string $path, int $maxsize, ?array $allowedMime = NULL, ?string &$origName = NULL, ?string &$origMime = NULL) : bool { if (!isset($_FILES[$file])) throw new Exception("Requested file upload, but no data was supplied"); $f = $_FILES[$file]; return saveFile($f, $path, $maxsize, $allowedMime, $origName, $origMime); } ?>