This package is part of the Apie library. The code is maintained in a monorepo, so PR's need to be sent to the monorepo
A set of common value object classes that can be used right away or can be used as examples how to make common value objects.
enums are just PHP 8.1 enums with common values. They are fully supported by Apie.
Enums | Description |
---|---|
Gender | Indicate male or female |
Identifiers are used by Apie entities to tell the id of an entity. To use these as identifiers for your entity, you need to extend one of these and implement the IdentifierInterface. Otherwise you can also use them as property fields on an entity or a composite value object.
Example:
<?php
use Apie\Core\Identifiers\UuidV4;
use Apie\Core\Identifiers\IdentifierInterface;
class UserIdentifier extends UuidV4 implements IdentifierInterface
{
public static function getReferenceFor(): ReflectionClass
{
return new ReflectionClass(User::class);
}
}
<?php
use Apie\Core\Entities\EntityInterface;
class User implements EntityInterface
{
private UserIdentifier $id;
public function __construct()
{
$this->id = UserIdentifier::createRandom();
}
public function getIdentifier(): UserIdentifier
{
return $this->id;
}
}
Class | Description |
---|---|
KebabCaseSlug | Slug in the shape of "example-slug" |
PascalCaseSlug | Slug in the shape of "example_slug" |
Slug | Slug in the shape of "exampleslug" |
Uuid | Any string in the shape of an uuid |
UuidV1 | Uuid in version 1 format |
UuidV2 | Uuid in version 2 format |
UuidV3 | Uuid in version 3 format |
UuidV4 | Uuid in version 4 format |
UuidV5 | Uuid in version 5 format |
UuidV6 | Uuid in version 6 format |
Contains value objects related to names. They are very tolerant what is written in them and support unicode characters to avoid wrong assumptions about what is a valid first and last name.
Class | Description |
---|---|
FirstName | First name |
LastName | Last name |
Ranges often have a restriction related that for example the start should always be lower than the end. They are often a composite of 2 values.
Class | Description |
---|---|
DateTimeRange | A range between dates. The first date should always be lower than the last date |
At first these value objects seem redundant as you wonder why you should not just use string, but the problem with using string is that it has no restriction on the length of a text. The value object will also mean you can tell an application it requires a non-empty text for example.
Class | Description |
---|---|
DatabaseText | A string that fits into a database text field (65535 characters). The text will be trimmed and can be empty. |
NonEmptyString | Any string as long it is not empty. The text will be trimmed. |
SmallDatabaseText | A string that fits into a database varchar field (255 characters). The text will be trimmed and can be empty. |
StrongPasswordField | A string used for passwords that are considered strong passwords. |