42 Commits

Author SHA1 Message Date
022ba575b7 Merge branch 'develop' into master 2021-06-04 21:15:26 -04:00
643c3e714f FIX: Find where in add 2021-05-23 21:27:13 -04:00
db2864395c FIX: Factory for find 2021-05-23 21:07:48 -04:00
1cd06d5fe6 Add and Edit Model 2021-05-23 21:03:10 -04:00
c913f65b91 Considera leer el dato y correccion en los nombres de los metodos 2021-03-16 00:22:13 -03:00
244d8cc414 FIX: null cases & method name 2021-03-16 00:19:51 -03:00
c8a7781c88 Merge branch 'develop' 2021-03-15 11:17:11 -03:00
630c971b45 Date traits 2021-03-15 11:14:10 -03:00
1505539e61 Merge branch 'develop' into master 2021-03-09 00:19:55 -03:00
c441d41a02 FIX: Not through enough 2021-03-09 00:19:32 -03:00
3087a48c43 Merge branch 'develop' into master 2021-03-09 00:15:12 -03:00
3aed13e6a0 FIX: usar correcta descripcion 2021-03-09 00:14:31 -03:00
43f545516d Merge branch 'develop' 2020-08-04 01:33:09 -04:00
4d64143dbc FIX: No se configuraba la creacion de nuevo modelo 2020-08-04 01:32:59 -04:00
b757ed19b2 Merge branch 'develop' 2020-08-03 23:54:16 -04:00
1dc21d8fb7 FIX: Interface differences 2020-08-03 23:54:07 -04:00
9dc71e4d77 Merge branch 'develop' 2020-08-03 23:51:05 -04:00
65bec43b45 FIX: Herencia de cambios anteriores 2020-08-03 23:50:58 -04:00
c6806a1c62 Merge branch 'develop' 2020-08-03 23:42:11 -04:00
5f3f6b72e5 FIX: Return null 2020-08-03 23:42:01 -04:00
6fd19a11be Merge branch 'develop' 2020-08-03 23:38:41 -04:00
a1466143b5 FIX: Type hint 2020-08-03 23:38:30 -04:00
7c727d93e9 Merge branch 'develop' 2020-08-03 23:27:45 -04:00
a8d548c0c4 Si existe duplicado avisa 2020-08-03 23:27:34 -04:00
e02b8c4063 Merge branch 'develop' 2020-08-03 23:17:38 -04:00
f03df583d7 FIX: Retorno de Factory::create 2020-08-03 23:17:29 -04:00
89d1db7a7e Merge branch 'develop' 2020-08-03 23:10:57 -04:00
17453427a2 Id en busqueda de 1 y creacion de nuevo modelo 2020-08-03 23:10:47 -04:00
8dc0a27fd9 Merge branch 'develop' 2020-08-03 22:07:24 -04:00
5b1a61cd3b FIX: not reseting 2020-08-03 22:07:12 -04:00
ae172b902c Merge branch 'develop' 2020-08-03 16:25:19 -04:00
d3cb68c5ca Form alias para Define 2020-08-03 16:25:05 -04:00
7f81b987c9 Merge branch 'develop' 2020-07-24 12:06:16 -04:00
0a46604e0c FIX: uso de nombre de variable equivocada en fabrica 2020-07-24 12:06:06 -04:00
af801e769f Merge branch 'develop' 2020-07-24 11:58:16 -04:00
e9bee7fa48 FIX: nombres de variables 2020-07-24 11:58:09 -04:00
c40baaad3f Merge branch 'develop' 2020-07-24 11:47:39 -04:00
ac019aac3f FIX: bad return value 2020-07-24 11:47:25 -04:00
a82fdce64b Merge branch 'develop' 2020-07-22 23:08:52 -04:00
86ffb0b84c FIX 2020-07-22 23:08:34 -04:00
8126b1f67d Merge branch 'develop' 2020-07-22 22:57:48 -04:00
7899b9f6c8 FIX: Define 2020-07-22 22:56:40 -04:00
7 changed files with 242 additions and 134 deletions

View File

