* * @copyright Copyright (c) 2016, ownCloud, Inc. * @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 OC\Notification; /** * Interface IManager * * @package OC\Notification * @since 8.2.0 * * DEVELOPER NOTE: * The notification api is experimental only in 8.2.0! Do not start using it, * if you can not prepare an update for the next version afterwards. */ interface IManager extends IApp, INotifier { /** * @param \Closure $service The service must implement IApp, otherwise a * \InvalidArgumentException is thrown later * @return null * @since 8.2.0 */ public function registerApp(\Closure $service); /** * @param \Closure $service The service must implement INotifier, otherwise a * \InvalidArgumentException is thrown later * @param \Closure $info An array with the keys 'id' and 'name' containing * the app id and the app name * @return null * @since 8.2.0 - Parameter $info was added in 9.0.0 */ public function registerNotifier(\Closure $service, \Closure $info); /** * @return array App ID => App Name * @since 9.0.0 */ public function listNotifiers(); /** * @return INotification * @since 8.2.0 */ public function createNotification(); /** * @return bool * @since 8.2.0 */ public function hasNotifiers(); }