Automatically add table prefixes when building multi-column search string

This commit is contained in:
Marcus Moore 2023-05-23 15:58:58 -07:00
parent 6300909fee
commit 0a3d46824e
No known key found for this signature in database
3 changed files with 14 additions and 13 deletions

View file

@ -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.'%')

View file

@ -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 ?';
} }
/** /**

View file

@ -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);
} }