Merge pull request #36 from Orange-Management/datamapper-static

Making datamapper static
This commit is contained in:
Dennis Eichhorn 2016-05-14 14:59:58 +02:00
commit f18d9e953a
2 changed files with 151 additions and 109 deletions

View File

@ -43,7 +43,7 @@ interface DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function create($obj); public static function create($obj);
/** /**
* Update data. * Update data.
@ -87,7 +87,7 @@ interface DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function find(...$columns) : Builder; public static function find(...$columns) : Builder;
/** /**
* List data. * List data.

View File

@ -32,8 +32,9 @@ use phpOMS\DataStorage\DataMapperInterface;
* @link http://orange-management.com * @link http://orange-management.com
* @since 1.0.0 * @since 1.0.0
*/ */
abstract class DataMapperAbstract implements DataMapperInterface class DataMapperAbstract //implements DataMapperInterface
{ {
protected static $CLASS = __CLASS__;
/** /**
* Database connection. * Database connection.
@ -41,7 +42,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @var \phpOMS\DataStorage\Database\Connection\ConnectionAbstract * @var \phpOMS\DataStorage\Database\Connection\ConnectionAbstract
* @since 1.0.0 * @since 1.0.0
*/ */
protected $db = null; protected static $db = null;
/** /**
* Overwriting extended values. * Overwriting extended values.
@ -137,7 +138,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @var array[] * @var array[]
* @since 1.0.0 * @since 1.0.0
*/ */
protected $fields = []; protected static $fields = [];
/** /**
* Extended value collection. * Extended value collection.
@ -145,7 +146,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @var array * @var array
* @since 1.0.0 * @since 1.0.0
*/ */
protected $collection = [ protected static $collection = [
'primaryField' => [], 'primaryField' => [],
'createdAt' => [], 'createdAt' => [],
'columns' => [], 'columns' => [],
@ -159,15 +160,30 @@ abstract class DataMapperAbstract implements DataMapperInterface
/** /**
* Constructor. * Constructor.
* *
* @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com>
*/
private function __construct() {}
/**
* Clone.
*
* @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com>
*/
private function __clone() {}
/**
* Set database connection.
*
* @param ConnectionAbstract $con Database connection * @param ConnectionAbstract $con Database connection
* *
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function __construct(ConnectionAbstract $con) public static function setConnection(ConnectionAbstract $con)
{ {
$this->db = $con; self::$db = $con;
$this->extend($this);
} }
/** /**
@ -178,7 +194,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getPrimaryField() : string public static function getPrimaryField() : string
{ {
return static::$primaryField; return static::$primaryField;
} }
@ -191,7 +207,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getTable() : string public static function getTable() : string
{ {
return static::$table; return static::$table;
} }
@ -206,20 +222,20 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
private function extend($class) private static function extend($class)
{ {
/* todo: have to implement this in the queries, so far not used */ /* todo: have to implement this in the queries, so far not used */
$this->collection['primaryField'][] = $class::$primaryField; self::$collection['primaryField'][] = $class::$primaryField;
$this->collection['createdAt'][] = $class::$createdAt; self::$collection['createdAt'][] = $class::$createdAt;
$this->collection['columns'][] = $class::$columns; self::$collection['columns'][] = $class::$columns;
$this->collection['hasMany'][] = $class::$hasMany; self::$collection['hasMany'][] = $class::$hasMany;
$this->collection['hasOne'][] = $class::$hasOne; self::$collection['hasOne'][] = $class::$hasOne;
$this->collection['ownsMany'][] = $class::$ownsMany; self::$collection['ownsMany'][] = $class::$ownsMany;
$this->collection['ownsOne'][] = $class::$ownsOne; self::$collection['ownsOne'][] = $class::$ownsOne;
$this->collection['table'][] = $class::$table; self::$collection['table'][] = $class::$table;
if (($parent = get_parent_class($class)) !== false && !$class::$overwrite) { if (($parent = get_parent_class($class)) !== false && !$class::$overwrite) {
$this->extend($parent); self::extend($parent);
} }
} }
@ -229,7 +245,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function save() public static function save()
{ {
} }
@ -239,7 +255,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function delete() public static function delete()
{ {
} }
@ -253,18 +269,39 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function with(...$objects) public static function with(...$objects)
{ {
// todo: how to handle with of parent objects/extends/relations // todo: how to handle with of parent objects/extends/relations
$this->fields = $objects; self::$fields = $objects;
return $this; return __CLASS__;
} }
public function clear() public static function clear()
{ {
$this->fields = []; self::$overwrite = true;
self::$primaryField = '';
self::$createdAt = '';
self::$columns = [];
self::$hasMany = [];
self::$ownsMany = [];
self::$hasOne = [];
self::$isExtending = [];
self::$extends = [];
self::$ownsOne = [];
self::$table = '';
self::$fields = [];
self::$collection = [
'primaryField' => [],
'createdAt' => [],
'columns' => [],
'hasMany' => [],
'hasOne' => [],
'ownsMany' => [],
'ownsOne' => [],
'table' => [],
];
} }
/** /**
@ -277,14 +314,16 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function find(...$columns) : Builder public static function find(...$columns) : Builder
{ {
self::extend(__CLASS__);
if (count($columns) === 0) { if (count($columns) === 0) {
$columns = [static::$table . '.*']; $columns = [static::$table . '.*'];
} }
$query = new Builder($this->db); $query = new Builder(self::$db);
$query->prefix($this->db->getPrefix()); $query->prefix(self::$db->getPrefix());
return $query->select(...$columns)->from(static::$table); return $query->select(...$columns)->from(static::$table);
} }
@ -302,10 +341,12 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function create($obj, bool $relations = true) public static function create($obj, bool $relations = true)
{ {
$query = new Builder($this->db); self::extend(__CLASS__);
$query->prefix($this->db->getPrefix())
$query = new Builder(self::$db);
$query->prefix(self::$db->getPrefix())
->into(static::$table); ->into(static::$table);
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
@ -315,8 +356,8 @@ abstract class DataMapperAbstract implements DataMapperInterface
/* Create extended */ /* Create extended */
foreach (static::$isExtending as $member => $rel) { foreach (static::$isExtending as $member => $rel) {
/** @var DataMapperAbstract $mapper */ /** @var DataMapperAbstract $mapper */
$mapper = new $rel['mapper']($this->db); $mapper = $rel['mapper'];
$extendedIds[$member] = $mapper->create($obj, $relations); $extendedIds[$member] = $mapper::create($obj, $relations);
} }
foreach ($properties as $property) { foreach ($properties as $property) {
@ -332,7 +373,6 @@ abstract class DataMapperAbstract implements DataMapperInterface
/* only insert if not already inserted */ /* only insert if not already inserted */
/** @var DataMapperAbstract $mapper */ /** @var DataMapperAbstract $mapper */
$mapper = static::$hasOne[$pname]['mapper']; $mapper = static::$hasOne[$pname]['mapper'];
$mapper = new $mapper($this->db);
$relReflectionClass = new \ReflectionClass(get_class($relObj)); $relReflectionClass = new \ReflectionClass(get_class($relObj));
/** @var array $columns */ /** @var array $columns */
@ -342,7 +382,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
$relProperty->setAccessible(false); $relProperty->setAccessible(false);
if (empty($primaryKey)) { if (empty($primaryKey)) {
$primaryKey = $mapper->create($property->getValue($obj)); $primaryKey = $mapper::create($property->getValue($obj));
} }
//$property->setValue($obj, $primaryKey); //$property->setValue($obj, $primaryKey);
@ -377,8 +417,8 @@ abstract class DataMapperAbstract implements DataMapperInterface
// todo: do i have to reverse the accessibility or is there no risk involved here? // todo: do i have to reverse the accessibility or is there no risk involved here?
} }
$this->db->con->prepare($query->toSql())->execute(); self::$db->con->prepare($query->toSql())->execute();
$objId = $this->db->con->lastInsertId(); $objId = self::$db->con->lastInsertId();
// handle relations // handle relations
if ($relations) { if ($relations) {
@ -402,7 +442,6 @@ abstract class DataMapperAbstract implements DataMapperInterface
// todo: only create if object doesn't exists... get primaryKey field, then get member name based on this // todo: only create if object doesn't exists... get primaryKey field, then get member name based on this
// now check if id is null or set. // now check if id is null or set.
$mapper = static::$hasMany[$pname]['mapper']; $mapper = static::$hasMany[$pname]['mapper'];
$mapper = new $mapper($this->db);
$objsIds = []; $objsIds = [];
if (isset(static::$hasMany[$pname]['mapper']) && static::$hasMany[$pname]['mapper'] === static::$hasMany[$pname]['relationmapper']) { if (isset(static::$hasMany[$pname]['mapper']) && static::$hasMany[$pname]['mapper'] === static::$hasMany[$pname]['relationmapper']) {
@ -432,7 +471,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
$relProperty->setAccessible(false); $relProperty->setAccessible(false);
} }
$objsIds[$key] = $mapper->create($value); $objsIds[$key] = $mapper::create($value);
} }
} elseif (is_scalar($temp)) { } elseif (is_scalar($temp)) {
$objsIds = $values; $objsIds = $values;
@ -442,8 +481,8 @@ abstract class DataMapperAbstract implements DataMapperInterface
if (isset(static::$hasMany[$pname]['mapper']) && static::$hasMany[$pname]['mapper'] !== static::$hasMany[$pname]['relationmapper']) { if (isset(static::$hasMany[$pname]['mapper']) && static::$hasMany[$pname]['mapper'] !== static::$hasMany[$pname]['relationmapper']) {
/* is many->many */ /* is many->many */
$relQuery = new Builder($this->db); $relQuery = new Builder(self::$db);
$relQuery->prefix($this->db->getPrefix()) $relQuery->prefix(self::$db->getPrefix())
->into(static::$hasMany[$pname]['table']) ->into(static::$hasMany[$pname]['table'])
->insert(static::$hasMany[$pname]['src'], static::$hasMany[$pname]['dst']); ->insert(static::$hasMany[$pname]['src'], static::$hasMany[$pname]['dst']);
@ -451,7 +490,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
$relQuery->values($src, $objId); $relQuery->values($src, $objId);
} }
$this->db->con->prepare($relQuery->toSql())->execute(); self::$db->con->prepare($relQuery->toSql())->execute();
} }
} }
} }
@ -485,12 +524,14 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function update($obj) public static function update($obj)
{ {
// todo: relations handling (needs to be done first)... updating, deleting or inserting are possible // todo: relations handling (needs to be done first)... updating, deleting or inserting are possible
$query = new Builder($this->db); self::extend(__CLASS__);
$query->prefix($this->db->getPrefix())
$query = new Builder(self::$db);
$query->prefix(self::$db->getPrefix())
->into(static::$table); ->into(static::$table);
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
@ -521,7 +562,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
// todo: do i have to reverse the accessibility or is there no risk involved here? // todo: do i have to reverse the accessibility or is there no risk involved here?
} }
$this->db->con->prepare($query->toSql())->execute(); self::$db->con->prepare($query->toSql())->execute();
} }
/** /**
@ -534,15 +575,15 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populateIterable(array $result) : array public static function populateIterable(array $result) : array
{ {
$row = []; $row = [];
foreach ($result as $element) { foreach ($result as $element) {
if (isset($element[static::$primaryField])) { if (isset($element[static::$primaryField])) {
$row[$element[static::$primaryField]] = $this->populate($element); $row[$element[static::$primaryField]] = self::populate($element);
} else { } else {
$row[] = $this->populate($element); $row[] = self::populate($element);
} }
} }
@ -560,9 +601,9 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populate(array $result, $obj = null) public static function populate(array $result, $obj = null)
{ {
$class = get_class($this); $class = static::class;
$class = str_replace('Mapper', '', $class); $class = str_replace('Mapper', '', $class);
if (count($result) === 0) { if (count($result) === 0) {
@ -576,7 +617,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
$obj = new $class(); $obj = new $class();
} }
return $this->populateAbstract($result, $obj); return self::populateAbstract($result, $obj);
} }
/** /**
@ -593,7 +634,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populateExtending($obj, int $relations = RelationType::ALL) public static function populateExtending($obj, int $relations = RelationType::ALL)
{ {
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
@ -601,8 +642,8 @@ abstract class DataMapperAbstract implements DataMapperInterface
$reflectionProperty = $reflectionClass->getProperty($member); $reflectionProperty = $reflectionClass->getProperty($member);
/** @var DataMapperAbstract $mapper */ /** @var DataMapperAbstract $mapper */
$mapper = new $rel['mapper']($this->db); $mapper = $rel['mapper'];
$mapper->get($reflectionProperty->getValue($obj), $relations, $obj); $mapper::get($reflectionProperty->getValue($obj), $relations, $obj);
} }
} }
@ -617,15 +658,13 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populateManyToMany(array $result, &$obj) public static function populateManyToMany(array $result, &$obj)
{ {
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
foreach ($result as $member => $values) { foreach ($result as $member => $values) {
if ($reflectionClass->hasProperty($member)) { if ($reflectionClass->hasProperty($member)) {
$mapper = static::$hasMany[$member]['mapper']; $mapper = static::$hasMany[$member]['mapper'];
/** @var DataMapperAbstract $mapper */
$mapper = new $mapper($this->db);
$reflectionProperty = $reflectionClass->getProperty($member); $reflectionProperty = $reflectionClass->getProperty($member);
if (!($accessible = $reflectionProperty->isPublic())) { if (!($accessible = $reflectionProperty->isPublic())) {
@ -634,16 +673,16 @@ abstract class DataMapperAbstract implements DataMapperInterface
// relation table vs relation defined in same table as object e.g. comments // relation table vs relation defined in same table as object e.g. comments
if ($values !== false) { if ($values !== false) {
$objects = $mapper->get($values); $objects = $mapper::get($values);
$reflectionProperty->setValue($obj, $objects); $reflectionProperty->setValue($obj, $objects);
} else { } else {
// todo: replace getId() with lookup by primaryKey and the assoziated member variable and get value // todo: replace getId() with lookup by primaryKey and the assoziated member variable and get value
$query = $mapper->find()->where(static::$hasMany[$member]['table'] . '.' . static::$hasMany[$member]['dst'], '=', $obj->getId()); $query = $mapper::find()->where(static::$hasMany[$member]['table'] . '.' . static::$hasMany[$member]['dst'], '=', $obj->getId());
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$results = $sth->fetchAll(\PDO::FETCH_ASSOC); $results = $sth->fetchAll(\PDO::FETCH_ASSOC);
$objects = $mapper->populateIterable($results); $objects = $mapper::populateIterable($results);
$reflectionProperty->setValue($obj, $objects); $reflectionProperty->setValue($obj, $objects);
} }
@ -664,7 +703,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populateOneToOne(&$obj) public static function populateOneToOne(&$obj)
{ {
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
@ -679,9 +718,8 @@ abstract class DataMapperAbstract implements DataMapperInterface
/** @var DataMapperAbstract $mapper */ /** @var DataMapperAbstract $mapper */
$mapper = static::$hasOne[$member]['mapper']; $mapper = static::$hasOne[$member]['mapper'];
$mapper = new $mapper($this->db);
$value = $mapper->get($reflectionProperty->getValue($obj)); $value = $mapper::get($reflectionProperty->getValue($obj));
$reflectionProperty->setValue($obj, $value); $reflectionProperty->setValue($obj, $value);
if (!$accessible) { if (!$accessible) {
@ -704,7 +742,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function populateAbstract(array $result, $obj) public static function populateAbstract(array $result, $obj)
{ {
$reflectionClass = new \ReflectionClass(get_class($obj)); $reflectionClass = new \ReflectionClass(get_class($obj));
@ -751,8 +789,10 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function get($primaryKey, int $relations = RelationType::ALL, $fill = null) public static function get($primaryKey, int $relations = RelationType::ALL, $fill = null)
{ {
self::extend(__CLASS__);
$primaryKey = (array) $primaryKey; $primaryKey = (array) $primaryKey;
$fill = (array) $fill; $fill = (array) $fill;
$obj = []; $obj = [];
@ -765,12 +805,12 @@ abstract class DataMapperAbstract implements DataMapperInterface
next($fill); next($fill);
} }
$obj[$value] = $this->populate($this->getRaw($value), $toFill); $obj[$value] = self::populate(self::getRaw($value), $toFill);
} }
$this->fillRelations($obj, $relations); self::fillRelations($obj, $relations);
$this->clear(); self::clear();
return count($obj) === 1 ? reset($obj) : $obj; return count($obj) === 1 ? reset($obj) : $obj;
} }
@ -785,11 +825,11 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getAll(int $relations = RelationType::ALL) public static function getAll(int $relations = RelationType::ALL)
{ {
$obj = $this->populateIterable($this->getAllRaw()); $obj = self::populateIterable(self::getAllRaw());
$this->fillRelations($obj, $relations); self::fillRelations($obj, $relations);
$this->clear(); self::clear();
return $obj; return $obj;
} }
@ -804,12 +844,12 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function listResults(Builder $query) public static function listResults(Builder $query)
{ {
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
return $this->populateIterable($sth->fetchAll(\PDO::FETCH_ASSOC)); return self::populateIterable($sth->fetchAll(\PDO::FETCH_ASSOC));
} }
/** /**
@ -826,10 +866,12 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getNewest(int $limit = 1, Builder $query = null, int $relations = RelationType::ALL) public static function getNewest(int $limit = 1, Builder $query = null, int $relations = RelationType::ALL)
{ {
$query = $query ?? new Builder($this->db); self::extend(__CLASS__);
$query->prefix($this->db->getPrefix())
$query = $query ?? new Builder(self::$db);
$query->prefix(self::$db->getPrefix())
->select('*') ->select('*')
->from(static::$table) ->from(static::$table)
->limit($limit); /* todo: limit is not working, setting this to 2 doesn't have any effect!!! */ ->limit($limit); /* todo: limit is not working, setting this to 2 doesn't have any effect!!! */
@ -840,14 +882,14 @@ abstract class DataMapperAbstract implements DataMapperInterface
$query->orderBy(static::$table . '.' . static::$columns[static::$primaryField]['name'], 'DESC'); $query->orderBy(static::$table . '.' . static::$columns[static::$primaryField]['name'], 'DESC');
} }
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$results = $sth->fetchAll(\PDO::FETCH_ASSOC); $results = $sth->fetchAll(\PDO::FETCH_ASSOC);
$obj = $this->populateIterable(is_bool($results) ? [] : $results); $obj = self::populateIterable(is_bool($results) ? [] : $results);
$this->fillRelations($obj, $relations); self::fillRelations($obj, $relations);
$this->clear(); self::clear();
return $obj; return $obj;
@ -864,17 +906,17 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getAllByQuery(Builder $query, bool $relations = true) : array public static function getAllByQuery(Builder $query, bool $relations = true) : array
{ {
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$results = $sth->fetchAll(\PDO::FETCH_ASSOC); $results = $sth->fetchAll(\PDO::FETCH_ASSOC);
$results = is_bool($results) ? [] : $results; $results = is_bool($results) ? [] : $results;
$obj = $this->populateIterable($results); $obj = self::populateIterable($results);
$this->fillRelations($obj, $relations); self::fillRelations($obj, $relations);
$this->clear(); self::clear();
return $obj; return $obj;
} }
@ -889,7 +931,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getRandom(int $relations = RelationType::ALL) public static function getRandom(int $relations = RelationType::ALL)
{ {
// todo: implement // todo: implement
} }
@ -905,7 +947,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function fillRelations(array &$obj, int $relations = RelationType::ALL) public static function fillRelations(array &$obj, int $relations = RelationType::ALL)
{ {
$hasMany = count(static::$hasMany) > 0; $hasMany = count(static::$hasMany) > 0;
$hasOne = count(static::$hasOne) > 0; $hasOne = count(static::$hasOne) > 0;
@ -914,17 +956,17 @@ abstract class DataMapperAbstract implements DataMapperInterface
if (($relations !== RelationType::NONE && ($hasMany || $hasOne)) || $isExtending) { if (($relations !== RelationType::NONE && ($hasMany || $hasOne)) || $isExtending) {
foreach ($obj as $key => $value) { foreach ($obj as $key => $value) {
if ($isExtending) { if ($isExtending) {
$this->populateExtending($obj[$key], $relations); self::populateExtending($obj[$key], $relations);
} }
/* loading relations from relations table and populating them and then adding them to the object */ /* loading relations from relations table and populating them and then adding them to the object */
if ($relations !== RelationType::NONE) { if ($relations !== RelationType::NONE) {
if ($hasMany) { if ($hasMany) {
$this->populateManyToMany($this->getManyRaw($key, $relations), $obj[$key]); self::populateManyToMany(self::getManyRaw($key, $relations), $obj[$key]);
} }
if ($hasOne) { if ($hasOne) {
$this->populateOneToOne($obj[$key]); self::populateOneToOne($obj[$key]);
} }
} }
} }
@ -941,15 +983,15 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getRaw($primaryKey) : array public static function getRaw($primaryKey) : array
{ {
$query = new Builder($this->db); $query = new Builder(self::$db);
$query->prefix($this->db->getPrefix()) $query->prefix(self::$db->getPrefix())
->select('*') ->select('*')
->from(static::$table) ->from(static::$table)
->where(static::$table . '.' . static::$primaryField, '=', $primaryKey); ->where(static::$table . '.' . static::$primaryField, '=', $primaryKey);
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$results = $sth->fetch(\PDO::FETCH_ASSOC); $results = $sth->fetch(\PDO::FETCH_ASSOC);
@ -967,14 +1009,14 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getAllRaw() : array public static function getAllRaw() : array
{ {
$query = new Builder($this->db); $query = new Builder(self::$db);
$query->prefix($this->db->getPrefix()) $query->prefix(self::$db->getPrefix())
->select('*') ->select('*')
->from(static::$table); ->from(static::$table);
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$results = $sth->fetchAll(\PDO::FETCH_ASSOC); $results = $sth->fetchAll(\PDO::FETCH_ASSOC);
@ -993,14 +1035,14 @@ abstract class DataMapperAbstract implements DataMapperInterface
* @since 1.0.0 * @since 1.0.0
* @author Dennis Eichhorn <d.eichhorn@oms.com> * @author Dennis Eichhorn <d.eichhorn@oms.com>
*/ */
public function getManyRaw($primaryKey, int $relations = RelationType::ALL) : array public static function getManyRaw($primaryKey, int $relations = RelationType::ALL) : array
{ {
$result = []; $result = [];
foreach (static::$hasMany as $member => $value) { foreach (static::$hasMany as $member => $value) {
if ($value['mapper'] !== $value['relationmapper']) { if ($value['mapper'] !== $value['relationmapper']) {
$query = new Builder($this->db); $query = new Builder(self::$db);
$query->prefix($this->db->getPrefix()); $query->prefix(self::$db->getPrefix());
if ($relations === RelationType::ALL) { if ($relations === RelationType::ALL) {
$query->select($value['table'] . '.' . $value['src']) $query->select($value['table'] . '.' . $value['src'])
@ -1027,7 +1069,7 @@ abstract class DataMapperAbstract implements DataMapperInterface
*/ */
} }
$sth = $this->db->con->prepare($query->toSql()); $sth = self::$db->con->prepare($query->toSql());
$sth->execute(); $sth->execute();
$result[$member] = $sth->fetchAll(\PDO::FETCH_COLUMN); $result[$member] = $sth->fetchAll(\PDO::FETCH_COLUMN);
} else { } else {