Completed
Push — master ( 6f54d6...ffe8b5 )
by CodexShaper
05:45
created

MenuController::generateError()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 6
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 4
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 6
ccs 0
cts 6
cp 0
crap 2
rs 10
1
<?php
2
3
namespace CodexShaper\DBM\Http\Controllers;
4
5
use CodexShaper\DBM\Facades\Manager as DBM;
6
use CodexShaper\DBM\Models\MenuItem;
7
use Illuminate\Support\Facades\Response;
8
use Illuminate\Support\Facades\Validator;
9
10
class MenuController extends Controller
11
{
12
    /**
13
     * Show login form.
14
     *
15
     * @return \Illuminate\View\View|\Illuminate\Contracts\View\Factory
16
     */
17
    public function showLoginForm()
18
    {
19
        return view('dbm::admin');
20
    }
21
    /**
22
     * Login User for API.
23
     *
24
     * @return \Illuminate\Http\JsonResponse
25
     */
26
    public function get()
27
    {
28
        // if ($request->ajax()) {
29
        try {
30
            $menus = MenuItem::with('childrens')
31
                ->where('menu_id', 1)
32
                ->whereNull('parent_id')
33
                ->orderBy('order', 'asc')
34
                ->get();
35
            return response()->json([
36
                'success' => true,
37
                'menus' => $menus,
38
            ]);
39
40
        } catch (\Exception $e) {
41
            $this->generateError([$e->getMessage()]);
42
        }
43
        // }
44
        // return response()->json(["success" => false, "error" => "Unauthorised"], 401);
45
46
    }
47
    /**
48
     * Validate Credentials.
49
     *
50
     * @param array $data
51
     *
52
     * @return \Illuminate\Http\JsonResponse|true
53
     */
54
    public function validation($data)
55
    {
56
        $validator = Validator::make($data, [
57
            'email' => 'required|email',
58
            'password' => 'required',
59
60
        ]);
61
62
        if ($validator->fails()) {
63
            $errors = [];
64
            foreach ($validator->errors()->all() as $error) {
65
                $errors[] = $error;
66
            }
67
            return $this->generateError($errors);
68
        }
69
70
        return true;
71
    }
72
    /**
73
     * Generate errors and return response.
74
     *
75
     * @param array $errors
76
     *
77
     * @return \Illuminate\Http\JsonResponse
78
     */
79
    public function generateError($errors)
80
    {
81
        return response()->json([
82
            'success' => false,
83
            'errors' => $errors,
84
        ], 400);
85
    }
86
}
87