aedart / athenaeum-properties
DEPRECATED - Provides means to dynamically deal with inaccessible properties, by implementing some of PHP's magic methods
Requires
- php: ^8.4
- aedart/athenaeum-contracts: ^10.10
- aedart/athenaeum-utils: ^10.10
This package is auto-updated.
Last update: 2026-06-23 06:48:05 UTC
README
Deprecated: Please use the Dto package instead!
Provides means to dynamically deal with inaccessible properties, by implementing some of PHP's magic methods.
The usage of getters- and setters-methods is enforced, ensuring that if a property is indeed available, its corresponding getter or setter method will be invoked.
The term 'overload', in this context, refers to PHP’s own definition hereof.
Example
use Aedart\Properties\Overload; /** * @property string|null $name Name of a person */ class Person { use Overload; protected string|null $name = null; public function getName() : string { return $this->name; } public function setName(string $value) { if(empty($value)){ throw new InvalidArgumentException('Provided name is invalid'); } $this->name = $value; return $this; } }
Elsewhere in your application, you can invoke the following:
$person = new Person(); $person->name = 'Alin'; // Invokes the setName(...) echo $person->name; // Invokes the getName(), then outputs 'Alin' echo isset($person->name); // Invokes the __isset(), then outputs true unset($person->name); // Invokes the __unset() and destroys the name property
Documentation
Please read the official documentation for additional information.
Repository
The mono repository is located at github.com/aedart/athenaeum
Versioning
This package follows Semantic Versioning 2.0.0
License
BSD-3-Clause, Read the LICENSE file included in this package