65 lines
2.0 KiB
PHP
65 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\AdminBackend;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use App\Models\User;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Support\Facades\Auth;
|
|
|
|
class AdminProfileController extends Controller
|
|
{
|
|
public function index()
|
|
{
|
|
return view('admin_backend.admin_profile');
|
|
}
|
|
|
|
public function update(Request $request)
|
|
{
|
|
// Validate the request data (you can add more validation rules)
|
|
$validatedData = $request->validate([
|
|
'nama_lengkap' => 'required',
|
|
'nim' => 'required',
|
|
'profile_image' => 'image|mimes:jpeg,png,jpg,gif|max:2048',
|
|
]);
|
|
$imagePath = null;
|
|
if ($request->hasFile('profile_image')) {
|
|
$image = $request->file('profile_image');
|
|
$imagePath = $image->store('images', 'public');
|
|
}
|
|
|
|
$user = User::findOrFail(auth()->user()->id);
|
|
$user->nama_lengkap = $request->input('nama_lengkap');
|
|
$user->nim = $request->input('nim');
|
|
if ($imagePath != null) {
|
|
$user->foto = $imagePath;
|
|
}
|
|
$user->update();
|
|
|
|
return redirect('/admin')->with('success', 'Profile updated successfully');
|
|
}
|
|
|
|
public function changePassword(Request $request)
|
|
{
|
|
$request->validate([
|
|
'current_password' => 'required',
|
|
'new_password' => 'required|string|min:8|confirmed',
|
|
], [
|
|
'new_password.min' => 'Password tidak boleh kurang dari 8 karakter',
|
|
]);
|
|
|
|
$user = Auth::user();
|
|
|
|
// Verify the current password using the fully qualified namespace
|
|
if (!\Illuminate\Support\Facades\Hash::check($request->input('current_password'), $user->password)) {
|
|
return redirect()->back()->with('error', 'Current password is incorrect');
|
|
}
|
|
|
|
// Update the password
|
|
$user->password = \Illuminate\Support\Facades\Hash::make($request->input('new_password'));
|
|
$user->save();
|
|
|
|
return redirect()->back()->with('success', 'Password changed successfully');
|
|
}
|
|
}
|