* * @author Louis Chemineau * * @license AGPL-3.0 * * This code is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License, version 3, * as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License, version 3, * along with this program. If not, see * */ namespace OCA\DAV\Connector\Sabre; class MtimeSanitizer { public static function sanitizeMtime(string $mtimeFromRequest): int { // In PHP 5.X "is_numeric" returns true for strings in hexadecimal // notation. This is no longer the case in PHP 7.X, so this check // ensures that strings with hexadecimal notations fail too in PHP 5.X. $isHexadecimal = preg_match('/^\s*0[xX]/', $mtimeFromRequest); if ($isHexadecimal || !is_numeric($mtimeFromRequest)) { throw new \InvalidArgumentException('X-OC-MTime header must be an integer (unix timestamp).'); } // Prevent writing invalid mtime (timezone-proof) if ((int)$mtimeFromRequest <= 24 * 60 * 60) { throw new \InvalidArgumentException('X-OC-MTime header must be a valid positive integer'); } return (int)$mtimeFromRequest; } }