4 Commits

Author SHA1 Message Date
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
3 changed files with 128 additions and 126 deletions

View File

@ -1,14 +1,125 @@
<?php
namespace ProVM\Common\Alias;
use \Model as BaseModel;
use ProVM\Common\Alias\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();
}
}

View File

@ -1,125 +1,14 @@
<?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(): 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();
}
public function toArray(): array;
}

View File

@ -33,7 +33,9 @@ class Model {
return $model;
}
}
return BaseModel::factory($model_class)->create($data);
$model = BaseModel::factory($model_class)->create($data);
$model->setFactory($this);
return $model;
}
protected $class;
public function find(string $model_class): Model {