alexboo / phalcon-annotation-mapper
Mapping data by annotation
dev-master
2018-01-26 03:58 UTC
Requires
- php: >=5.4.0
- ext-phalcon: >=1.2.4
This package is not auto-updated.
Last update: 2025-01-04 20:22:33 UTC
README
Mapping data from object or associative array to object implements \Alexboo\AnnotationMapper\MapperInterface
Install
You can install it using the composer. But it need phalcon framework php extension.
composer require alexboo/phalcon-annotation-mapper
Examples
class Example extends \Alexboo\AnnotationMapper\Mapper
{
/**
* @Mapped(property="priceOut", type="float", precision=2)
*/
public $price;
/**
* @Mapped(type="integer")
*/
protected $count;
/**
* @Mapped(type="float[]")
*/
public $array;
/**
* @Mapped(type="Example2[]")
*/
public $object;
public function setCount($value) {
$this->count = $value;
}
}
class Example2 extends \Alexboo\AnnotationMapper\Mapper
{
/**
* @Mapped(type="integer")
*/
public $propertyOne;
/**
* @Mapped(type="float")
*/
public $propertyTwo;
/**
* @Mapped(type="string")
*/
public $propertyThree;
}
$donator = [
'priceOut' => '1000.51000',
'count' => 100,
'array' => ['1.222','2.333','3.400000'],
'object' => [[
'propertyOne' => '1000.500',
'propertyTwo' => '2000.500',
'propertyThree' => ' aaaddd '
]]
];
$example = new Example();
$example->mapping($donator);
var_dump($example);
$donator = new stdClass();
$donator->priceOut = '2000.52000';
$donator->count = 200;
$donator->array = [4,5,6];
$donator->object = [[
'propertyOne' => '1000.520',
'propertyTwo' => '2000.520',
'propertyThree' => ' aaaddd '
]];
$example = new Example();
$example->mapping($donator);
var_dump($example);
Additional options.
Caster float and string support additional options. For float caster you can set precision (number of digits after the decimal point). For string you can disabled or enabled (using by default) trim all string.
// Set default precision for all properties with float type
\Alexboo\AnnotationMapper\Cast\Float::setDefaultPrecision(1);
class Example3 extends \Alexboo\AnnotationMapper\Mapper
{
/**
* @var float $field1
* @Mapped(type="float")
*/
public $field1;
/**
* @var float $field2
* @Mapped(type="float")
*/
public $field2;
}
$example = new Example3();
$example->mapping([
'field1' => '15.123456',
'field2' => '987.654123',
]);
var_dump($example);
// Disabled/enabled trim string data
class Example4 extends \Alexboo\AnnotationMapper\Mapper
{
/**
* @Mapped(type="string")
*/
public $field1;
/**
* @Mapped(type="string")
*/
public $field2;
}
\Alexboo\AnnotationMapper\Cast\String::isTrim(false);
$example = new Example4();
$example->mapping([
'field1' => ' asdasd asdasdasd ',
'field2' => ' ',
]);
var_dump($example);
\Alexboo\AnnotationMapper\Cast\String::isTrim(true);
$example = new Example4();
$example->mapping([
'field1' => ' asdasd asdasdasd ',
'field2' => ' ',
]);
var_dump($example);
Create you custer
You can create custom custer if you need. Than you can specify it like type of property. Caster must implements \Alexboo\AnnotationMapper\CastCastInterface
/**
* Cast all data to "blabla" string
* Class BlaBlaCaster
*/
class BlaBlaCaster extends \Alexboo\AnnotationMapper\Cast\CastAbstract
{
public function cast($value) {
return "blabla";
}
}
class Example5 extends \Alexboo\AnnotationMapper\Mapper
{
/**
* @Mapped(type="BlaBlaCaster")
*/
public $field1;
/**
* @Mapped(type="\Alexboo\AnnotationMapper\Cast\Integer")
*/
public $field2;
}
$example = new Example5();
$example->mapping([
'field1' => 'Say something very clever!',
'field2' => 123213213,
]);
var_dump($example);