* @author Robin Appelman * * @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 OCP; /** * Interface ICacheFactory * * @package OCP * @since 7.0.0 */ interface ICacheFactory{ /** * Get a distributed memory cache instance * * All entries added trough the cache instance will be namespaced by $prefix to prevent collisions between apps * * @param string $prefix * @return \OCP\ICache * @since 7.0.0 * @deprecated 13.0.0 Use either createLocking, createDistributed or createLocal */ public function create($prefix = ''); /** * Check if any memory cache backend is available * * @return bool * @since 7.0.0 */ public function isAvailable(); /** * create a cache instance for storing locks * * @param string $prefix * @return \OCP\IMemcache * @since 13.0.0 */ public function createLocking($prefix = ''); /** * create a distributed cache instance * * @param string $prefix * @return \OCP\ICache * @since 13.0.0 */ public function createDistributed($prefix = ''); /** * create a local cache instance * * @param string $prefix * @return \OCP\ICache * @since 13.0.0 */ public function createLocal($prefix = ''); }