ringfinger/backend/classes/controller/FingerprintPostController.php

71 lines
2.0 KiB
PHP
Raw Permalink Normal View History

2020-08-17 23:46:58 +02:00
<?php
declare(strict_types=1);
final class FingerprintPostController extends AbstractController
{
2020-08-23 12:37:39 +02:00
protected string $route = '/api/v1/fingerprint';
protected array $mandatoryAttributes = [
'fingerprint',
'userId',
];
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
public function handle(): void
{
parent::handle();
if (!$this->isUserLoggedIn() || $this->response->getStatus() !== ServerStatus::OK) {
2020-08-23 12:37:39 +02:00
return;
}
2020-08-23 12:37:39 +02:00
$db = new MySqlDatabase();
2020-08-23 12:37:39 +02:00
$fingerprint = new Fingerprint(null, $db);
2020-08-20 23:08:20 +02:00
$this->response = new ApiJsonResponse();
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
try {
if (!$this->hasUserPermission((int)$this->jsonBody->userId)) {
return;
}
$fingerprint->setFingerprint((string)$this->jsonBody->fingerprint);
$fingerprint->setUserId((int)$this->jsonBody->userId);
2020-08-18 11:46:03 +02:00
2020-08-23 12:37:39 +02:00
if (!$db->hasTransaction()) {
$db->startTransaction();
}
2020-08-18 11:46:03 +02:00
2020-08-23 12:37:39 +02:00
$fingerprint->Save();
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
$qrCode = new QrCode($fingerprint->getFingerprintId(), $fingerprint->getFingerprint());
$qrCode->generate();
$qrCode->save();
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
$db->commit();
2020-08-18 11:46:03 +02:00
2020-08-23 12:37:39 +02:00
$this->response->setParameter('fingerprintId', $fingerprint->getFingerprintId());
} catch (QrCodeException $e) {
$this->response->setStatus(ServerStatus::INTERNAL_ERROR);
$this->response->setParameter('success', false);
$this->response->setMessage('An error occured during QR code creation!');
} catch (Throwable $e) {
$this->catchDatabaseException($e->getMessage(), $this->jsonBody);
2020-08-23 12:37:39 +02:00
}
}
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
private function catchDatabaseException(string $message, object $json): void
{
$this->response->setParameter('success', false);
2020-08-17 23:46:58 +02:00
2020-08-23 12:37:39 +02:00
if (substr_count($message, 'foreign key constraint fails') > 0) {
$this->response->setMessage(sprintf('User with id %d doesn\'t exist!', $json->userId));
$this->response->setStatus(ServerStatus::NOT_FOUND);
} elseif (substr_count($message, 'Duplicate entry') > 0) {
$this->response->setMessage(sprintf('Fingerprint %s already exists!', $json->fingerprint));
$this->response->setStatus(ServerStatus::BAD_REQUEST);
} else {
$this->response->setMessage($message);
$this->response->setStatus(ServerStatus::INTERNAL_ERROR);
}
}
2020-08-17 23:46:58 +02:00
}