UserDataTable::ajax()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 11
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 8
nc 1
nop 0
dl 0
loc 11
ccs 0
cts 0
cp 0
crap 2
rs 9.4285
c 1
b 0
f 0
1
<?php
2
/**
3
 * UsersDataTable.php
4
 *
5
 * Provide layout and data for the Users DataTable
6
 *
7
 * This program is free software: you can redistribute it and/or modify
8
 * it under the terms of the GNU General Public License as published by
9
 * the Free Software Foundation, either version 3 of the License, or
10
 * (at your option) any later version.
11
 *
12
 * This program is distributed in the hope that it will be useful,
13
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.See the
15
 * GNU General Public License for more details.
16
 *
17
 * You should have received a copy of the GNU General Public License
18
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
19
 *
20
 * @package    LibreNMS
21
 * @link       http://librenms.org
22
 * @copyright  2016 Tony Murray
23
 * @author     Tony Murray <[email protected]>
24
 */
25
26
namespace App\DataTables\General;
27
28
use App\DataTables\BaseDataTable;
29
use App\Models\User;
30
31
class UserDataTable extends BaseDataTable
32
{
33
    /**
34
     * Display ajax response.
35
     *
36
     * @return \Illuminate\Http\JsonResponse
37
     */
38
    public function ajax()
39
    {
40
        return $this->datatables
41
            ->eloquent($this->query())
42
            ->editColumn('level', function ($user) {
43
                return trans('user.level.'.$user->level);
44
            })
45
            ->editColumn('actions', 'datatables.user.actions')
46
            ->rawColumns(['actions'])
47
            ->make(true);
48
    }
49
50
    /**
51
     * Get the query object to be processed by datatables.
52
     *
53
     * @return \Illuminate\Database\Query\Builder|\Illuminate\Database\Eloquent\Builder
54
     */
55
    public function query()
56
    {
57
        $users = User::select('users.*');
58
        return $this->applyScopes($users);
59
    }
60
61
    /**
62
     * Get columns.
63
     *
64
     * @return array
65
     */
66 1
    public function getColumns()
67
    {
68
        return [
69
            'username' => [
70 1
                'title' => trans('user.text.username'),
71
            ],
72
            'realname' => [
73 1
                'title' => trans('user.text.realname'),
74
            ],
75
            'level'    => [
76 1
                'title' => trans('user.text.level'),
77
            ],
78
            'actions'  => [
79 1
                'title' => trans('user.text.actions'),
80
            ],
81
        ];
82
    }
83
84
    /**
85
     * Get filename for export.
86
     *
87
     * @return string
88
     */
89
    protected function filename()
90
    {
91
        return 'users';
92
    }
93
}
94