42 Commits

Author SHA1 Message Date
8c481eb512 Merge branch 'develop' into release 2022-12-22 19:48:34 -03:00
67fea3b15f Merge branch 'develop' into release 2022-12-22 19:42:29 -03:00
2a06507876 Merge branch 'develop' into release 2022-10-11 12:17:39 -03:00
faf615e79d Merge branch 'develop' into release 2022-10-11 11:41:05 -03:00
b8409182d7 Merge branch 'develop' into release 2022-10-10 22:19:18 -03:00
e576ef5054 Merge branch 'develop' into release 2022-10-10 21:48:01 -03:00
b19654bc70 Merge branch 'develop' into release 2022-10-10 17:32:48 -03:00
0af6be2c8e Merge branch 'develop' into release 2022-10-10 16:46:57 -03:00
ba3c70a70e Merge branch 'develop' into release 2022-10-10 16:37:30 -03:00
bc006f3e01 Merge branch 'develop' into release 2022-09-12 21:49:23 -03:00
4ccc38ffac Merge branch 'develop' into release 2022-09-12 17:39:15 -03:00
8531658899 FIX 2022-09-12 17:34:05 -03:00
02f8bb0b4f FIX 2022-09-12 17:29:32 -03:00
10e87b71a3 Update in Repository 2022-09-12 17:23:55 -03:00
37c5a79d5a Made model jsonserializable and added functionality into repository 2022-09-09 15:57:01 -04:00
d12f3f7897 Implement delete 2022-09-09 13:15:54 -04:00
7fc7de7390 Added Factory implementation 2022-09-09 10:33:19 -04:00
3bc54fb9d1 Second version 2022-09-08 21:42:32 -04:00
123d46d33c Fixed Model joins 2021-12-20 23:34:52 -03:00
65c224c636 Merge branch 'develop' into master 2021-08-01 20:51:44 -04:00
6cd26a88ea Merge branch 'develop' into master 2021-08-01 20:34:04 -04:00
022ba575b7 Merge branch 'develop' into master 2021-06-04 21:15:26 -04:00
c913f65b91 Considera leer el dato y correccion en los nombres de los metodos 2021-03-16 00:22:13 -03:00
c8a7781c88 Merge branch 'develop' 2021-03-15 11:17:11 -03:00
1505539e61 Merge branch 'develop' into master 2021-03-09 00:19:55 -03:00
3087a48c43 Merge branch 'develop' into master 2021-03-09 00:15:12 -03:00
43f545516d Merge branch 'develop' 2020-08-04 01:33:09 -04:00
b757ed19b2 Merge branch 'develop' 2020-08-03 23:54:16 -04:00
9dc71e4d77 Merge branch 'develop' 2020-08-03 23:51:05 -04:00
c6806a1c62 Merge branch 'develop' 2020-08-03 23:42:11 -04:00
6fd19a11be Merge branch 'develop' 2020-08-03 23:38:41 -04:00
7c727d93e9 Merge branch 'develop' 2020-08-03 23:27:45 -04:00
e02b8c4063 Merge branch 'develop' 2020-08-03 23:17:38 -04:00
89d1db7a7e Merge branch 'develop' 2020-08-03 23:10:57 -04:00
8dc0a27fd9 Merge branch 'develop' 2020-08-03 22:07:24 -04:00
ae172b902c Merge branch 'develop' 2020-08-03 16:25:19 -04:00
7f81b987c9 Merge branch 'develop' 2020-07-24 12:06:16 -04:00
af801e769f Merge branch 'develop' 2020-07-24 11:58:16 -04:00
c40baaad3f Merge branch 'develop' 2020-07-24 11:47:39 -04:00
a82fdce64b Merge branch 'develop' 2020-07-22 23:08:52 -04:00
8126b1f67d Merge branch 'develop' 2020-07-22 22:57:48 -04:00
2177cb4652 Merge branch 'develop' 2020-07-22 14:08:09 -04:00
6 changed files with 99 additions and 130 deletions