@ -1,14 +1,159 @@
<?php
namespace ProVM\Common\Alias;
use \Model as BaseModel;
use ProVM\Common\Define\Model as ModelInterface;
use ProVM\Common\Factory\Model as ModelFactory;
interface Model {
public function getTable(): string;
public function setFactory(ModelFactory $factory): Model;
public function parentOf(string $child_model_class, array $relation_definitions): array;
public function childOf(string $parent_model_class, array $relation_definitions): Model;
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): array;
abstract class Model extends BaseModel implements ModelInterface {
const SELF_KEY = 'self_key';
const PARENT_KEY = 'parent_key';
const CHILD_KEY = 'child_key';
const SIBLING_KEY = 'sibling_key';
const SELF_CONNECT_KEY = 'self_connect_key';
const SIBLING_CONNECT_KEY = 'sibling_connect_key';
public function toArray(): array;
public function getTable(): string {
return static::$_table;
}
protected $factory;
public function setFactory(ModelFactory $factory): ModelInterface {
$this->factory = $factory;
return $this;
}
protected function checkDefinitions(array $definitions, array $required, array $default) {
foreach ($default as $key => $value) {
if (!isset($definitions[$key])) {
$definitions[$key] = $value;
}
}
foreach ($required as $definition) {
if (!isset($definitions[$definition])) {
$trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1);
throw new \InvalidArgumentException($definition . ' is required for ' . $trace[1]['function'] . ' in ' . get_called_class());
}
}
return $definitions;
}
public function parentOf(string $child_model_class, array $relation_definitions): ?array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::CHILD_KEY
], [
Model::SELF_KEY => 'id'
]);
return $this->factory
->find($child_model_class)
->where([
[
$relation_definitions[Model::CHILD_KEY],
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->many();
}
public function childOf(string $parent_model_class, array $relation_definitions): ?ModelInterface {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::PARENT_KEY
], [
Model::PARENT_KEY => 'id'
]);
$parent_table = (new $parent_model_class())->getTable();
return $this->factory
->find($parent_model_class)
->where([
[
$relation_definitions[Model::PARENT_KEY],
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->one();
}
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): ?array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::SIBLING_KEY,
Model::SELF_CONNECT_KEY,
Model::SIBLING_CONNECT_KEY
], [
Model::SELF_KEY => 'id',
Model::SIBLING_KEY => 'id'
]);
$sibling_table = (new $sibling_model_class())->getTable();
return $this->find($sibling_model_class)
->select([
[
$sibling_table,
'*'
],
[
$connecting_table,
'*'
]
])
->join([
[
$connecting_table,
implode('.', [
$connecting_table,
$relation_definitions[Model::SIBLING_CONNECT_KEY]
]),
implode('.', [
$sibling_table,
$relation_definitions[Model::SIBLING_KEY]
])
]
])
->where([
[
implode('.', [
$connecting_table,
$relation_definitions[Model::SELF_CONNECT_KEY]
]),
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->many();
}
public function toArray(): array {
return $this->asArray();
}
protected static function parseInput($input): array {
return array_intersect_key((array) $input, array_combine(self::$fields, self::$fields));
}
public static function add(ModelFactory $factory, $input): bool {
$data = self::parseInput($input);
$class = get_called_class();
if (method_exists($class, 'find')) {
$obj = self::find($factory, $input);
} else {
$where = $data;
$where = array_values(array_walk($where, function(&$item, $key) {
$item = [$key, $item];
}));
$obj = $factory->find($class)->where($where)->one();
}
if ($obj === false) {
$obj = $factory->create($class, $data);
return $obj->save();
}
return false;
}
public function edit($input): bool {
$data = self::parseInput($input);
foreach (self::$fields as $field) {
if ($this->{$field} != $data[$field]) {
$this->{$field} = $data[$field];
}
}
if ($this->isDirty()) {
return $this->save();
}
return false;
}
}

View File

@ -1,124 +1,17 @@
<?php
namespace ProVM\Common\Define;
use \Model as BaseModel;
use ProVM\Common\Alias\Model as ModelInterface;
use ProVM\Common\Factory\Model as ModelFactory;
abstract class Model extends BaseModel implements ModelInterface {
const SELF_KEY = 'self_key';
const PARENT_KEY = 'parent_key';
const CHILD_KEY = 'child_key';
const SIBLING_KEY = 'sibling_key';
const SELF_CONNECT_KEY = 'self_connect_key';
const SIBLING_CONNECT_KEY = 'sibling_connect_key';
interface Model {
public function getTable(): string;
public function setFactory(ModelFactory $factory): Model;
public function parentOf(string $child_model_class, array $relation_definitions): ?array;
public function childOf(string $parent_model_class, array $relation_definitions): ?Model;
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): ?array;
public function getTable() {
return static::$_table;
}
public function toArray(): array;
protected $factory;
public function setFactory(ModelFactory $factory): ModelInterface {
$this->factory = $factory;
return $this;
}
protected function checkDefinitions(array $definitions, array $required, array $default) {
foreach ($default as $key => $value) {
if (!isset($definitions[$key])) {
$definitions[$key] = $value;
}
}
foreach ($required as $definition) {
if (!isset($definitions[$definition])) {
$trace = debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 1);
throw new \InvalidArgumentException($definition . ' is required for ' . $trace[1]['function'] . ' in ' . get_called_class());
}
}
return $definitions;
}
public function parentOf(string $child_model_class, array $relation_definitions): array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::CHILD_KEY
], [
Model::SELF_KEY => 'id'
]);
return $this->factory
->find($child_model_class)
->where([
[
$relation_definitions[Model::CHILD_KEY],
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->many();
}
public function childOf(string $parent_model_class, array $relation_definitions): ModelInterface {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::PARENT_KEY
], [
Model::PARENT_KEY => 'id'
]);
$parent_table = (new $parent_class())->getTable();
return $this->factory
->find($parent_model_class)
->wherer([
[
$relation_definitions[Model::PARENT_KEY],
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->one();
}
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY,
Model::SIBLING_KEY,
Model::SELF_CONNECT_KEY,
Model::SIBLING_CONNECT_KEY
], [
Model::SELF_KEY => 'id',
Model::SIBLING_KEY => 'id'
]);
$sibling_table = (new $sibling_class())->getTable();
return $this->find($sibling_model_class)
->select([
[
$sibling_table,
'*'
],
[
$connecting_table,
'*'
]
])
->join([
[
$connecting_table,
implode('.', [
$connecting_table,
$relation_definitions[Model::SIBLING_CONNECT_KEY]
]),
implode('.', [
$sibling_table,
$relation_definitions[Model::SIBLING_KEY]
])
]
])
->where([
[
implode('.', [
$connecting_table,
$relation_definitions[Model::SELF_CONNECT_KEY]
]),
$this->{$relation_definitions[Model::SELF_KEY]}
]
])
->many();
}
public function toArray(): array {
return $this->asArray();
}
public static function add(ModelFactory $factory, $input): bool;
public function edit($input): bool;
}

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait Date {
public function date(\DateTime $date = null) {
if ($date === null) {
return Carbon::parse($this->date);
}
$this->date = $data->format('Y-m-d');
}
}

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait DateTime {
public function dateTime(\DateTime $date_time = null) {
if ($date_time === null) {
return Carbon::parse($this->date_time);
}
$this->date_time = $date_time->format('c');
}
}

