<?php
namespace JanusHercules\ExternallyIncomingApplications\Domain\Entity;
use App\Utility\DatabaseIdGenerator;
use App\Utility\DateTimeUtility;
use DateTime;
use Doctrine\DBAL\Types\Types;
use Doctrine\ORM\Mapping as ORM;
use Exception;
#[ORM\Entity]
#[ORM\Table(name: 'perspective_requests')]
class PerspectiveRequest
{
/**
* @throws Exception
*/
public function __construct(
string $requestData
) {
$this->createdAt = DateTimeUtility::createDateTimeCet();
$this->requestData = $requestData;
}
#[ORM\Id]
#[ORM\GeneratedValue(strategy: 'CUSTOM')]
#[ORM\CustomIdGenerator(class: DatabaseIdGenerator::class)]
#[ORM\Column(
type : Types::GUID,
unique: true
)]
private ?string $id = null;
public function getId(): ?string
{
return $this->id;
}
#[ORM\Column(
type : Types::DATETIME_MUTABLE,
nullable: false
)]
private DateTime $createdAt;
public function setCreatedAt(DateTime $createdAt): void
{
$this->createdAt = $createdAt;
}
public function getCreatedAt(): DateTime
{
return $this->createdAt;
}
#[ORM\Column(
type : Types::TEXT,
length : 32768,
nullable: false
)]
private string $requestData;
public function setRequestData(string $requestData): void
{
$this->requestData = mb_substr($requestData, 0, 32768);
}
public function getRequestData(): string
{
return $this->requestData;
}
}