14 Commits

Author SHA1 Message Date
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
2 changed files with 30 additions and 7 deletions

View File

@ -37,7 +37,7 @@ abstract class Model extends BaseModel implements ModelInterface {
} }
return $definitions; return $definitions;
} }
public function parentOf(string $child_model_class, array $relation_definitions): array { public function parentOf(string $child_model_class, array $relation_definitions): ?array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [ $relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY, Model::SELF_KEY,
Model::CHILD_KEY Model::CHILD_KEY
@ -54,7 +54,7 @@ abstract class Model extends BaseModel implements ModelInterface {
]) ])
->many(); ->many();
} }
public function childOf(string $parent_model_class, array $relation_definitions): ModelInterface { public function childOf(string $parent_model_class, array $relation_definitions): ?ModelInterface {
$relation_definitions = $this->checkDefinitions($relation_definitions, [ $relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY, Model::SELF_KEY,
Model::PARENT_KEY Model::PARENT_KEY
@ -72,7 +72,7 @@ abstract class Model extends BaseModel implements ModelInterface {
]) ])
->one(); ->one();
} }
public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): array { public function siblingOf(string $sibling_model_class, string $connecting_table, array $relation_definitions): ?array {
$relation_definitions = $this->checkDefinitions($relation_definitions, [ $relation_definitions = $this->checkDefinitions($relation_definitions, [
Model::SELF_KEY, Model::SELF_KEY,
Model::SIBLING_KEY, Model::SIBLING_KEY,

View File

@ -22,11 +22,25 @@ class Model {
} }
return $this; 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;
}
}
return BaseModel::factory($model_class)->create($data);
}
protected $class; protected $class;
public function find(string $model_class): Model { public function find(string $model_class): Model {
if (!class_exists($model_class)) { if (!class_exists($model_class)) {
throw new \InvalidArgumentException('El modelo ' . $model_class . ' no existe.'); throw new \InvalidArgumentException('El modelo ' . $model_class . ' no existe.');
} }
$this->reset();
$this->class = $model_class; $this->class = $model_class;
return $this; return $this;
} }
@ -328,20 +342,29 @@ class Model {
return $orm->offset($this->offset); return $orm->offset($this->offset);
} }
public function one(): ModelInterface { public function one($id = null): ?ModelInterface {
$result = $this->build()->findOne(); $result = $this->build()->findOne($id);
if (!$result) {
return null;
}
$result->setFactory($this); $result->setFactory($this);
return $result; return $result;
} }
public function many(): array { public function many(): ?array {
$results = $this->build()->findMany(); $results = $this->build()->findMany();
if (!$results) {
return null;
}
foreach ($results as &$r) { foreach ($results as &$r) {
$r->setFactory($this); $r->setFactory($this);
} }
return $results; return $results;
} }
public function array(): array { public function array(): ?array {
$results = $this->build()->findArray(); $results = $this->build()->findArray();
if (!$results) {
return null;
}
return $results; return $results;
} }