mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-23 11:21:13 +01:00
232 lines
6.9 KiB
PHP
232 lines
6.9 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Xentral\Modules\Api\Controller\Version1;
|
||
|
|
||
|
use Xentral\Components\Http\Response;
|
||
|
use Xentral\Modules\Api\Error\ApiError;
|
||
|
use Xentral\Modules\Api\Exception\BadRequestException;
|
||
|
use Xentral\Modules\Api\Exception\ResourceNotFoundException;
|
||
|
use Xentral\Modules\Api\Exception\ServerErrorException;
|
||
|
use Xentral\Modules\Api\Resource\FileResource;
|
||
|
use Xentral\Modules\Api\Resource\Result\ItemResult;
|
||
|
|
||
|
class FileController extends AbstractController
|
||
|
{
|
||
|
/**
|
||
|
* Resourcen-Liste abrufen
|
||
|
*
|
||
|
* @return Response
|
||
|
*/
|
||
|
public function listAction()
|
||
|
{
|
||
|
// Filter, Sortierung und Paginierung
|
||
|
$filter = $this->prepareFilterParams();
|
||
|
$sorting = $this->prepareSortingParams();
|
||
|
$includes = $this->prepareIncludeParams();
|
||
|
$currentPage = $this->getPaginationPage();
|
||
|
$itemsPerPage = $this->getPaginationCount();
|
||
|
|
||
|
// Liste laden
|
||
|
$resource = $this->getResource($this->resourceClass);
|
||
|
$result = $resource->getList($filter, $sorting, [], $includes, $currentPage, $itemsPerPage);
|
||
|
|
||
|
return $this->sendResult($result);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Einzelne Resource anhand ID laden
|
||
|
*
|
||
|
* @return Response
|
||
|
*/
|
||
|
public function readAction()
|
||
|
{
|
||
|
return $this->sendResult($this->readResult());
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Datei als Download senden
|
||
|
*
|
||
|
* @return Response
|
||
|
*/
|
||
|
public function downloadAction()
|
||
|
{
|
||
|
$fileId = $this->getResourceId();
|
||
|
|
||
|
$erp = $this->legacyApi->app->erp;
|
||
|
$filePath = $erp->GetDateiPfad($fileId);
|
||
|
$fileName = $erp->GetDateiName($fileId);
|
||
|
if (!is_file($filePath)) {
|
||
|
throw new ResourceNotFoundException('File not found in filesystem.');
|
||
|
}
|
||
|
|
||
|
$fileMime = mime_content_type($filePath);
|
||
|
if ($fileMime === 'directory') {
|
||
|
throw new ResourceNotFoundException('File not found. File is a directory.');
|
||
|
}
|
||
|
|
||
|
$header = [
|
||
|
'Content-Type' => $fileMime,
|
||
|
'Content-Disposition' => sprintf('attachment; filename="%s"', $fileName),
|
||
|
'Content-Length' => (string)filesize($filePath),
|
||
|
];
|
||
|
|
||
|
return new Response(file_get_contents($filePath), 200, $header);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Datei base64-kodiert senden
|
||
|
*
|
||
|
* @return Response
|
||
|
*/
|
||
|
public function base64Action()
|
||
|
{
|
||
|
$fileId = $this->getResourceId();
|
||
|
|
||
|
$erp = $this->legacyApi->app->erp;
|
||
|
$filePath = $erp->GetDateiPfad($fileId);
|
||
|
if (!is_file($filePath)) {
|
||
|
throw new ResourceNotFoundException('File not found in filesystem.');
|
||
|
}
|
||
|
|
||
|
$fileMime = mime_content_type($filePath);
|
||
|
if ($fileMime === 'directory') {
|
||
|
throw new ResourceNotFoundException('File not found. File is a directory.');
|
||
|
}
|
||
|
|
||
|
$prefix = 'data:' . $fileMime . ';base64,';
|
||
|
$header = [
|
||
|
'Content-Type' => 'text/plain',
|
||
|
'Content-Disposition' => 'inline',
|
||
|
];
|
||
|
|
||
|
return new Response($prefix . base64_encode(file_get_contents($filePath)), 200, $header);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Datei anlegen/hochladen
|
||
|
*
|
||
|
* @throws BadRequestException Wenn Pflichtfelder leer, oder Content-Type falsch
|
||
|
* @throws ServerErrorException Wenn Datei aus unbekannten Gründen nicht angelegt werden konnte (sollte nicht auftreten)
|
||
|
*
|
||
|
* @return Response
|
||
|
*/
|
||
|
public function createAction()
|
||
|
{
|
||
|
$input = $this->getRequestDataFromUrlEncodedForm();
|
||
|
|
||
|
if (empty($input['dateiname'])) {
|
||
|
throw new BadRequestException('Required property "dateiname" is missing.');
|
||
|
}
|
||
|
if (empty($input['titel'])) {
|
||
|
throw new BadRequestException('Required property "titel" is missing.');
|
||
|
}
|
||
|
if (empty($input['file_content'])) {
|
||
|
throw new BadRequestException('Required property "file_content" is missing.');
|
||
|
}
|
||
|
|
||
|
$fileName = $input['dateiname']; // Pflichtfeld
|
||
|
$fileTitle = $input['titel']; // Pflichtfeld
|
||
|
$fileDescription = $input['beschreibung'] ?? '';
|
||
|
$fileNumber = null;
|
||
|
$fileCreatorUserId = null;
|
||
|
|
||
|
$erp = $this->legacyApi->app->erp;
|
||
|
$fileId = (int)$erp->CreateDatei(
|
||
|
$fileName,
|
||
|
$fileTitle,
|
||
|
$fileDescription,
|
||
|
$fileNumber,
|
||
|
$input['file_content'],
|
||
|
$fileCreatorUserId
|
||
|
);
|
||
|
|
||
|
if ($fileId <= 0) {
|
||
|
throw new ServerErrorException('Failed to create file.');
|
||
|
}
|
||
|
|
||
|
// if (!empty($input['belegtyp'])) {
|
||
|
// $erp->AddDateiStichwort($fileId, 'Belege', $input['belegtyp'], $belegId); // @todo $belegId
|
||
|
// }
|
||
|
|
||
|
// Bei Erfolg die angelegte Resource zurückliefern; mit Success-Flag
|
||
|
/** @var FileResource $resource */
|
||
|
$result = $this->readResult($fileId);
|
||
|
$result->setSuccess(true);
|
||
|
|
||
|
return $this->sendResult($result, Response::HTTP_CREATED);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @throws ResourceNotFoundException
|
||
|
*
|
||
|
* @return void
|
||
|
*/
|
||
|
public function updateAction()
|
||
|
{
|
||
|
throw new ResourceNotFoundException();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @throws BadRequestException
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
protected function getRequestDataFromUrlEncodedForm()
|
||
|
{
|
||
|
$request = $this->request;
|
||
|
if ($request->getContentType() !== 'x-www-form-urlencoded') {
|
||
|
throw new BadRequestException(
|
||
|
'Unsupported Content-Type',
|
||
|
ApiError::CODE_CONTENT_TYPE_NOT_SUPPORTED,
|
||
|
null,
|
||
|
['Content-Type must be "application/x-www-form-urlencoded"']
|
||
|
);
|
||
|
}
|
||
|
|
||
|
return $request->post->all();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @param int|null $useFileId
|
||
|
*
|
||
|
* @throws ResourceNotFoundException
|
||
|
*
|
||
|
* @return ItemResult
|
||
|
*/
|
||
|
protected function readResult($useFileId = null)
|
||
|
{
|
||
|
$fileId = (int)$useFileId > 0 ? (int)$useFileId : $this->getResourceId();
|
||
|
|
||
|
$erp = $this->legacyApi->app->erp;
|
||
|
$filePath = $erp->GetDateiPfad($fileId);
|
||
|
if (!is_file($filePath)) {
|
||
|
throw new ResourceNotFoundException('File not found in filesystem.');
|
||
|
}
|
||
|
|
||
|
$fileMime = mime_content_type($filePath);
|
||
|
if ($fileMime === 'directory') {
|
||
|
throw new ResourceNotFoundException('File not found. File is a directory.');
|
||
|
}
|
||
|
|
||
|
$resource = $this->getResource($this->resourceClass);
|
||
|
$includes = $this->prepareIncludeParams();
|
||
|
$result = $resource->getOne($fileId, $includes);
|
||
|
$fullUri = $this->request->getFullUrl();
|
||
|
|
||
|
// URI um File-ID erweitern, wenn der Request ohne ID war (beim Anlegen)
|
||
|
if ((int)$useFileId > 0) {
|
||
|
$fullUri .= '/' . $useFileId;
|
||
|
}
|
||
|
|
||
|
// Daten anreichern um Download-Links
|
||
|
$data = $result->getData();
|
||
|
$data['mimetype'] = $fileMime;
|
||
|
$data['links'] = [
|
||
|
'download' => $fullUri . '/download',
|
||
|
'base64' => $fullUri . '/base64',
|
||
|
];
|
||
|
|
||
|
return new ItemResult($data);
|
||
|
}
|
||
|
}
|