create user login activity
This commit is contained in:
44
app/Http/Controllers/ActivityController.php
Normal file
44
app/Http/Controllers/ActivityController.php
Normal 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);
|
||||
}
|
||||
}
|
||||
33
app/Http/Requests/DataTableRequest.php
Normal file
33
app/Http/Requests/DataTableRequest.php
Normal 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',
|
||||
];
|
||||
}
|
||||
}
|
||||
@@ -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');
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user