123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188 |
- <?php
- /**
- * DB transaction model
- *
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework\DB;
- /**
- * @todo need collect connection by name
- */
- class Transaction
- {
- /**
- * Objects which will be involved to transaction
- *
- * @var array
- */
- protected $_objects = [];
- /**
- * Transaction objects array with alias key
- *
- * @var array
- */
- protected $_objectsByAlias = [];
- /**
- * Callbacks array.
- *
- * @var array
- */
- protected $_beforeCommitCallbacks = [];
- /**
- * Begin transaction for all involved object resources
- *
- * @return $this
- */
- protected function _startTransaction()
- {
- foreach ($this->_objects as $object) {
- $object->getResource()->beginTransaction();
- }
- return $this;
- }
- /**
- * Commit transaction for all resources
- *
- * @return $this
- */
- protected function _commitTransaction()
- {
- foreach ($this->_objects as $object) {
- $object->getResource()->commit();
- }
- return $this;
- }
- /**
- * Rollback transaction
- *
- * @return $this
- */
- protected function _rollbackTransaction()
- {
- foreach ($this->_objects as $object) {
- $object->getResource()->rollBack();
- }
- return $this;
- }
- /**
- * Run all configured object callbacks
- *
- * @return $this
- */
- protected function _runCallbacks()
- {
- foreach ($this->_beforeCommitCallbacks as $callback) {
- call_user_func($callback);
- }
- return $this;
- }
- /**
- * Adding object for using in transaction
- *
- * @param \Magento\Framework\Model\AbstractModel $object
- * @param string $alias
- * @return $this
- */
- public function addObject(\Magento\Framework\Model\AbstractModel $object, $alias = '')
- {
- $this->_objects[] = $object;
- if (!empty($alias)) {
- $this->_objectsByAlias[$alias] = $object;
- }
- return $this;
- }
- /**
- * Add callback function which will be called before commit transactions
- *
- * @param callback $callback
- * @return $this
- */
- public function addCommitCallback($callback)
- {
- $this->_beforeCommitCallbacks[] = $callback;
- return $this;
- }
- /**
- * Initialize objects save transaction
- *
- * @return $this
- * @throws \Exception
- */
- public function save()
- {
- $this->_startTransaction();
- $error = false;
- try {
- foreach ($this->_objects as $object) {
- $object->save();
- }
- } catch (\Exception $e) {
- $error = $e;
- }
- if ($error === false) {
- try {
- $this->_runCallbacks();
- } catch (\Exception $e) {
- $error = $e;
- }
- }
- if ($error) {
- $this->_rollbackTransaction();
- throw $error;
- } else {
- $this->_commitTransaction();
- }
- return $this;
- }
- /**
- * Initialize objects delete transaction
- *
- * @return $this
- * @throws \Exception
- */
- public function delete()
- {
- $this->_startTransaction();
- $error = false;
- try {
- foreach ($this->_objects as $object) {
- $object->delete();
- }
- } catch (\Exception $e) {
- $error = $e;
- }
- if ($error === false) {
- try {
- $this->_runCallbacks();
- } catch (\Exception $e) {
- $error = $e;
- }
- }
- if ($error) {
- $this->_rollbackTransaction();
- throw $error;
- } else {
- $this->_commitTransaction();
- }
- return $this;
- }
- }
|