зеркало из https://github.com/nextcloud/text.git
124 строки
3.7 KiB
PHP
124 строки
3.7 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
/**
|
|
* SPDX-FileCopyrightText: 2019 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
namespace OCA\Text\Controller;
|
|
|
|
use OCA\Text\Middleware\Attribute\RequireDocumentBaseVersionEtag;
|
|
use OCA\Text\Middleware\Attribute\RequireDocumentSession;
|
|
use OCA\Text\Service\ApiService;
|
|
use OCA\Text\Service\NotificationService;
|
|
use OCA\Text\Service\SessionService;
|
|
use OCP\AppFramework\ApiController;
|
|
use OCP\AppFramework\Http\Attribute\NoAdminRequired;
|
|
use OCP\AppFramework\Http\Attribute\PublicPage;
|
|
use OCP\AppFramework\Http\Attribute\UserRateLimit;
|
|
use OCP\AppFramework\Http\DataResponse;
|
|
use OCP\IRequest;
|
|
use OCP\IUser;
|
|
use OCP\IUserManager;
|
|
use OCP\IUserSession;
|
|
|
|
class SessionController extends ApiController implements ISessionAwareController {
|
|
use TSessionAwareController;
|
|
|
|
private bool $restoreUser = false;
|
|
private ?IUser $userToRestore = null;
|
|
|
|
public function __construct(
|
|
string $appName,
|
|
IRequest $request,
|
|
private ApiService $apiService,
|
|
private SessionService $sessionService,
|
|
private NotificationService $notificationService,
|
|
private IUserManager $userManager,
|
|
private IUserSession $userSession,
|
|
) {
|
|
parent::__construct($appName, $request);
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
public function create(?int $fileId = null, ?string $file = null, ?string $baseVersionEtag = null): DataResponse {
|
|
return $this->apiService->create($fileId, $file, $baseVersionEtag);
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
#[PublicPage]
|
|
public function close(int $documentId, int $sessionId, string $sessionToken): DataResponse {
|
|
return $this->apiService->close($documentId, $sessionId, $sessionToken);
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
#[PublicPage]
|
|
#[RequireDocumentBaseVersionEtag]
|
|
#[RequireDocumentSession]
|
|
public function push(int $version, array $steps, string $awareness): DataResponse {
|
|
try {
|
|
$this->loginSessionUser();
|
|
return $this->apiService->push($this->getSession(), $this->getDocument(), $version, $steps, $awareness);
|
|
} finally {
|
|
$this->restoreSessionUser();
|
|
}
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
#[PublicPage]
|
|
#[RequireDocumentBaseVersionEtag]
|
|
#[RequireDocumentSession]
|
|
public function sync(int $version = 0): DataResponse {
|
|
try {
|
|
$this->loginSessionUser();
|
|
return $this->apiService->sync($this->getSession(), $this->getDocument(), $version);
|
|
} finally {
|
|
$this->restoreSessionUser();
|
|
}
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
#[PublicPage]
|
|
#[RequireDocumentBaseVersionEtag]
|
|
#[RequireDocumentSession]
|
|
public function save(int $version = 0, ?string $autosaveContent = null, ?string $documentState = null, bool $force = false, bool $manualSave = false): DataResponse {
|
|
try {
|
|
$this->loginSessionUser();
|
|
return $this->apiService->save($this->getSession(), $this->getDocument(), $version, $autosaveContent, $documentState, $force, $manualSave);
|
|
} finally {
|
|
$this->restoreSessionUser();
|
|
}
|
|
}
|
|
|
|
#[NoAdminRequired]
|
|
#[PublicPage]
|
|
#[RequireDocumentSession]
|
|
#[UserRateLimit(limit: 5, period: 120)]
|
|
public function mention(string $mention): DataResponse {
|
|
if ($this->getSession()->isGuest() && !$this->sessionService->isUserInDocument($this->getDocument()->getId(), $mention)) {
|
|
return new DataResponse([], 403);
|
|
}
|
|
|
|
return new DataResponse($this->notificationService->mention($this->getDocument()->getId(), $mention));
|
|
}
|
|
|
|
private function loginSessionUser(): void {
|
|
$currentSession = $this->getSession();
|
|
if (!$this->userSession->isLoggedIn()) {
|
|
$user = $this->userManager->get($currentSession->getUserId());
|
|
if ($user !== null) {
|
|
$this->restoreUser = true;
|
|
$this->userToRestore = $this->userSession->getUser();
|
|
$this->userSession->setUser($user);
|
|
}
|
|
}
|
|
}
|
|
|
|
private function restoreSessionUser(): void {
|
|
if ($this->restoreUser) {
|
|
$this->userSession->setUser($this->userToRestore);
|
|
}
|
|
}
|
|
}
|