* @author Olivier Paroz * * @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 OCP\AppFramework\Utility; /** * Interface ControllerMethodReflector * * Reads and parses annotations from doc comments * * @package OCP\AppFramework\Utility * @since 8.0.0 */ interface IControllerMethodReflector { /** * @param object $object an object or classname * @param string $method the method which we want to inspect * @since 8.0.0 */ public function reflect($object, $method); /** * Inspects the PHPDoc parameters for types * * @param string $parameter the parameter whose type comments should be * parsed * @return string|null type in the type parameters (@param int $something) * would return int or null if not existing * @since 8.0.0 */ public function getType($parameter); /** * @return array the arguments of the method with key => default value * @since 8.0.0 */ public function getParameters(); /** * Check if a method contains an annotation * * @param string $name the name of the annotation * @return bool true if the annotation is found * @since 8.0.0 */ public function hasAnnotation($name); }