View File

@ -11,10 +11,19 @@ use ProVM\Exception\BlankResult;
abstract class Repository implements RepositoryInterface
{
public function __construct(protected Connection $connection, protected QueryBuilder $builder, protected Factory $factory)
{}
public function __construct(Connection $connection, QueryBuilder $builder, Factory $factory)
{
$this->setConnection($connection)
->setQueryBuilder($builder)
->setFactory($factory)
->setup();
}
protected Connection $connection;
protected QueryBuilder $builder;
protected Factory $factory;
protected string $model;
protected string $table;
public function getConnection(): Connection
{
@ -28,6 +37,40 @@ abstract class Repository implements RepositoryInterface
{
return $this->factory;
}
public function getModel(): string
{
return $this->model;
}
public function getTable(): string
{
return $this->table;
}
public function setConnection(Connection $connection): Repository
{
$this->connection = $connection;
return $this;
}
public function setQueryBuilder(QueryBuilder $builder): RepositoryInterface
{
$this->builder = $builder;
return $this;
}
public function setFactory(Factory $factory): RepositoryInterface
{
$this->factory = $factory;
return $this;
}
public function setModel(string $model_class): RepositoryInterface
{
$this->model = $model_class;
return $this;
}
public function setTable(string $table): RepositoryInterface
{
$this->table = $table;
return $this;
}
public function save(Model &$model): void
{
@ -41,19 +84,22 @@ abstract class Repository implements RepositoryInterface
}
public function update(Model $model, Model $old): void
{
$mapper = $this->getMapper();
$model_values = $mapper->mapModelToTable($model);
$old_values = $mapper->mapModelToTable($old);
$model_values = $this->valuesForUpdate($model);
$old_values = $this->valuesForUpdate($old);
$differences = array_diff_assoc($old_values, $model_values);
$columns = array_map(function($key) {
return "`{$key}` = ?";
}, array_keys($differences));
$values = array_values($differences);
$columns = [];
$values = [];
foreach ($this->fieldsForUpdate() as $i => $column) {
if (isset($model_values[$i]) and $old_values[$i] !== $model_values[$i]) {
$columns []= "`{$column}` = ?";
$values []= $model_values[$i];
}
}
if (count($columns) === 0) {
return;
}
$values = array_values($values);
$values []= $old->{$this->idProperty()}();
$query = $this->getQueryBuilder()->update($this->getTable())->set($columns)->where(["{$this->idField()}} = ?"]);
$this->getConnection()->execute($query, $values);
@ -69,8 +115,8 @@ abstract class Repository implements RepositoryInterface
}
public function delete(Model $model): void
{
$query = $this->getQueryBuilder()->delete($this->getTable())->where(["{$this->idField()} = ?"]);
$this->getConnection()->execute($query, [$model->{$this->idProperty()}()]);
$query = $this->getQueryBuilder()->delete($this->getTable())->where(['id = ?']);
$this->getConnection()->execute($query, [$model->getId()]);
$this->resetIndex();
$this->optimize();
}
@ -85,14 +131,13 @@ abstract class Repository implements RepositoryInterface
}
protected function insert(Model $model): void
{
$mapper = $this->getMapper();
$fields = $mapper->getColumns();
$fields = $this->fieldsForInsert();
$fields_string = array_map(function($field) {
return "`{$field}`";
}, $fields);
$fields_questions = array_fill(0, count($fields), '?');
$query = $this->getQueryBuilder()->insert($this->getTable())->columns($fields_string)->values($fields_questions);
$values = array_values($mapper->mapModelToTable($model));
$values = $this->valuesForInsert($model);
$this->getConnection()->execute($query, $values);
}
protected function resetIndex(): void
@ -152,8 +197,6 @@ abstract class Repository implements RepositoryInterface
return $this->fetchMany($query);
}
abstract protected function getMapper(): Model\Mapper;
abstract protected function fieldsForUpdate(): array;
abstract protected function fieldsForInsert(): array;
abstract protected function valuesForUpdate(Model $model): array;

