apie / common-value-objects
Composer package of the apie library: common value objects
Installs: 7 363
Dependents: 6
Suggesters: 2
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/apie/common-value-objects
Requires
- php: >=8.3
- apie/core: 1.0.0-RC2
- apie/count-words: 1.0.0-RC2
- apie/country-and-phone-number: 1.0.0-RC2
- apie/date-value-objects: 1.0.0-RC2
- apie/regex-value-objects: 1.0.0-RC2
- apie/text-value-objects: 1.0.0-RC2
- devizzent/cebe-php-openapi: ^1.1.2
- egulias/email-validator: ^4.0.2
- symfony/html-sanitizer: ^7.2
Requires (Dev)
- apie/fixtures: 1.0.0-RC2
- phpunit/phpunit: ^11.5.2
This package is auto-updated.
Last update: 2025-09-25 11:03:10 UTC
README
common-value-objects
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
Documentation
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
enums are just PHP enums with common values. They are fully supported by Apie.
| Enums | Description | 
|---|---|
| Gender | Indicate male or female | 
Identifiers
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 | 
Name value objects
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 | 
Range value objects
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 | 
Text value objects
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 | 
|---|---|
| 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. |