2017 © Pedro Peláez
 

library mappers

Mappers for Lean Mapper.

image

inlm/mappers

Mappers for Lean Mapper.

  • Sunday, June 24, 2018
  • by janpecha
  • Repository
  • 1 Watchers
  • 0 Stars
  • 107 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 0 Forks
  • 0 Open issues
  • 4 Versions
  • 34 % Grown

The README.md

Inlm\Mappers

Build Status Downloads this Month Latest Stable Version License, (*1)

Mappers for Lean Mapper., (*2)

Donate, (*3)

Installation

Download a latest package or use Composer:, (*4)

composer require inlm/mappers

Inlm\Mappers requires PHP 8.0 or later., (*5)

Usage

Mapper Entity Table Column Note
Inlm\Mappers\DefaultMapper OrderItem orderitem customerName only extends LeanMapper\DefaultMapper
Inlm\Mappers\CamelCaseMapper OrderItem orderItem customerName There is issue for MySQL on OS Windows.
Inlm\Mappers\UnderScoreMapper OrderItem order_item customer_name
Inlm\Mappers\DynamicMapper ~ ~ ~ See below.
Inlm\Mappers\PrefixMapper ~ ~ ~ See below.
Inlm\Mappers\RowMapper ~ ~ ~ See below.
Inlm\Mappers\StiMapper ~ ~ ~ See below.

DynamicMapper

Dynamic mapper uses explicit mapping of entities and tables., (*6)

``` php $mapper = new DynamicMapper; $mapper->setMapping( 'order_items', // table name - required 'OrderItem', // entity class - optional 'OrderItemRepository', // repository class - optional 'item_id' // primary key - optional );, (*7)


If there's no mapping for entity or table, call is passed to fallback mapper (`LeanMapper\DefaultMapper` by default): ``` php $mapper = new DynamicMapper; $mapper->getTable('OrderItem'); // returns 'orderitem' $mapper = new DynamicMapper(new Inlm\Mappers\UnderScoreMapper); $mapper->getTable('OrderItem'); // returns 'order_item'

PrefixMapper

PrefixMapper adds & removes prefix from table names., (*8)

``` php $mapper = new PrefixMapper('prefix_'); $mapper = new PrefixMapper('prefix_', $fallbackMapper);, (*9)


PrefixMapper only processes prefixes in table names, everything else is given to fallback mapper (`LeanMapper\DefaultMapper` by default): ``` php $mapper = new PrefixMapper('prefix_'); echo $mapper->getTable('OrderItem'); // prints 'prefix_orderitem' $mapper = new PrefixMapper('prefix_', new Inlm\Mappers\UnderScoreMapper); echo $mapper->getTable('OrderItem'); // prints 'prefix_order_item'

RowMapper

RowMapper maps values to / from LeanMapper\Row (requires Lean Mapper 3.5+)., (*10)

``` php $mapper = new RowMapper; $mapper = new RowMapper($fallbackMapper); $mapper->registerFieldMapping($entity, $field, $fromDbValue, $toDbValue); $mapper->registerFieldMapping( Model\Entity\Client::class, 'website', function ($dbValue) { return new Website($dbValue); }, function (Website $rowValue) { return $rowValue->getUrl(); } );, (*11)

// multi column mapping $mapper->registerMultiValueMapping( Model\OrderItem::class, 'price', function (array $values, $rowField) { return new Price($values[$rowField . '_total'], $values[$rowField . '_currency']); }, function (Price $price, $rowField) { return [ $rowField . '_total' => $price->getPrice(), $rowField . '_currency' => $price->getCurrency(), ]; } );, (*12)



### StiMapper StiMapper simplifies working with Single Table Inheritance. ``` php $mapper = new StiMapper; $mapper = new StiMapper($fallbackMapper);

Registration of STI types:, (*13)

``` php $mapper->registerStiType($baseEntity, $typeValue, $entityClass); $mapper->registerStiType(Entities\Client::class, 'company', Entities\ClientCompany::class); $mapper->registerStiType(Entities\Client::class, 'individual', Entities\ClientIndividual::class);, (*14)


Default STI type column is named `type`, you can change it with: ``` php $mapper->registerTypeField(Entities\Client::class, 'clientType');

You can limit LeanMapper\Fluent for specific STI type:, (*15)

``` php $fluent = $connection->select('*')->from('client'); $mapper->applyStiMapping($fluent, Entities\ClientCompany::class); echo $fluent; // SELECT * FROM client WHERE client.clientType = 'company', (*16)


### How change default entity namespace ``` php $mapper = new Inlm\Mappers\DefaultMapper('App\Entity'); $mapper = new Inlm\Mappers\CamelCaseMapper('App\Entity'); $mapper = new Inlm\Mappers\UnderScoreMapper('App\Entity');
  • RowMapper
  • StiMapper
  • PrefixMapper
  • DynamicMapper
  • DefaultMapper / CamelCaseMapper / UnderScoreMapper

License: New BSD License
Author: Jan Pecha, https://www.janpecha.cz/, (*17)

The Versions

24/06 2018

dev-master

9999999-dev

Mappers for Lean Mapper.

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

01/04 2018

v1.1.0

1.1.0.0

Mappers for Lean Mapper.

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

28/11 2017

v1.0.1

1.0.1.0

Mappers for Lean Mapper.

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires

22/08 2017

v1.0.0

1.0.0.0

Mappers for Lean Mapper.

  Sources   Download

BSD-3-Clause

The Requires

 

The Development Requires