From dd9d092c2b479d76858f19e57c481727b86fb0c1 Mon Sep 17 00:00:00 2001 From: Jan Skrasek Date: Mon, 13 Apr 2020 12:32:55 +0200 Subject: [PATCH] mapper: fix accessing possibly uninitialized storage reflection [closes #403] --- src/Mapper/Dbal/DbalMapper.php | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/src/Mapper/Dbal/DbalMapper.php b/src/Mapper/Dbal/DbalMapper.php index ae9f9247..d0c74d8d 100644 --- a/src/Mapper/Dbal/DbalMapper.php +++ b/src/Mapper/Dbal/DbalMapper.php @@ -332,11 +332,12 @@ protected function processMySQLAutoupdate(IEntity $entity, array $args) { assert($this instanceof IPersistAutoupdateMapper); $this->connection->queryArgs($args); + $storageReflection = $this->getStorageReflection(); $primary = []; $id = (array) ($entity->isPersisted() ? $entity->getPersistedId() : $this->connection->getLastInsertedId()); foreach ($entity->getMetadata()->getPrimaryKey() as $key) { - $key = $this->storageReflection->convertEntityToStorageKey($key); + $key = $storageReflection->convertEntityToStorageKey($key); $primary[$key] = array_shift($id); } @@ -349,7 +350,7 @@ protected function processMySQLAutoupdate(IEntity $entity, array $args) if ($row === null) { $entity->onRefresh(null, true); } else { - $data = $this->getStorageReflection()->convertStorageToEntity($row->toArray()); + $data = $storageReflection->convertStorageToEntity($row->toArray()); $entity->onRefresh($data, true); } } @@ -358,11 +359,12 @@ protected function processMySQLAutoupdate(IEntity $entity, array $args) public function remove(IEntity $entity) { $this->beginTransaction(); + $storageReflection = $this->getStorageReflection(); $primary = []; $id = (array) $entity->getPersistedId(); foreach ($entity->getMetadata()->getPrimaryKey() as $key) { - $key = $this->storageReflection->convertEntityToStorageKey($key); + $key = $storageReflection->convertEntityToStorageKey($key); $primary[$key] = array_shift($id); }