2022-08-10 04:41:59 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
declare(strict_types=1);
|
|
|
|
|
/**
|
2024-05-27 04:08:53 -04:00
|
|
|
* SPDX-FileCopyrightText: 2022 Nextcloud GmbH and Nextcloud contributors
|
|
|
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
2022-08-10 04:41:59 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
namespace OC\Core\Controller;
|
|
|
|
|
|
2022-08-28 14:54:21 -04:00
|
|
|
use OCP\AppFramework\Controller;
|
2022-08-12 14:17:44 -04:00
|
|
|
use OCP\AppFramework\Http;
|
2024-01-10 06:35:44 -05:00
|
|
|
use OCP\AppFramework\Http\Attribute\FrontpageRoute;
|
2024-07-25 07:24:59 -04:00
|
|
|
use OCP\AppFramework\Http\Attribute\NoCSRFRequired;
|
2024-12-17 07:17:22 -05:00
|
|
|
use OCP\AppFramework\Http\Attribute\OpenAPI;
|
2024-07-25 07:24:59 -04:00
|
|
|
use OCP\AppFramework\Http\Attribute\PublicPage;
|
2022-08-12 14:17:44 -04:00
|
|
|
use OCP\AppFramework\Http\DataDownloadResponse;
|
|
|
|
|
use OCP\AppFramework\Http\DataResponse;
|
2023-11-23 04:22:34 -05:00
|
|
|
use OCP\Collaboration\Reference\IReferenceManager;
|
2022-08-12 14:17:44 -04:00
|
|
|
use OCP\Files\AppData\IAppDataFactory;
|
|
|
|
|
use OCP\Files\NotFoundException;
|
2022-08-28 14:54:21 -04:00
|
|
|
use OCP\Files\NotPermittedException;
|
2022-08-10 04:41:59 -04:00
|
|
|
use OCP\IRequest;
|
|
|
|
|
|
2022-08-28 14:54:21 -04:00
|
|
|
class ReferenceController extends Controller {
|
2023-06-05 11:12:42 -04:00
|
|
|
public function __construct(
|
|
|
|
|
string $appName,
|
|
|
|
|
IRequest $request,
|
|
|
|
|
private IReferenceManager $referenceManager,
|
|
|
|
|
private IAppDataFactory $appDataFactory,
|
|
|
|
|
) {
|
2022-08-10 04:41:59 -04:00
|
|
|
parent::__construct($appName, $request);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
2023-03-15 12:29:32 -04:00
|
|
|
* Get a preview for a reference
|
|
|
|
|
*
|
2022-10-06 06:57:38 -04:00
|
|
|
* @param string $referenceId the reference cache key
|
2023-03-15 12:29:32 -04:00
|
|
|
* @return DataDownloadResponse<Http::STATUS_OK, string, array{}>|DataResponse<Http::STATUS_NOT_FOUND, '', array{}>
|
|
|
|
|
*
|
|
|
|
|
* 200: Preview returned
|
|
|
|
|
* 404: Reference not found
|
2022-08-10 04:41:59 -04:00
|
|
|
*/
|
2024-07-25 07:24:59 -04:00
|
|
|
#[PublicPage]
|
|
|
|
|
#[NoCSRFRequired]
|
2024-01-10 06:35:44 -05:00
|
|
|
#[FrontpageRoute(verb: 'GET', url: '/core/references/preview/{referenceId}')]
|
2024-12-17 07:17:22 -05:00
|
|
|
#[OpenAPI(scope: OpenAPI::SCOPE_DEFAULT)]
|
2023-03-15 12:29:32 -04:00
|
|
|
public function preview(string $referenceId): DataDownloadResponse|DataResponse {
|
2022-08-12 14:17:44 -04:00
|
|
|
$reference = $this->referenceManager->getReferenceByCacheKey($referenceId);
|
2022-08-10 04:41:59 -04:00
|
|
|
|
2022-08-12 14:17:44 -04:00
|
|
|
try {
|
|
|
|
|
$appData = $this->appDataFactory->get('core');
|
|
|
|
|
$folder = $appData->getFolder('opengraph');
|
|
|
|
|
$file = $folder->getFile($referenceId);
|
2023-02-22 06:39:26 -05:00
|
|
|
$contentType = $reference === null || $reference->getImageContentType() === null
|
|
|
|
|
? $file->getMimeType()
|
|
|
|
|
: $reference->getImageContentType();
|
2022-10-06 06:57:38 -04:00
|
|
|
$response = new DataDownloadResponse(
|
|
|
|
|
$file->getContent(),
|
|
|
|
|
$referenceId,
|
2023-02-22 06:39:26 -05:00
|
|
|
$contentType
|
2022-10-06 06:57:38 -04:00
|
|
|
);
|
2022-08-28 14:54:21 -04:00
|
|
|
} catch (NotFoundException|NotPermittedException $e) {
|
2022-09-23 06:42:08 -04:00
|
|
|
$response = new DataResponse('', Http::STATUS_NOT_FOUND);
|
2022-08-10 04:41:59 -04:00
|
|
|
}
|
2022-09-23 06:42:08 -04:00
|
|
|
$response->cacheFor(3600, false, true);
|
|
|
|
|
return $response;
|
2022-08-10 04:41:59 -04:00
|
|
|
}
|
|
|
|
|
}
|