File "model.php"
Full Path: /home/vantageo/public_html/cache/cache/cache/cache/cache/cache/.wp-cli/wp-content/plugins/woo-product-filter/classes/model.php
File size: 8.11 KB
MIME-type: text/x-php
Charset: utf-8
<?php
abstract class ModelWpf extends BaseObjectWpf {
protected $_data = array();
protected $_code = '';
protected $_orderBy = '';
protected $_sortOrder = '';
protected $_groupBy = '';
protected $_limit = '';
protected $_where = array();
protected $_stringWhere = '';
protected $_selectFields = '*';
protected $_tbl = '';
protected $_lastGetCount = 0;
protected $_idField = 'id';
protected $_indexes = array();
public function setCode( $code ) {
$this->_code = $code;
}
public function getCode() {
return $this->_code;
}
public function getModule() {
return FrameWpf::_()->getModule( $this->_code );
}
protected function _setTbl( $tbl ) {
$this->_tbl = $tbl;
}
public function setOrderBy( $orderBy ) {
$this->_orderBy = $orderBy;
return $this;
}
public function setIndexes( $indexes ) {
$this->_indexes = $indexes;
}
/**
* ASC, DESC
*/
public function setSortOrder( $sortOrder ) {
$this->_sortOrder = $sortOrder;
return $this;
}
public function setLimit( $limit ) {
$this->_limit = $limit;
return $this;
}
public function setWhere( $where ) {
$this->_where = $where;
return $this;
}
public function addWhere( $where ) {
if (empty($this->_where) && !is_string($where)) {
$this->setWhere( $where );
} elseif (is_array($this->_where) && is_array($where)) {
$this->_where = array_merge($this->_where, $where);
} elseif (is_string($where)) {
if (!isset($this->_where['additionalCondition'])) {
$this->_where['additionalCondition'] = '';
}
if (!empty($this->_where['additionalCondition'])) {
$this->_where['additionalCondition'] .= ' AND ';
}
$this->_where['additionalCondition'] .= $where;
}
return $this;
}
public function setSelectFields( $selectFields ) {
if (is_array($selectFields)) {
$selectFields = implode(',', $selectFields);
}
$this->_selectFields = $selectFields;
return $this;
}
public function groupBy( $groupBy ) {
$this->_groupBy = $groupBy;
return $this;
}
public function getLastGetCount() {
return $this->_lastGetCount;
}
public function getFromTbl( $params = array() ) {
$this->_lastGetCount = 0;
$tbl = isset($params['tbl']) ? $params['tbl'] : $this->_tbl;
$table = FrameWpf::_()->getTable( $tbl );
$this->_buildQuery( $table );
$return = isset($params['return']) ? $params['return'] : 'all';
$data = $table->get($this->_selectFields, $this->_where, '', $return);
if (!empty($data)) {
switch ($return) {
case 'one':
$this->_lastGetCount = 1;
break;
case 'row':
$data = $this->_afterGetFromTbl( $data );
$this->_lastGetCount = 1;
break;
default:
foreach ($data as $i => $row) {
$data[ $i ] = $this->_afterGetFromTbl( $row );
}
$this->_lastGetCount = count( $data );
break;
}
}
$this->_clearQuery( $params );
return $data;
}
protected function _clearQuery( $params = array() ) {
$clear = isset($params['clear']) ? $params['clear'] : array();
if (!is_array($clear)) {
$clear = array($clear);
}
if (empty($clear) || in_array('limit', $clear)) {
$this->_limit = '';
}
if (empty($clear) || in_array('orderBy', $clear)) {
$this->_orderBy = '';
}
if (empty($clear) || in_array('sortOrder', $clear)) {
$this->_sortOrder = '';
}
if (empty($clear) || in_array('where', $clear)) {
$this->_where = array();
}
if (empty($clear) || in_array('selectFields', $clear)) {
$this->_selectFields = '*';
}
if (empty($clear) || in_array('groupBy', $clear)) {
$this->_groupBy = '';
}
}
public function getCount( $params = array() ) {
$tbl = isset($params['tbl']) ? $params['tbl'] : $this->_tbl;
$table = FrameWpf::_()->getTable( $tbl );
$this->setSelectFields('COUNT(*) AS total');
$this->_buildQuery( $table );
$data = (int) $table->get($this->_selectFields, $this->_where, '', 'one');
$this->_clearQuery($params);
return $data;
}
protected function _afterGetFromTbl( $row ) {
// You can re-define this method in your own model
return $row;
}
protected function _buildQuery( $table = null ) {
if (!$table) {
$table = FrameWpf::_()->getTable( $this->_tbl );
}
if (!empty($this->_orderBy)) {
$order = $this->_orderBy;
if (!empty($this->_sortOrder)) {
$order .= ' ' . strtoupper($this->_sortOrder);
}
$table->orderBy( $order );
}
if (!empty($this->_groupBy)) {
$table->groupBy( $this->_groupBy );
}
if (!empty($this->_limit)) {
$table->setLimit( $this->_limit );
}
}
public function removeGroup( $ids ) {
if (!is_array($ids)) {
$ids = array($ids);
}
// Remove all empty values
$ids = array_filter(array_map('intval', $ids));
if (!empty($ids)) {
if (FrameWpf::_()->getTable( $this->_tbl )->delete(array('additionalCondition' => 'id IN (' . implode(',', $ids) . ')'))) {
return true;
} else {
$this->pushError(esc_html__('Database error detected', 'woo-product-filter'));
}
} else {
$this->pushError(esc_html__('Invalid ID', 'woo-product-filter'));
}
return false;
}
public function clear() {
return $this->delete(); // Just delete all
}
public function delete( $params = array() ) {
if (FrameWpf::_()->getTable( $this->_tbl )->delete( $params )) {
return true;
} else {
$this->pushError(esc_html__('Database error detected', 'woo-product-filter'));
}
return false;
}
public function getById( $id ) {
$data = $this->setWhere(array($this->_idField => $id))->getFromTbl();
return empty($data) ? false : array_shift($data);
}
public function insert( $data ) {
$data = $this->_dataSave($data, false);
$id = FrameWpf::_()->getTable( $this->_tbl)->insert( $data );
if ($id) {
return $id;
}
$this->pushError(FrameWpf::_()->getTable( $this->_tbl )->getErrors());
return false;
}
public function updateById( $data, $id = 0 ) {
if (!$id) {
$id = isset($data[ $this->_idField ]) ? (int) $data[ $this->_idField ] : 0;
}
if ($id) {
return $this->update($data, array($this->_idField => $id));
} else {
$this->pushError(esc_html__('Empty or invalid ID', 'woo-product-filter'));
}
return false;
}
public function update( $data, $where ) {
$data = $this->_dataSave($data, true);
if (FrameWpf::_()->getTable( $this->_tbl )->update( $data, $where )) {
return true;
}
$this->pushError(FrameWpf::_()->getTable( $this->_tbl )->getErrors());
return false;
}
protected function _dataSave( $data, $update = false ) {
return $data;
}
public function getTbl() {
return $this->_tbl;
}
/**
* We can re-define this method to not retrive all data - for simple tables
*/
public function setSimpleGetFields() {
return $this;
}
public function dropIndexes( $withPrimary = false ) {
$table = $this->_tbl;
$indexes = DbWpf::get('SHOW INDEX FROM `@__' . $table . '`');
if (!$indexes) {
$this->pushError(DbWpf::getError());
return false;
}
$drop = array();
foreach ($indexes as $index) {
$name = $index['Key_name'];
if ($withPrimary || 'PRIMARY' != $name) {
$drop[] = ' DROP INDEX ' . $name;
}
}
if (!empty($drop)) {
if (!DbWpf::query('ALTER TABLE `@__' . $table . '`' . implode(',', array_unique($drop)))) {
$this->pushError(DbWpf::getError());
return false;
}
}
return true;
}
public function addIndexes( $delete = true ) {
if (empty($this->_indexes)) {
return true;
}
$table = $this->_tbl;
$indexes = DbWpf::get('SHOW INDEX FROM `@__' . $table . '`');
if (!$indexes) {
$this->pushError(DbWpf::getError());
return false;
}
$exists = array();
foreach ($indexes as $index) {
$exists[] = $index['Key_name'];
}
$alter = '';
foreach ($this->_indexes as $name => $index) {
if (!in_array($name, $exists)) {
$alter .= ' ADD ' . $index . ',';
}
}
if (!empty($alter)) {
if (!DbWpf::query('ALTER TABLE `@__' . $table . '`' . substr($alter, 0, -1))) {
$this->pushError(DbWpf::getError());
if ($delete) {
$this->delete();
}
return false;
}
}
return true;
}
}