File Manager Lite
Dir:
/home/u540325668/domains/dumbafarm.in/public_html/src/Core/Foundation/Database/EntityManager
Upload
[..]
QueryBuilder.php (2.34 KB)
Edit
Rename
Del
Edit: QueryBuilder.php
<?php /** * Copyright since 2007 PrestaShop SA and Contributors * PrestaShop is an International Registered Trademark & Property of PrestaShop SA * * NOTICE OF LICENSE * * This source file is subject to the Open Software License (OSL 3.0) * that is bundled with this package in the file LICENSE.md. * It is also available through the world-wide-web at this URL: * https://opensource.org/licenses/OSL-3.0 * If you did not receive a copy of the license and are unable to * obtain it through the world-wide-web, please send an email * to license@prestashop.com so we can send you a copy immediately. * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade PrestaShop to newer * versions in the future. If you wish to customize PrestaShop for your * needs please refer to https://devdocs.prestashop.com/ for more information. * * @author PrestaShop SA and Contributors <contact@prestashop.com> * @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ namespace PrestaShop\PrestaShop\Core\Foundation\Database\EntityManager; use PrestaShop\PrestaShop\Core\Foundation\Database\Exception; class QueryBuilder { private $db; public function __construct(\PrestaShop\PrestaShop\Core\Foundation\Database\DatabaseInterface $db) { $this->db = $db; } public function quote($value) { $escaped = $this->db->escape($value); if (is_string($value)) { return "'" . $escaped . "'"; } else { return $escaped; } } public function buildWhereConditions($andOrOr, array $conditions) { $operator = strtoupper($andOrOr); if ($operator !== 'AND' && $operator !== 'OR') { throw new Exception(sprintf('Invalid operator %s - must be "and" or "or".', $andOrOr)); } $parts = []; foreach ($conditions as $key => $value) { if (is_scalar($value)) { $parts[] = $key . ' = ' . $this->quote($value); } else { $list = []; foreach ($value as $item) { $list[] = $this->quote($item); } $parts[] = $key . ' IN (' . implode(', ', $list) . ')'; } } return implode(" $operator ", $parts); } }
Simpan