<?php
+/**
+ * @copyright Copyright (C) 2020, Friendica
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <https://www.gnu.org/licenses/>.
+ *
+ */
namespace Friendica;
* Chainable.
*
* @param array $condition
- * @param array $order An optional array with order information
- * @param int|array $limit Optional limit information
- *
+ * @param array $params
* @return BaseCollection
* @throws \Exception
*/
- public function select(array $condition = [], array $order = [], $limit = null)
+ public function select(array $condition = [], array $params = [])
{
- $models = $this->selectModels($condition, $order, $limit);
+ $models = $this->selectModels($condition, $params);
return new static::$collection_class($models);
}
* Chainable.
*
* @param array $condition
- * @param array $order
+ * @param array $params
* @param int? $max_id
* @param int? $since_id
* @param int $limit
- *
* @return BaseCollection
* @throws \Exception
*/
- public function selectByBoundaries(array $condition = [], array $order = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
+ public function selectByBoundaries(array $condition = [], array $params = [], int $max_id = null, int $since_id = null, int $limit = self::LIMIT)
{
$condition = DBA::collapseCondition($condition);
$boundCondition[] = $since_id;
}
- $models = $this->selectModels($boundCondition, $order, $limit);
+ $params['limit'] = $limit;
+
+ $models = $this->selectModels($boundCondition, $params);
$totalCount = DBA::count(static::$table_name, $condition);
*/
public function update(BaseModel $model)
{
- return $this->dba->update(static::$table_name, $model->toArray(), ['id' => $model->id], $model->getOriginalData());
+ if ($this->dba->update(static::$table_name, $model->toArray(), ['id' => $model->id], $model->getOriginalData())) {
+ $model->resetOriginalData();
+ return true;
+ }
+
+ return false;
}
/**
/**
* @param array $condition Query condition
- * @param array $order An optional array with order information
- * @param int|array $limit Optional limit information
- *
+ * @param array $params Additional query parameters
* @return BaseModel[]
* @throws \Exception
*/
- protected function selectModels(array $condition, array $order = [], $limit = null)
+ protected function selectModels(array $condition, array $params = [])
{
- $params = [];
-
- if (!empty($order)) {
- $params['order'] = $order;
- }
-
- if (!empty($limit)) {
- $params['limit'] = $limit;
- }
-
$result = $this->dba->select(static::$table_name, [], $condition, $params);
/** @var BaseModel $prototype */