View File

@ -0,0 +1,13 @@
<?php
namespace ProVM\Common\Define\Model;
use Carbon\Carbon;
trait Time {
public function time(\DateTime $time = null) {
if ($time === null) {
return Carbon::parse($this->time);
}
$this->time = $time->format('H:i:s e');
}
}

View File

@ -3,7 +3,7 @@ namespace ProVM\Common\Factory;
use ORM;
use Model as BaseModel;
use ProVM\Common\Alias\Model as ModelInterface;
use ProVM\Common\Define\Model as ModelInterface;
class Model {
public function reset(): Model {
@ -22,11 +22,27 @@ class Model {
}
return $this;
}
public function create(string $model_class, array $data = null): ModelInterface {
if ($data !== null) {
$model = $this->find($model_class);
foreach ($data as $f => $v) {
$model = $model->where([[$f, $v]]);
}
$model = $model->one();
if ($model !== null) {
return $model;
}
}
$model = BaseModel::factory($model_class)->create($data);
$model->setFactory($this);
return $model;
}
protected $class;
public function find(string $model_class): Model {
if (!class_exists($model_class)) {
throw new \InvalidArgumentException('El modelo ' . $model_class . ' no existe.');
}
$this->reset();
$this->class = $model_class;
return $this;
}
@ -79,14 +95,14 @@ class Model {
}
foreach ($conditions as $c) {
$cond = (object) [
'column' => $j['column'] ?? $j[0],
'value' => $j['value'] ?? $j[1],
'sym' => strtolower($j['sym'] ?? ($j[2] ?? '=')),
'type' => strtolower($j['type']) ?? ''
'column' => $c['column'] ?? $c[0],
'value' => $c['value'] ?? $c[1],
'sym' => strtolower($c['sym'] ?? ($c[2] ?? '=')),
'type' => strtolower($c['type']) ?? ''
];
$this->conditions []= $cond;
}
return $this->conditions;
return $this;
}
protected $grouping;
public function group($groups): Model {
@ -328,20 +344,29 @@ class Model {
return $orm->offset($this->offset);
}
public function one(): ModelInterface {
$result = $this->build()->findOne();
public function one($id = null): ?ModelInterface {
$result = $this->build()->findOne($id);
if (!$result) {
return null;
}
$result->setFactory($this);
return $result;
}
public function many(): array {
public function many(): ?array {
$results = $this->build()->findMany();
if (!$results) {
return null;
}
foreach ($results as &$r) {
$r->setFactory($this);
}
return $results;
}
public function array(): array {
public function array(): ?array {
$results = $this->build()->findArray();
if (!$results) {
return null;
}
return $results;
}

6
common/Form/Model.php Normal file
View File

@ -0,0 +1,6 @@
<?php
namespace ProVM\Common\Form;
use ProVM\Common\Alias\Model as BaseModel;
abstract class Model extends BaseModel {}