fixes to support analytics
This commit is contained in:
@@ -27,6 +27,13 @@ class AnalyticsConductor extends Conductor
|
|||||||
*/
|
*/
|
||||||
protected $sort = 'created_at';
|
protected $sort = 'created_at';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default includes to include in a request.
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $includes = ['duration'];
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return if the current model is visible.
|
* Return if the current model is visible.
|
||||||
|
|||||||
@@ -3,6 +3,7 @@
|
|||||||
namespace App\Http\Controllers\Api;
|
namespace App\Http\Controllers\Api;
|
||||||
|
|
||||||
use App\Conductors\AnalyticsConductor;
|
use App\Conductors\AnalyticsConductor;
|
||||||
|
use App\Conductors\Conductor;
|
||||||
use App\Enum\HttpResponseCodes;
|
use App\Enum\HttpResponseCodes;
|
||||||
use App\Http\Requests\AnalyticsRequest;
|
use App\Http\Requests\AnalyticsRequest;
|
||||||
use App\Models\Media;
|
use App\Models\Media;
|
||||||
@@ -37,14 +38,34 @@ class AnalyticsController extends ApiController
|
|||||||
*/
|
*/
|
||||||
public function index(Request $request)
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
list($collection, $total) = AnalyticsConductor::request($request);
|
if ($request->user() !== null && $request->user()?->hasPermission('admin/analytics') === true) {
|
||||||
|
$searchFields = ['attribute', 'type', 'useragent', 'ip'];
|
||||||
|
|
||||||
return $this->respondAsResource(
|
$queryRequest = new Request();
|
||||||
$collection,
|
$queryRequest->merge($request->only($searchFields));
|
||||||
['isCollection' => true,
|
foreach ($searchFields as $field) {
|
||||||
'appendData' => ['total' => $total]
|
unset($request[$field]);
|
||||||
]
|
}
|
||||||
);
|
|
||||||
|
$query = Analytics::query()
|
||||||
|
->selectRaw('session,
|
||||||
|
MIN(created_at) as created_at,
|
||||||
|
TIMESTAMPDIFF(MINUTE, MIN(created_at), MAX(created_at)) as duration');
|
||||||
|
$query = Conductor::filterQuery($query, $queryRequest);
|
||||||
|
|
||||||
|
list($collection, $total) = AnalyticsConductor::collection($request, $query
|
||||||
|
->groupBy('session')
|
||||||
|
->get());
|
||||||
|
|
||||||
|
return $this->respondAsResource(
|
||||||
|
$collection,
|
||||||
|
['isCollection' => true,
|
||||||
|
'appendData' => ['total' => $total]
|
||||||
|
]
|
||||||
|
);
|
||||||
|
}//end if
|
||||||
|
|
||||||
|
return $this->respondForbidden();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -54,10 +75,19 @@ class AnalyticsController extends ApiController
|
|||||||
* @param \App\Models\Analytics $analytics The analyics model.
|
* @param \App\Models\Analytics $analytics The analyics model.
|
||||||
* @return \Illuminate\Http\Response
|
* @return \Illuminate\Http\Response
|
||||||
*/
|
*/
|
||||||
public function show(Request $request, Analytics $analytics)
|
public function show(Request $request, int $session)
|
||||||
{
|
{
|
||||||
if (AnalyticsConductor::viewable($analytics) === true) {
|
if ($request->user() !== null && $request->user()?->hasPermission('admin/analytics') === true) {
|
||||||
return $this->respondAsResource(AnalyticsConductor::model($request, $analytics));
|
list($collection, $total) = AnalyticsConductor::collection($request, Analytics::query()
|
||||||
|
->where('session', $session)
|
||||||
|
->get());
|
||||||
|
|
||||||
|
return $this->respondAsResource(
|
||||||
|
$collection,
|
||||||
|
['isCollection' => true,
|
||||||
|
'appendData' => ['total' => $total]
|
||||||
|
]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->respondForbidden();
|
return $this->respondForbidden();
|
||||||
|
|||||||
@@ -27,6 +27,7 @@ Route::post('/login', [AuthController::class, 'login'])->name('login');
|
|||||||
Route::post('/register', [UserController::class, 'register']);
|
Route::post('/register', [UserController::class, 'register']);
|
||||||
|
|
||||||
Route::get('/analytics', [AnalyticsController::class, 'index']);
|
Route::get('/analytics', [AnalyticsController::class, 'index']);
|
||||||
|
Route::get('/analytics/{session}', [AnalyticsController::class, 'show']);
|
||||||
Route::post('/analytics', [AnalyticsController::class, 'store']);
|
Route::post('/analytics', [AnalyticsController::class, 'store']);
|
||||||
|
|
||||||
Route::apiResource('users', UserController::class);
|
Route::apiResource('users', UserController::class);
|
||||||
|
|||||||
Reference in New Issue
Block a user