You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
72 lines
1.9 KiB
72 lines
1.9 KiB
<?php
|
|
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Support\Facades\DB;
|
|
use Illuminate\Support\Facades\Hash;
|
|
use Illuminate\Support\Str;
|
|
|
|
trait FilterRequestColumnModelTrait
|
|
{
|
|
public function getColumns()
|
|
{
|
|
$columns = [];
|
|
foreach (DB::select("describe {$this->table}") as $field) {
|
|
$type = (!Str::contains($field->Type, '(')) ? $field->Type : substr($field->Type, 0, strpos($field->Type, '('));
|
|
$columns[$field->Field] = $type;
|
|
}
|
|
return $columns;
|
|
}
|
|
|
|
/**
|
|
* filter request columns by fields
|
|
* @param $request
|
|
* @param array $additional
|
|
* @return array
|
|
*/
|
|
public function filterRequestColumns($request, $except = [])
|
|
{
|
|
if (gettype($request) == "object") {
|
|
if (method_exists($request, "input")) {
|
|
$request = $request->input();
|
|
} else {
|
|
abort(403);
|
|
}
|
|
}
|
|
|
|
$columns = $this->getColumns();
|
|
|
|
$return = [];
|
|
foreach ($request as $k => $v) {
|
|
if (!in_array($k, array_keys($columns)) || in_array($k, $except)) {
|
|
continue;
|
|
}
|
|
if ($k === "password") {
|
|
if (!$v) {
|
|
continue;
|
|
}
|
|
$v = Hash::make($v);
|
|
}
|
|
|
|
switch ($columns[$k]) {
|
|
case "json":
|
|
$v = json_encode($v, JSON_UNESCAPED_UNICODE);
|
|
break;
|
|
default:
|
|
if (is_array($v)) {
|
|
if (count($v) == count($v, 1)) {
|
|
$v = implode($this->glue, $v);
|
|
} else {
|
|
$v = json_encode($v, JSON_UNESCAPED_UNICODE);
|
|
}
|
|
}
|
|
}
|
|
|
|
$return[$k] = $v;
|
|
}
|
|
|
|
return $return;
|
|
}
|
|
|
|
}
|