mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-12 14:27:33 -08:00
Automatically add table prefixes when building multi-column search string
This commit is contained in:
parent
6300909fee
commit
0a3d46824e
|
@ -948,8 +948,8 @@ class Asset extends Depreciable
|
||||||
->orWhere('assets_users.last_name', 'LIKE', '%'.$term.'%')
|
->orWhere('assets_users.last_name', 'LIKE', '%'.$term.'%')
|
||||||
->orWhere('assets_users.username', 'LIKE', '%'.$term.'%')
|
->orWhere('assets_users.username', 'LIKE', '%'.$term.'%')
|
||||||
->orWhereMultipleColumns([
|
->orWhereMultipleColumns([
|
||||||
DB::getTablePrefix() . 'assets_users.first_name',
|
'assets_users.first_name',
|
||||||
DB::getTablePrefix() . 'assets_users.last_name',
|
'assets_users.last_name',
|
||||||
], $term);
|
], $term);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1346,8 +1346,8 @@ class Asset extends Depreciable
|
||||||
$query->where('assets_users.first_name', 'LIKE', '%'.$search.'%')
|
$query->where('assets_users.first_name', 'LIKE', '%'.$search.'%')
|
||||||
->orWhere('assets_users.last_name', 'LIKE', '%'.$search.'%')
|
->orWhere('assets_users.last_name', 'LIKE', '%'.$search.'%')
|
||||||
->orWhereMultipleColumns([
|
->orWhereMultipleColumns([
|
||||||
DB::getTablePrefix() . 'assets_users.first_name',
|
'assets_users.first_name',
|
||||||
DB::getTablePrefix() . 'assets_users.last_name',
|
'assets_users.last_name',
|
||||||
], $search)
|
], $search)
|
||||||
->orWhere('assets_users.username', 'LIKE', '%'.$search.'%')
|
->orWhere('assets_users.username', 'LIKE', '%'.$search.'%')
|
||||||
->orWhere('assets_locations.name', 'LIKE', '%'.$search.'%')
|
->orWhere('assets_locations.name', 'LIKE', '%'.$search.'%')
|
||||||
|
|
|
@ -167,8 +167,8 @@ trait Searchable
|
||||||
if($relation == 'user') {
|
if($relation == 'user') {
|
||||||
$query->orWhereRaw(
|
$query->orWhereRaw(
|
||||||
$this->buildMultipleColumnSearch([
|
$this->buildMultipleColumnSearch([
|
||||||
DB::getTablePrefix() . 'users.first_name',
|
'users.first_name',
|
||||||
DB::getTablePrefix() . 'users.last_name',
|
'users.last_name',
|
||||||
]),
|
]),
|
||||||
["%{$term}%"]
|
["%{$term}%"]
|
||||||
);
|
);
|
||||||
|
@ -273,14 +273,16 @@ trait Searchable
|
||||||
*/
|
*/
|
||||||
private function buildMultipleColumnSearch(array $columns): string
|
private function buildMultipleColumnSearch(array $columns): string
|
||||||
{
|
{
|
||||||
|
$mappedColumns = collect($columns)->map(fn($column) => DB::getTablePrefix() . $column)->toArray();
|
||||||
|
|
||||||
$driver = config('database.connections.' . config('database.default') . '.driver');
|
$driver = config('database.connections.' . config('database.default') . '.driver');
|
||||||
|
|
||||||
if ($driver === 'sqlite') {
|
if ($driver === 'sqlite') {
|
||||||
return implode("||' '||", $columns) . ' LIKE ?';
|
return implode("||' '||", $mappedColumns) . ' LIKE ?';
|
||||||
}
|
}
|
||||||
|
|
||||||
// Default to MySQL's concatenation method
|
// Default to MySQL's concatenation method
|
||||||
return 'CONCAT(' . implode('," ",', $columns) . ') LIKE ?';
|
return 'CONCAT(' . implode('," ",', $mappedColumns) . ') LIKE ?';
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -647,8 +647,8 @@ class User extends SnipeModel implements AuthenticatableContract, AuthorizableCo
|
||||||
return $query->where('first_name', 'LIKE', '%' . $search . '%')
|
return $query->where('first_name', 'LIKE', '%' . $search . '%')
|
||||||
->orWhere('last_name', 'LIKE', '%' . $search . '%')
|
->orWhere('last_name', 'LIKE', '%' . $search . '%')
|
||||||
->orWhereMultipleColumns([
|
->orWhereMultipleColumns([
|
||||||
DB::getTablePrefix() . 'users.first_name',
|
'users.first_name',
|
||||||
DB::getTablePrefix() . 'users.last_name',
|
'users.last_name',
|
||||||
], $search);
|
], $search);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -660,11 +660,10 @@ class User extends SnipeModel implements AuthenticatableContract, AuthorizableCo
|
||||||
* @return \Illuminate\Database\Eloquent\Builder
|
* @return \Illuminate\Database\Eloquent\Builder
|
||||||
*/
|
*/
|
||||||
public function advancedTextSearch(Builder $query, array $terms) {
|
public function advancedTextSearch(Builder $query, array $terms) {
|
||||||
|
|
||||||
foreach($terms as $term) {
|
foreach($terms as $term) {
|
||||||
$query->orWhereMultipleColumns([
|
$query->orWhereMultipleColumns([
|
||||||
DB::getTablePrefix() . 'users.first_name',
|
'users.first_name',
|
||||||
DB::getTablePrefix() . 'users.last_name',
|
'users.last_name',
|
||||||
], $term);
|
], $term);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue