* @throws OCSNotFoundException The user was not found * * 200: The status was found successfully */ #[ApiRoute(verb: 'GET', url: '/api/v1/user_status')] public function getStatus(): DataResponse { try { $this->calendarStatusService->processCalendarStatus($this->userId); $userStatus = $this->service->findByUserId($this->userId); } catch (DoesNotExistException $ex) { throw new OCSNotFoundException('No status for the current user'); } return new DataResponse($this->formatStatus($userStatus)); } /** * Update the status type of the current user * * @NoAdminRequired * * @param string $statusType The new status type * @return DataResponse * @throws OCSBadRequestException The status type is invalid * * 200: The status was updated successfully */ #[ApiRoute(verb: 'PUT', url: '/api/v1/user_status/status')] public function setStatus(string $statusType): DataResponse { try { $status = $this->service->setStatus($this->userId, $statusType, null, true); $this->service->removeBackupUserStatus($this->userId); return new DataResponse($this->formatStatus($status)); } catch (InvalidStatusTypeException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to an invalid status type "' . $statusType . '"'); throw new OCSBadRequestException($ex->getMessage(), $ex); } } /** * Set the message to a predefined message for the current user * * @NoAdminRequired * * @param string $messageId ID of the predefined message * @param int|null $clearAt When the message should be cleared * @return DataResponse * @throws OCSBadRequestException The clearAt or message-id is invalid * * 200: The message was updated successfully */ #[ApiRoute(verb: 'PUT', url: '/api/v1/user_status/message/predefined')] public function setPredefinedMessage(string $messageId, ?int $clearAt): DataResponse { try { $status = $this->service->setPredefinedMessage($this->userId, $messageId, $clearAt); $this->service->removeBackupUserStatus($this->userId); return new DataResponse($this->formatStatus($status)); } catch (InvalidClearAtException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to an invalid clearAt value "' . $clearAt . '"'); throw new OCSBadRequestException($ex->getMessage(), $ex); } catch (InvalidMessageIdException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to an invalid message-id "' . $messageId . '"'); throw new OCSBadRequestException($ex->getMessage(), $ex); } } /** * Set the message to a custom message for the current user * * @NoAdminRequired * * @param string|null $statusIcon Icon of the status * @param string|null $message Message of the status * @param int|null $clearAt When the message should be cleared * @return DataResponse * @throws OCSBadRequestException The clearAt or icon is invalid or the message is too long * * 200: The message was updated successfully */ #[ApiRoute(verb: 'PUT', url: '/api/v1/user_status/message/custom')] public function setCustomMessage(?string $statusIcon, ?string $message, ?int $clearAt): DataResponse { try { if (($statusIcon !== null && $statusIcon !== '') || ($message !== null && $message !== '') || ($clearAt !== null && $clearAt !== 0)) { $status = $this->service->setCustomMessage($this->userId, $statusIcon, $message, $clearAt); } else { $this->service->clearMessage($this->userId); $status = $this->service->findByUserId($this->userId); } $this->service->removeBackupUserStatus($this->userId); return new DataResponse($this->formatStatus($status)); } catch (InvalidClearAtException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to an invalid clearAt value "' . $clearAt . '"'); throw new OCSBadRequestException($ex->getMessage(), $ex); } catch (InvalidStatusIconException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to an invalid icon value "' . $statusIcon . '"'); throw new OCSBadRequestException($ex->getMessage(), $ex); } catch (StatusMessageTooLongException $ex) { $this->logger->debug('New user-status for "' . $this->userId . '" was rejected due to a too long status message.'); throw new OCSBadRequestException($ex->getMessage(), $ex); } } /** * Clear the message of the current user * * @NoAdminRequired * * @return DataResponse, array{}> * * 200: Message cleared successfully */ #[ApiRoute(verb: 'DELETE', url: '/api/v1/user_status/message')] public function clearMessage(): DataResponse { $this->service->clearMessage($this->userId); return new DataResponse([]); } /** * Revert the status to the previous status * * @NoAdminRequired * * @param string $messageId ID of the message to delete * * @return DataResponse, array{}> * * 200: Status reverted */ #[ApiRoute(verb: 'DELETE', url: '/api/v1/user_status/revert/{messageId}')] public function revertStatus(string $messageId): DataResponse { $backupStatus = $this->service->revertUserStatus($this->userId, $messageId, true); if ($backupStatus) { return new DataResponse($this->formatStatus($backupStatus)); } return new DataResponse([]); } /** * @param UserStatus $status * @return UserStatusPrivate */ private function formatStatus(UserStatus $status): array { /** @var UserStatusType $visibleStatus */ $visibleStatus = $status->getStatus(); return [ 'userId' => $status->getUserId(), 'message' => $status->getCustomMessage(), 'messageId' => $status->getMessageId(), 'messageIsPredefined' => $status->getMessageId() !== null, 'icon' => $status->getCustomIcon(), 'clearAt' => $status->getClearAt(), 'status' => $visibleStatus, 'statusIsUserDefined' => $status->getIsUserDefined(), ]; } }