tourze / getter-setter-trait
Getter/Setter Trait
0.0.1
2025-04-21 12:30 UTC
Requires
- php: ^8.1
- tourze/yii2-base: 0.0.*
Requires (Dev)
- phpstan/phpstan: ^2.1
- phpunit/phpunit: ^10.0
This package is auto-updated.
Last update: 2025-04-25 19:08:20 UTC
README
A lightweight PHP library providing reusable Getter and Setter traits for object property access, inspired by Yii2 conventions. It enables magic property access (__get
, __set
) with robust exception handling for unknown or write/read-only properties.
Features
- Simple integration of getter/setter magic methods via traits
- Yii2-style exception handling for property access
- Automatic detection of getter/setter methods
- Support for property existence checks
- Designed for PHP 8.1+
Installation
Requires PHP 8.1 or higher.
Install via Composer:
composer require tourze/getter-setter-trait
Quick Start
use Tourze\GetterSetterTrait\GetterTrait; use Tourze\GetterSetterTrait\SetterTrait; use Tourze\GetterSetterTrait\PropertyTrait; class User { use GetterTrait, SetterTrait, PropertyTrait; private string $name = ''; public function getName(): string { return $this->name; } public function setName(string $name): void { $this->name = $name; } } $user = new User(); $user->name = 'Tom'; echo $user->name; // Tom
Documentation
- GetterTrait: Implements
__get($name)
for magic property reading. - SetterTrait: Implements
__set($name, $value)
for magic property writing. - PropertyTrait: Provides
hasProperty
,canGetProperty
,canSetProperty
helpers. - Throws
UnknownPropertyException
for undefined properties,InvalidCallException
for read/write-only properties (compatible with Yii2).
Advanced Usage
- You may override getter/setter methods for custom logic.
- Use
PropertyTrait
to check property accessibility programmatically.
Contributing
Contributions are welcome! Please follow these steps:
- Submit issues for bugs or feature requests.
- Fork the repository and create pull requests.
- Ensure code style and run tests before submitting.
- Follow PSR-12 coding standards.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Author
tourze Team
This README is generated based on the actual codebase and follows the project documentation rules.