redbox / hydrate
Requires
- php: >=5.4.0
Requires (Dev)
- phpunit/phpunit: ~4.6
This package is not auto-updated.
Last update: 2024-11-09 20:28:22 UTC
README
![HHVM Ready](https://img.shields.io/badge/PHP 7.1-Ready-green.svg) ![Twitter URL](https://img.shields.io/twitter/url/http/shields.io.svg?style=social&label=Contact author)
Redbox-hydrate
Hydrating an object is fancy talk for populating properties on PHP objects. This Hydrator helps you to quickly hydrate new class instances and returns the populated result. Please note it does not mether if you have private or protected properties in your class it will take care of that for you. Look in the examples folder for basic examples.
Examples
I have gone to great length to provide a special (read sexy) and tiny API for you. You can use any kind of API style you see fit in your operation for example.
Static class method
In this example we will hydrate a new instance of class User and return it as $result1 using with with() function.
use Redbox\Hydrate\Hydrator; /** * Method 1 */ $result1 = Hydrator::hydrate(new User())->with( [ 'username' => 'abc', 'password' => 'pass' ] );
Hydrate function
use function Redbox\Hydrate\Helpers\Hydrate; /** * Method 2 */ $result2 = Hydrate(new User())->with( [ 'username' => 'abc', 'password' => 'pass' ] );
Instantiate a new Hydrator
Plain old PHP, create your instance of the hydrator then call the with( ) method.
Please note There is something off with this method. If your doing this inside a loop it might consume some memory because of all the instances you create. Please don't forget to use the unset function if you are inside any kind of loop.
use Redbox\Hydrate\Hydrator; /** * Method 3 */ $hydrator = new Hydrator(new User()); $result3 = $hydrator->with( [ 'username' => 'abcs', 'password' => 'pass' ] ); unset($hydrator);
System Requirements
Below are the minimum requirements to use this package:
- PHP >= 5.40 (But higher is always better)
- Composer for autoloading
Installation
Using composer:
$ composer require redbox/hydrate
Installation trough archive download
If you download the package from a website (for example github.io or phpclasses.org or any other) you will need composer installed on your machine. The reason for this is that Redbox-hydrate comes without the vendor directory which is required to run the package.
First of all if you don't have composer installed you can find it here. Follow the instructions and please don't get intimidated in fact its really really easy to install.
In the this sample i will assume you have composer installed (on any machine). Go to the package root (where composer.json is located) and execute the following command.
$ composer install --no-dev
Now your almost ready to go. In your project require the redbox-hydrate.php (located in the package root). Assuming that Redbox-hydrate was installed in ./lib/redbox-hydrate/ your php file would look like this.
<?php require 'lib/redbox-hydrate/redbox-hydrate.php'; // more of your nice code below
And you are ready use Redbox-hydrate in your application.
Author
Redbox-hydrate is created and maintained by Johnny Mast. For feature requests or suggestions you could consider sending me an e-mail.
License
Redbox-hydrate is released under the MIT public license.
https://github.com/johnnymast/redbox-hydrator/blob/master/LICENSE.md
Enjoy
Oh and if you've come down this far, you might as well follow me on twitter.