12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394 |
- <?php
- declare(strict_types=1);
- /*
- * @copyright 2023 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @author 2023 Christoph Wurst <christoph@winzerhof-wurst.at>
- *
- * @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 <http://www.gnu.org/licenses/>.
- */
- namespace OCP\User;
- use JsonSerializable;
- use OCP\IUser;
- /**
- * DTO to hold out-of-office information of a user
- *
- * @psalm-type OutOfOfficeData = array{
- * id: string,
- * userId: string,
- * startDate: int,
- * endDate: int,
- * shortMessage: string,
- * message: string,
- * }
- *
- * @since 28.0.0
- */
- interface IOutOfOfficeData extends JsonSerializable {
- /**
- * Get the unique token assigned to the current out-of-office event
- *
- * @since 28.0.0
- */
- public function getId(): string;
- /**
- * @since 28.0.0
- */
- public function getUser(): IUser;
- /**
- * Get the accurate out-of-office start date
- *
- * This event is not guaranteed to be emitted exactly at start date
- *
- * @since 28.0.0
- */
- public function getStartDate(): int;
- /**
- * Get the (preliminary) out-of-office end date
- *
- * @since 28.0.0
- */
- public function getEndDate(): int;
- /**
- * Get the short summary text displayed in the user status and similar
- *
- * @since 28.0.0
- */
- public function getShortMessage(): string;
- /**
- * Get the long out-of-office message for auto responders and similar
- *
- * @since 28.0.0
- */
- public function getMessage(): string;
- /**
- * @return OutOfOfficeData
- *
- * @since 28.0.0
- */
- public function jsonSerialize(): array;
- }
|