* * @author Christoph Wurst * @author Roeland Jago Douma * * @license GNU AGPL version 3 or any later version * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * 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 * along with this program. If not, see . * */ namespace OCP\Contacts\ContactsMenu; use JsonSerializable; /** * @since 12.0 */ interface IEntry extends JsonSerializable { /** * @since 12.0 * @return string */ public function getFullName(): string; /** * @since 12.0 * @return string[] */ public function getEMailAddresses(): array; /** * @since 12.0 * @return string|null image URI */ public function getAvatar(): ?string; /** * @since 12.0 * @param IAction $action an action to show in the contacts menu */ public function addAction(IAction $action): void; /** * Set the (system) contact's user status * * @since 28.0 * @param string $status * @param string $statusMessage * @param string|null $icon * @return void */ public function setStatus(string $status, ?string $statusMessage = null, ?int $statusMessageTimestamp = null, ?string $icon = null): void; /** * Get an arbitrary property from the contact * * @since 12.0 * @param string $key * @return mixed the value of the property or null */ public function getProperty(string $key); }