b374k
m1n1 1.01
Apache/2.4.41 (Ubuntu)
Linux vmi616275.contaboserver.net 5.4.0-84-generic #94-Ubuntu SMP Thu Aug 26 20:27:37 UTC 2021 x86_64
uid=33(www-data) gid=33(www-data) groups=33(www-data)
server ip : 62.171.164.128 | your ip : 127.0.0.1
safemode OFF
 >  / home / dev2.destoffenstraat.com / vendor / magento / framework / DB / Helper / Mysql /
Filename/home/dev2.destoffenstraat.com/vendor/magento/framework/DB/Helper/Mysql/Fulltext.php
Size3.27 kb
Permissionrw-r--r--
Ownerroot : root
Create time17-Aug-2025 10:26
Last modified07-Jan-2021 21:08
Last accessed23-Aug-2025 03:56
Actionsedit | rename | delete | download (gzip)
Viewtext | code | image
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);

namespace Magento\Framework\DB\Helper\Mysql;

use Magento\Framework\App\ResourceConnection;

/**
* MySQL Fulltext Query Builder
*/
class Fulltext
{
/**
* Characters that have special meaning in fulltext match syntax
*
* @var string
*/
const SPECIAL_CHARACTERS = '-+<>*()~?';

/**
* FULLTEXT search in MySQL search mode "natural language"
*/
const FULLTEXT_MODE_NATURAL = 'IN NATURAL LANGUAGE MODE';

/**
* FULLTEXT search in MySQL search mode "natural language with query expansion"
*/
const FULLTEXT_MODE_NATURAL_QUERY = 'IN NATURAL LANGUAGE MODE WITH QUERY EXPANSION';

/**
* FULLTEXT search in MySQL search mode "boolean"
*/
const FULLTEXT_MODE_BOOLEAN = 'IN BOOLEAN MODE';

/**
* FULLTEXT search in MySQL search mode "query expansion"
*/
const FULLTEXT_MODE_QUERY = 'WITH QUERY EXPANSION';

/**
* FULLTEXT search in MySQL MATCH method
*/
const MATCH = 'MATCH';

/**
* FULLTEXT search in MySQL AGAINST method
*/
const AGAINST = 'AGAINST';

/**
* @var \Magento\Framework\DB\Adapter\AdapterInterface
*/
private $connection;

/**
* @param ResourceConnection $resource
*/
public function __construct(ResourceConnection $resource)
{
$this->connection = $resource->getConnection();
}

/**
* Method for FULLTEXT search in Mysql, will generated MATCH ($columns) AGAINST ('$expression' $mode)
*
* @param string|string[] $columns Columns which add to MATCH ()
* @param string $expression Expression which add to AGAINST ()
* @param string $mode
* @return string
*/
public function getMatchQuery($columns, $expression, $mode = self::FULLTEXT_MODE_NATURAL)
{
if (is_array($columns)) {
$columns = implode(', ', $columns);
}

$expression = $this->connection->quote($expression);

$condition = self::MATCH . " ({$columns}) " . self::AGAINST . " ({$expression} {$mode})";
return $condition;
}

/**
* Method for FULLTEXT search in Mysql; will add generated MATCH ($columns) AGAINST ('$expression' $mode) to $select
*
* @param \Magento\Framework\DB\Select $select
* @param string|string[] $columns Columns which add to MATCH ()
* @param string $expression Expression which add to AGAINST ()
* @param bool $isCondition true=AND, false=OR
* @param string $mode
* @return \Magento\Framework\DB\Select
*/
public function match($select, $columns, $expression, $isCondition = true, $mode = self::FULLTEXT_MODE_NATURAL)
{
$fullCondition = $this->getMatchQuery($columns, $expression, $mode);

if ($isCondition) {
$select->where($fullCondition);
} else {
$select->orWhere($fullCondition);
}

return $select;
}

/**
* Remove special characters from fulltext query expression
*
* @param string $expression
* @return string
*/
public function removeSpecialCharacters(string $expression): string
{
return str_replace(str_split(static::SPECIAL_CHARACTERS), '', $expression);
}
}