* @author Lukas Reschke * @author Morris Jobke * @author Roeland Jago Douma * @author Thomas Müller * @author Thomas Tanghus * * @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 * */ /** * Public interface of ownCloud for apps to use. * Session interface * */ // use OCP namespace for all classes that are considered public. // This means that they should be used by apps instead of the internal ownCloud classes namespace OCP; use OCP\Session\Exceptions\SessionNotAvailableException; /** * Interface ISession * * wrap PHP's internal session handling into the ISession interface * @since 6.0.0 */ interface ISession { /** * Set a value in the session * * @param string $key * @param mixed $value * @since 6.0.0 */ public function set(string $key, $value); /** * Get a value from the session * * @param string $key * @return mixed should return null if $key does not exist * @since 6.0.0 */ public function get(string $key); /** * Check if a named key exists in the session * * @param string $key * @return bool * @since 6.0.0 */ public function exists(string $key): bool; /** * Remove a $key/$value pair from the session * * @param string $key * @since 6.0.0 */ public function remove(string $key); /** * Reset and recreate the session * @since 6.0.0 */ public function clear(); /** * Close the session and release the lock * @since 7.0.0 */ public function close(); /** * Wrapper around session_regenerate_id * * @param bool $deleteOldSession Whether to delete the old associated session file or not. * @param bool $updateToken Wheater to update the associated auth token * @return void * @since 9.0.0, $updateToken added in 14.0.0 */ public function regenerateId(bool $deleteOldSession = true, bool $updateToken = false); /** * Wrapper around session_id * * @return string * @throws SessionNotAvailableException * @since 9.1.0 */ public function getId(): string; }