From b6ad16cbd2092d76d4fed03d37a77d29b5b38f00 Mon Sep 17 00:00:00 2001 From: emkael Date: Fri, 26 Feb 2016 14:59:34 +0100 Subject: * database connection setup in PHP app --- app/php/application.xml | 31 +++++++------------------- app/php/db/DBConnection.php | 33 +++++++++++++++++++++++++++ app/php/db/DBModule.php | 45 +++++++++++++++++++++++++++++++++++++ app/php/db/DBTransaction.php | 53 ++++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 139 insertions(+), 23 deletions(-) create mode 100644 app/php/db/DBConnection.php create mode 100644 app/php/db/DBModule.php create mode 100644 app/php/db/DBTransaction.php (limited to 'app') diff --git a/app/php/application.xml b/app/php/application.xml index 98f3af5..4aa2f30 100644 --- a/app/php/application.xml +++ b/app/php/application.xml @@ -1,39 +1,24 @@ - - - - - - + + + - - - - - diff --git a/app/php/db/DBConnection.php b/app/php/db/DBConnection.php new file mode 100644 index 0000000..4fb18c8 --- /dev/null +++ b/app/php/db/DBConnection.php @@ -0,0 +1,33 @@ +setTransactionClass('Application.Code.DBTransaction'); + parent::__construct($dsn, $username, $password, $charset); + } + + private $_transaction = NULL; + public function getCurrentTransaction() { + if (!$this->_transaction->getActive()) { + $this->_transaction = NULL; + } + return $this->_transaction; + } + + public function beginTransaction() { + if ($this->_transaction && $this->_transaction->getActive()) { + $this->_transaction->beginNestedTransaction(); + } + else { + $this->_transaction = parent::beginTransaction(); + } + return $this->_transaction; + } + +} + +?> diff --git a/app/php/db/DBModule.php b/app/php/db/DBModule.php new file mode 100644 index 0000000..3622db0 --- /dev/null +++ b/app/php/db/DBModule.php @@ -0,0 +1,45 @@ +setConnectionClass('Application.db.DBConnection'); + $config = json_decode(file_get_contents( + realpath( + $this->getApplication()->getBasePath() + . DIRECTORY_SEPARATOR + . $this->_config + ) + )); + $newXML = new TXmlElement('module'); + foreach ($xml->getAttributes() as $attr => $val) { + $newXML->setAttribute($attr, $val); + } + $dbXML = new TXmlElement('database'); + if (isset($config->cset)) { + $dbXML->setAttribute('Charset', $config->cset); + } + $dbXML->setAttribute('Username', $config->user); + $dbXML->setAttribute('Password', $config->pass); + $dbXML->setAttribute( + 'ConnectionString', + sprintf( + '%s:host=%s;dbname=%s', + $config->type, $config->host, $config->name + ) + ); + $newXML->Elements[] = $dbXML; + parent::init($newXML); + } + + public function setConfig($config) { + $this->_config = TPropertyValue::ensureString($config); + } + +} + +?> diff --git a/app/php/db/DBTransaction.php b/app/php/db/DBTransaction.php new file mode 100644 index 0000000..b176453 --- /dev/null +++ b/app/php/db/DBTransaction.php @@ -0,0 +1,53 @@ +getActive()) { + $this->_nestedCount++; + } + } + + public function commit() { + if ($this->_rolledBack) { + $childTransaction = (bool)($this->_nestedCount); + $this->rollback(); + if (!$childTransaction) { + throw new TDbException('Nested transaction was rolled back, unable to commit.'); + } + } + else { + if ($this->_nestedCount) { + $this->_nestedCount--; + } + else { + parent::commit(); + } + } + } + + public function rollback() { + if (!$this->getActive()) { + $this->_nestedCount = 0; + return; + } + if ($this->_nestedCount) { + $this->_rolledBack = TRUE; + $this->_nestedCount--; + } + else { + parent::rollback(); + $this->_nestedCount = 0; + $this->_rolledBack = FALSE; + } + } + +} + +?> -- cgit v1.2.3