route, 'module',true); $data['breadcrumbs'] = [ ['name' => 'Dashboard','url' => url('dashboard')], ['name' => 'Management & Akses Role'], ['name' => 'Data User','active' => true], ]; $data['title'] = $this->title; $data['route'] = $this->route; return view($this->template.'.index',$data); } public function grid(Request $request) { $data = User::with(['group'])->where('ms_group_id','!=',1)->where('id','!=',auth()->user()->id)->orderBy('id','DESC')->get(); // $data = User::with(['group'])->orderBy('id','DESC')->get(); $_data = []; foreach ($data as $key => $row) { $action = ''; if((permission('is_create', $this->route.'.*','module',false)) || (permission('is_update', $this->route.'.*','module',false))){ $action .= '
'; $action .= ''; if(session('group_id') == 1){ $action .= ''; $action .= ''; } $action .= '
'; } $_data[] = [ 'no' => $key+1, 'id' => encode_id($row->id), 'name' => @$row->name, 'role' => @$row->group->name, 'username' => @$row->username, 'email' => @$row->email, 'created_at' => dateTime(@$row->created_at), 'action' => @$action, ]; } // return response()->json($_data); // Return the data as a JSON response return response()->json($_data); } /** * Show the form for creating a new resource. */ public function create() { // } /** * Store a newly created resource in storage. */ public function store(Request $request) { try { $keyId = decode_id($request->secure_id); if(@$keyId){ Validator::make($request->all(), [ 'email' => 'required|unique:users,email,'.$keyId.'|email', 'name' => 'required|max:50', 'group' => 'required', 'ms_instansi_id' => 'required', 'username' => 'required|unique:users,username,'.$keyId, 'password' => 'nullable|min:8|max:15|regex:/[a-z]/|regex:/[A-Z]/|regex:/[0-9]/|regex:/[@$!%*#?&]/', //min 8 char, maks 15 char, min 1 symbol, min 1 uppercase, min 1 lowercase, 1 number ],[ 'password.min' => 'password Minimal 8 Karakter', 'password.max' => 'password Maksimal 15 Karakter', 'password.regex' => 'Format Kata Sandi harus mengandung minimal Huruf Besar, Huruf Kecil, Angka, Spesial Karakter', ])->validate(); $user = User::find($keyId); $user->email = $request->email; $user->username = $request->username; $user->ms_group_id = decode_id($request->group); $user->ms_instansi_id = decode_id($request->ms_instansi_id); if(@$request->password){ $user->password = Hash::make($request->password); } $user->name = $request->name; $user->save(); }else{ Validator::make($request->all(), [ 'email' => 'required|unique:users,email|email', 'name' => 'required|max:50', 'group' => 'required', 'ms_instansi_id' => 'required', 'username' => 'required|unique:users,username', 'password' => 'required|min:8|max:15|regex:/[a-z]/|regex:/[A-Z]/|regex:/[0-9]/|regex:/[@$!%*#?&]/', //min 8 char, maks 15 char, min 1 symbol, min 1 uppercase, min 1 lowercase, 1 number ],[ 'password.min' => 'password Minimal 8 Karakter', 'password.max' => 'password Maksimal 15 Karakter', 'password.regex' => 'Format Kata Sandi harus mengandung minimal Huruf Besar, Huruf Kecil, Angka, Spesial Karakter', ])->validate(); $user = new User; $user->email = $request->email; $user->username = $request->username; $user->ms_group_id = decode_id($request->group); $user->ms_instansi_id = decode_id($request->ms_instansi_id); if(@$request->password){ $user->password = Hash::make($request->password); } $user->name = $request->name; $user->save(); } return redirect()->back()->with([ 'message' => 'Berhasil update data', 'type' => 'success', ]); } catch (Exception $e) { return redirect()->back()->with([ 'message' => $e->getMessage(), 'type' => "error" ]); } } /** * Display the specified resource. */ public function show(string $id) { // } /** * Show the form for editing the specified resource. */ public function edit(string $id) { // } /** * Update the specified resource in storage. */ public function update($id = null) { $data['breadcrumbs'] = [ ['name' => 'Dashboard','url' => url('dashboard')], ['name' => 'Management & Akses Role'], ['name' => 'Data User','active' => true], ]; $keyId = decode_id($id); $data['title'] = $this->title; $data['route'] = $this->route; $data['keyId'] = $id; $data['item'] = User::where('id',$keyId)->first(); $data['group'] = Group::where('MsGroupId','!=',1)->get(); return view($this->template.'.form',$data); } /** * Remove the specified resource from storage. */ public function destroy(string $id) { // } public function delete($id) { $keyId = decode_id($id); $user = User::where('id',$keyId)->delete(); return response()->json(['success' => true,'message' => 'Berhasil update data','type' => 'success']); } public function forcelogin($id = null) { //dd($id); if (!$id) { return response()->json(['success' => false,'message' => 'Data Tidak Temukan','type' => 'error']); } $id = decode_id($id); $user = User::find($id); if (!$user) { return response()->json(['success' => false,'message' => 'Data Tidak Temukan','type' => 'error']); } else { if ($user->username && $user->password) { if (Auth::loginUsingId($id)) { $session = [ 'username' => $user->username, 'name' => $user->name, 'email' => $user->email, 'currYear' => date('Y'), 'group_id' => @$user->ms_group_id, 'instansi_id' => @$user->ms_instansi_id, 'group_alias' => @$user->group->alias, 'group_name' => @$user->group->name, ]; session($session); return response()->json(['status' => true,'message' => 'Selamat datang kembali','type' => 'success']); } else { return response()->json(['status' => false,'message' => 'Maaf Terjadi Kesalahan','type' => 'error']); } } else { return response()->json(['status' => false,'message' => 'Maaf Terjadi Kesalahan','type' => 'error']); } } } }