create user login activity

This commit is contained in:
Geriano
2022-07-29 20:45:43 +07:00
parent 8585428659
commit 15e3431a06
7 changed files with 167 additions and 0 deletions

View File

@@ -0,0 +1,44 @@
<?php
namespace App\Http\Controllers;
use App\Http\Requests\DataTableRequest;
use App\Models\Login;
use Illuminate\Database\Eloquent\Builder;
use Illuminate\Http\Request;
use Inertia\Inertia;
class ActivityController extends Controller
{
/**
* @return \Illuminate\Http\Response
*/
public function login()
{
return Inertia::render('Superuser/Activity/Login');
}
/**
* @param \App\Http\Requests\DataTableRequest $request
* @return \Illuminate\Http\Response
*/
public function logins(DataTableRequest $request)
{
$request->validated();
return Login::join('users', 'login_activities.user_id', '=', 'users.id')
->where(function (Builder $query) use ($request) {
$search = '%' . $request->search . '%';
$query->where('users.name', 'like', $search)
->orWhere('users.username', 'like', $search)
->orWhere('login_activities.ip_address', 'like', $search)
->orWhere('login_activities.browser', 'like', $search)
->orWhere('login_activities.platform', 'like', $search)
->orWhere('login_activities.created_at', 'like', $search);
})
->select(['users.*', 'login_activities.*'])
->orderBy($request->input('order.key') ?: 'created_at', $request->input('order.dir') ?: 'asc')
->paginate($request->per_page ?: 10);
}
}

View File

@@ -0,0 +1,33 @@
<?php
namespace App\Http\Requests;
use Illuminate\Foundation\Http\FormRequest;
class DataTableRequest extends FormRequest
{
/**
* Determine if the user is authorized to make this request.
*
* @return bool
*/
public function authorize()
{
return true;
}
/**
* Get the validation rules that apply to the request.
*
* @return array<string, mixed>
*/
public function rules()
{
return [
'search' => 'nullable|string',
'per_page' => 'nullable|integer|min:0|max:10',
'order.key' => 'nullable|string',
'order.dir' => 'nullable|in:asc,desc',
];
}
}

View File

@@ -23,4 +23,12 @@ class Login extends Model
'browser',
'platform',
];
/**
* @return \Illuminate\Database\Eloquent\Relations\HasOne
*/
public function user()
{
return $this->hasOne(User::class, 'id', 'user_id');
}
}