AdminController.php 1.83 KB
<?php

namespace App\Http\Controllers;

use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Facades\Validator;

class AdminController extends Controller
{
    // главная страница административного раздела
    public function index() {
        return view('admin.index');
    }

    // форма смены пароля
    public function form_password() {
        return view('admin.password');
    }

    //валидация смены пароля
    public function validate_password(Request $request) {

        $rules = [
            'old_password' => 'required|min:6', //|current_password:api',
            'password' => 'required|min:6|confirmed',
        ];
        $messages = [
            'required' => 'Укажите обязательное поле',
            'confirmed' => 'Пароли не совпадают'
        ];

        $validator = Validator::make($request->all(), $rules, $messages);

        if (! Hash::check($request->old_password, $request->user()->password)) {
            return back()->withErrors([
                'old_password' => ['Неверный предыдущий пароль']
            ]);
        }

        if ($validator->fails()) {
            return redirect()->route('admin.form_password')
                ->withErrors($validator);
        } else {
            $params = $request->all();
            // устанавливаем новый пароль для пользователя
            User::where('id', Auth::id())
                ->update(['password' => Hash::make($request->password)]);
            session()->flash('success', 'Успешно изменен пароль!');

            return redirect()->route('admin.form_password');
        }
    }
}