-
Notifications
You must be signed in to change notification settings - Fork 22
/
Copy pathQueryProcessor.php
75 lines (66 loc) · 2.14 KB
/
QueryProcessor.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php
/**
* Copyright 2022 Adobe
* All Rights Reserved.
*
* NOTICE: All information contained herein is, and remains
* the property of Adobe and its suppliers, if any. The intellectual
* and technical concepts contained herein are proprietary to Adobe
* and its suppliers and are protected by all applicable intellectual
* property laws, including trade secret and copyright laws.
* Dissemination of this information or reproduction of this material
* is strictly forbidden unless prior written permission is obtained
* from Adobe.
*/
declare(strict_types=1);
namespace Magento\QueryXml\Model;
use Magento\Framework\App\ResourceConnection;
use Magento\Framework\DB\Adapter\AdapterInterface;
/**
* Class QueryProcessor
*/
class QueryProcessor
{
/**
* @var ResourceConnection
*/
private $resourceConnection;
/**
* @var QueryFactory
*/
private $queryFactory;
public function __construct(
ResourceConnection $resourceConnection,
QueryFactory $queryFactory
) {
$this->resourceConnection = $resourceConnection;
$this->queryFactory = $queryFactory;
}
/**
* @param AdapterInterface $connection
* @param string $sql
* @param $arguments
* @return string
*/
private function processPlaceholders(AdapterInterface $connection, string $sql, $arguments) : string
{
// TODO: add support for repeatable variables
foreach ($arguments as $name => $value) {
$sql = str_replace(sprintf('::%s::', $name), '?', $sql);
$sql = $connection->quoteInto($sql, $value);
}
return $sql;
}
/**
* @param string $queryName
* @param array $arguments
* @return \Zend_Db_Statement_Interface
*/
public function execute(string $queryName, array $arguments = []) : \Zend_Db_Statement_Interface
{
$query = $this->queryFactory->create($queryName);
$connection = $this->resourceConnection->getConnection($query->getConnectionName());
$sql = $this->processPlaceholders($connection, $query->getSelect()->assemble(), $arguments);
return $connection->query($sql);
}
}