getDbo() публичный Метод

Get the database connection associated with this data Model
public getDbo ( ) : JDatabaseDriver
Результат JDatabaseDriver
Пример #1
0
 public function onAfterSave(DataModel &$model)
 {
     if (!$model->hasField('asset_id') || !$model->isAssetsTracked()) {
         return true;
     }
     $assetFieldAlias = $model->getFieldAlias('asset_id');
     $currentAssetId = $model->getFieldValue('asset_id');
     unset($model->{$assetFieldAlias});
     // Create the object used for inserting/udpating data to the database
     $fields = $model->getTableFields();
     // Let's remove the asset_id field, since we unset the property above and we would get a PHP notice
     if (isset($fields[$assetFieldAlias])) {
         unset($fields[$assetFieldAlias]);
     }
     // Asset Tracking
     $parentId = $model->getAssetParentId();
     $name = $model->getAssetName();
     $title = $model->getAssetTitle();
     $asset = \JTable::getInstance('Asset');
     $asset->loadByName($name);
     // Re-inject the asset id.
     $this->{$assetFieldAlias} = $asset->id;
     // Check for an error.
     $error = $asset->getError();
     // Since we are using JTable, there is no way to mock it and test for failures :(
     // @codeCoverageIgnoreStart
     if ($error) {
         throw new \Exception($error);
     }
     // @codeCoverageIgnoreEnd
     // Specify how a new or moved node asset is inserted into the tree.
     // Since we're unsetting the table field before, this statement is always true...
     if (empty($model->{$assetFieldAlias}) || $asset->parent_id != $parentId) {
         $asset->setLocation($parentId, 'last-child');
     }
     // Prepare the asset to be stored.
     $asset->parent_id = $parentId;
     $asset->name = $name;
     $asset->title = $title;
     if ($model->getRules() instanceof \JAccessRules) {
         $asset->rules = (string) $model->getRules();
     }
     // Since we are using JTable, there is no way to mock it and test for failures :(
     // @codeCoverageIgnoreStart
     if (!$asset->check() || !$asset->store()) {
         throw new \Exception($asset->getError());
     }
     // @codeCoverageIgnoreEnd
     // Create an asset_id or heal one that is corrupted.
     if (empty($model->{$assetFieldAlias}) || $currentAssetId != $model->{$assetFieldAlias} && !empty($model->{$assetFieldAlias})) {
         // Update the asset_id field in this table.
         $model->{$assetFieldAlias} = (int) $asset->id;
         $k = $model->getKeyName();
         $db = $model->getDbo();
         $query = $db->getQuery(true)->update($db->qn($model->getTableName()))->set($db->qn($assetFieldAlias) . ' = ' . (int) $model->{$assetFieldAlias})->where($db->qn($k) . ' = ' . (int) $model->{$k});
         $db->setQuery($query)->execute();
     }
     return true;
 }
Пример #2
0
 /**
  * @param   DataModel  $model
  * @param   \stdClass  $dataObject
  */
 public function onBeforeCreate(&$model, &$dataObject)
 {
     // Handle the created_on field
     if ($model->hasField('created_on')) {
         $nullDate = $model->getDbo()->getNullDate();
         $created_on = $model->getFieldValue('created_on');
         if (empty($created_on) || $created_on == $nullDate) {
             $model->setFieldValue('created_on', $model->getContainer()->platform->getDate()->toSql(false, $model->getDbo()));
             $createdOnField = $model->getFieldAlias('created_on');
             $dataObject->{$createdOnField} = $model->getFieldValue('created_on');
         }
     }
     // Handle the created_by field
     if ($model->hasField('created_by')) {
         $created_by = $model->getFieldValue('created_by');
         if (empty($created_by)) {
             $model->setFieldValue('created_by', $model->getContainer()->platform->getUser()->id);
             $createdByField = $model->getFieldAlias('created_by');
             $dataObject->{$createdByField} = $model->getFieldValue('created_by');
         }
     }
 }
Пример #3
0
 /**
  * @param   DataModel  $model
  * @param   \stdClass  $dataObject
  */
 public function onBeforeUpdate(&$model, &$dataObject)
 {
     // Make sure we're not modifying a locked record
     $userId = $model->getContainer()->platform->getUser()->id;
     $isLocked = $model->isLocked($userId);
     if ($isLocked) {
         return;
     }
     // Handle the modified_on field
     if ($model->hasField('modified_on')) {
         $model->setFieldValue('modified_on', $model->getContainer()->platform->getDate()->toSql(false, $model->getDbo()));
         $modifiedOnField = $model->getFieldAlias('modified_on');
         $dataObject->{$modifiedOnField} = $model->getFieldValue('modified_on');
     }
     // Handle the modified_by field
     if ($model->hasField('modified_by')) {
         $model->setFieldValue('modified_by', $userId);
         $modifiedByField = $model->getFieldAlias('modified_by');
         $dataObject->{$modifiedByField} = $model->getFieldValue('modified_by');
     }
 }