requestBody); $fingerprint = new Fingerprint(null, $db); try { $fingerprint->setFingerprint($json->fingerprint); $fingerprint->setUserId($json->userId); if (!$db->hasTransaction()) { $db->startTransaction(); } $fingerprint->Save(); $qrCode = new QrCode($fingerprint->getFingerprintId(), $fingerprint->getFingerprint()); $qrCode->generate(); $qrCode->save(); $db->commit(); $this->response->setParameter('fingerprintId', $fingerprint->getFingerprintId()); } catch (QrCodeException $e) { $db->rollback(); $this->response->setParameter('success', false); $this->response->setStatus(ServerStatus::INTERNAL_ERROR); $this->response->setMessage('An error occured during qr code creation!'); } catch (Throwable $e) { $db->rollback(); $this->catchDatabaseException($e->getMessage(), $json); } } private function catchDatabaseException(string $message, object $json): void { $this->response->setParameter('success', false); 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); } } }