View File

@ -2,6 +2,7 @@
namespace ProVM\Concept;
use JsonSerializable;
use ProVM\Concept\Model\Repository;
interface Model extends JsonSerializable
{

View File

@ -1,11 +0,0 @@
<?php
namespace ProVM\Concept\Model;
use ProVM\Concept;
interface Mapper
{
public function getColumns(): array;
public function mapModelToTable(Concept\Model $model): array;
public function mapTableToModel(array $data, Concept\Model $model): Concept\Model;
}

View File

@ -28,6 +28,44 @@ interface Repository
*/
public function getTable(): string;
/**
* @param Connection $connection
* @return Repository
*/
public function setConnection(Connection $connection): Repository;
/**
* @param QueryBuilder $builder
* @return Repository
*/
public function setQueryBuilder(QueryBuilder $builder): Repository;
/**
* @param Factory $factory
* @return Repository
*/
public function setFactory(Factory $factory): Repository;
/**
* @param string $model_class
* @return Repository
*/
public function setModel(string $model_class): Repository;
/**
* @param string $table
* @return Repository
*/
public function setTable(string $table): Repository;
/**
* Set up the Repository
* SHOULD CALL
* setTable
* setColumns [setRequired, setOptional]
* setProperties
* setMapping
* setModel
* @return Repository
*/
public function setup(): Repository;
/**
* Transform result array to Model
* @param array $data

View File

@ -1,39 +0,0 @@
<?php
namespace ProVM\Implement\Model;
use ProVM\Concept;
use ProVM\Implement\Model\Mapper\PropertyMap;
class Mapper implements Concept\Model\Mapper
{
protected array $map;
public function getColumns(): array
{
return array_keys($this->map);
}
public function registerColumn(string $columnName, ?PropertyMap $propertyMap = null): Mapper
{
if ($propertyMap == null) {
$this->map[$columnName] = (new PropertyMap())->setColumn($columnName);
return $this;
}
$this->map[$columnName] = $propertyMap;
return $this;
}
public function mapModelToTable(Concept\Model $model): array
{
$data = [];
foreach ($this->map as $columnName => $propertyMap) {
$data[$columnName] = $propertyMap->mapToTable($model);
}
return $data;
}
public function mapTableToModel(array $data, Concept\Model $model): Concept\Model
{
foreach ($this->map as $propertyMap) {
$propertyMap->map($model, $data);
}
return $model;
}
}

View File

@ -1,63 +0,0 @@
<?php
namespace ProVM\Implement\Model\Mapper;
use Closure;
use Exception;
use ProVM\Concept\Model;
class PropertyMap
{
protected string $column;
protected string $property;
protected Closure $callback;
protected mixed $defaultValue;
public function setProperty(string $property): PropertyMap
{
$this->property = $property;
return $this;
}
public function setColumn(string $column): PropertyMap
{
$this->column = $column;
return $this;
}
public function setCallback(Closure $callback): PropertyMap
{
$this->callback = $callback;
return $this;
}
public function setDefaultValue(mixed $defaultValue): PropertyMap
{
$this->defaultValue = $defaultValue;
return $this;
}
public function map(Model $model, array $data): Model
{
$property = $this->property ?? $this->column;
if (isset($this->callback)) {
try {
$model->{$property} = call_user_func_array($this->callback, $data);
} catch (Exception) {
if (!isset($data[$this->column])) {
$model->{$property} = $this->defaultValue;
} else {
$model->{$property} = $data[$this->column];
}
}
return $model;
}
if (!isset($data[$this->column])) {
$model->{$property} = $this->defaultValue;
} else {
$model->{$property} = $data[$this->column];
}
return $model;
}
public function mapToTable(Model $model): mixed
{
$property = $this->property ?? $this->column;
return $model->{$property} ?? $this->defaultValue;
}
}