diff options
| author | Simon | 2011-01-31 10:00:46 +0100 |
|---|---|---|
| committer | Simon | 2011-01-31 10:00:46 +0100 |
| commit | c72be928a23151bfe248da3b198bfbee79063261 (patch) | |
| tree | 30ee0acb26bf81c2a0b5c34b92341b1cb5d8e9b0 /application/models | |
| parent | password_salt bei pbs_person hinzugefügt (diff) | |
| download | pbs2-c72be928a23151bfe248da3b198bfbee79063261.tar.gz pbs2-c72be928a23151bfe248da3b198bfbee79063261.tar.xz pbs2-c72be928a23151bfe248da3b198bfbee79063261.zip | |
Änderungen am ClientMapper und Client
Diffstat (limited to 'application/models')
| -rw-r--r-- | application/models/Client.php | 4 | ||||
| -rw-r--r-- | application/models/ClientMapper.php | 65 |
2 files changed, 66 insertions, 3 deletions
diff --git a/application/models/Client.php b/application/models/Client.php index 0fb5f64..9995bfe 100644 --- a/application/models/Client.php +++ b/application/models/Client.php @@ -44,11 +44,11 @@ class Application_Model_Client } - public function getClientID() + public function getID() { return $this->_clientID; } - public function setClientID($_clientID) + public function setID($_clientID) { $this->_clientID = $_clientID; } diff --git a/application/models/ClientMapper.php b/application/models/ClientMapper.php index 52465c7..f1e5852 100644 --- a/application/models/ClientMapper.php +++ b/application/models/ClientMapper.php @@ -3,6 +3,69 @@ class Application_Model_ClientMapper { - + protected $_dbTable; + + public function setDbTable($dbTable) + { + if (is_string($dbTable)) { + $dbTable = new $dbTable(); + } + if (!$dbTable instanceof Zend_Db_Table_Abstract) { + throw new Exception('Invalid table data gateway provided'); + } + $this->_dbTable = $dbTable; + return $this; + } + + public function getDbTable() + { + if (null === $this->_dbTable) { + $this->setDbTable('Application_Model_DbTable_Guestbook'); + } + return $this->_dbTable; + } + + public function save(Application_Model_Client $client) + { + $data = array( + 'clientID' => $client->getID(), + 'macadress' => $client->getMacadress(), + 'hardwarehash' => $client->getHardwarehash, + ); + + if (null === ($clientID = $client->getId())) { + unset($data['clientID']); + $this->getDbTable()->insert($data); + } else { + $this->getDbTable()->update($data, array('clientID = ?' => $clientID)); + } + } + + public function find($clientID, Application_Model_Client $client) + { + $result = $this->getDbTable()->find($clientID); + if (0 == count($result)) { + return; + } + $row = $result->current(); + $guestbook->setID($row->clientID) + ->setMacadress($row->macadress) + ->setHardwarehash($row->hardwarehash); + } + + public function fetchAll() + { + $resultSet = $this->getDbTable()->fetchAll(); + $entries = array(); + foreach ($resultSet as $row) { + $entry = new Application_Model_Client(); + $entry->setId($row->clientID) + ->setMacadress($row->macadress) + ->setHardwarehash($row->hardwarehash); + $entries[] = $entry; + } + return $entries; + } } + |
