snipe-it/app/Http/Controllers/Api/ReportsController.php

67 lines
2.3 KiB
PHP
Raw Normal View History

2017-05-23 09:24:36 -07:00
<?php
namespace App\Http\Controllers\Api;
use App\Http\Controllers\Controller;
use App\Http\Transformers\ActionlogsTransformer;
use App\Models\Actionlog;
use Illuminate\Http\Request;
2017-05-23 09:24:36 -07:00
class ReportsController extends Controller
{
/**
* Returns Activity Report JSON.
*
* @author [A. Gianotto] [<snipe@snipe.net>]
* @since [v4.0]
* @return View
*/
public function index(Request $request)
{
$this->authorize('reports.view');
2017-08-25 18:40:20 -07:00
$actionlogs = Actionlog::with('item', 'user', 'target','location');
2017-05-23 09:24:36 -07:00
if ($request->filled('search')) {
2017-05-23 09:24:36 -07:00
$actionlogs = $actionlogs->TextSearch(e($request->input('search')));
}
if (($request->filled('target_type')) && ($request->filled('target_id'))) {
2017-06-08 19:09:42 -07:00
$actionlogs = $actionlogs->where('target_id','=',$request->input('target_id'))
->where('target_type','=',"App\\Models\\".ucwords($request->input('target_type')));
}
if (($request->filled('item_type')) && ($request->filled('item_id'))) {
2017-06-08 18:26:55 -07:00
$actionlogs = $actionlogs->where('item_id','=',$request->input('item_id'))
->where('item_type','=',"App\\Models\\".ucwords($request->input('item_type')));
}
if ($request->filled('action_type')) {
$actionlogs = $actionlogs->where('action_type','=',$request->input('action_type'))->orderBy('created_at', 'desc');
}
if ($request->filled('uploads')) {
2018-05-02 14:13:06 -07:00
$actionlogs = $actionlogs->whereNotNull('filename')->orderBy('created_at', 'desc');
}
$allowed_columns = [
'id',
'created_at',
'target_id',
'user_id',
'action_type',
'note'
];
2017-05-23 09:24:36 -07:00
$sort = in_array($request->input('sort'), $allowed_columns) ? e($request->input('sort')) : 'created_at';
2018-02-01 15:17:56 -08:00
$order = ($request->input('order') == 'asc') ? 'asc' : 'desc';
2017-05-23 09:24:36 -07:00
$offset = request('offset', 0);
$limit = request('limit', 50);
$total = $actionlogs->count();
2017-11-21 22:34:07 -08:00
$actionlogs = $actionlogs->orderBy($sort, $order)->skip($offset)->take($limit)->get();
2017-05-23 09:24:36 -07:00
2017-11-21 22:34:07 -08:00
return response()->json((new ActionlogsTransformer)->transformActionlogs($actionlogs, $total), 200, ['Content-Type' => 'application/json;charset=utf8'], JSON_UNESCAPED_UNICODE);
2017-05-23 09:24:36 -07:00
}
}