AuthController.php 5.7 KB
<?php
/**
+-----------------------------------------------------------------------------------------------------------------------
 * 控制层:登录注册控制类
+-----------------------------------------------------------------------------------------------------------------------
 *
 * PHP version 7
 *
 * @category  App\Http\Api\V1\Controllers
 * @package   App\Http\Api\V1\Controllers
 * @author    Richer <yangzi1028@163.com>
 * @date      2020年11月13日 01:26:09
 * @copyright 2020-2022 Richer (http://www.Richer.com/)
 * @license   http://www.Richer.com/ License
 * @link      http://www.Richer.com/
 */
namespace App\Http\Api\V1\Controllers;

use Illuminate\Http\Request;
use App\Services\AuthService;
use App\Http\Requests\LoginRequest;
use App\Http\Requests\RegisterRequest;
use App\Http\Requests\ResetPasswordRequest;
use Illuminate\Http\Response;
use Illuminate\Support\Facades\Auth;
use Illuminate\Support\Facades\Log;

/**
 * Class AuthController
 *
 * @category  App\Http\Api\V1\Controllers
 * @package   App\Http\Api\V1\Controllers
 * @author    Richer <yangzi1028@163.com>
 * @date      2020年11月13日 01:26:09
 * @copyright 2020-2022 Richer (http://www.Richer.com/)
 * @license   http://www.Richer.com/ License
 * @link      http://www.Richer.com/
 */
class AuthController extends BaseController
{
    /**
     * AuthController constructor.
     *
     * @param AuthService $service 注入service层
     */
    public function __construct(AuthService $service)
    {
        // 执行父类构造方法
        parent::__construct($service);
    }

    /**
     * Attempt to get the guard from the local cache.
     *
     * @return \Illuminate\Contracts\Auth\Guard|\Illuminate\Contracts\Auth\StatefulGuard
     */
    public function guard()
    {
        $guard ='admin_user';

        return Auth::guard($guard);
    }

    /**
     * @param LoginRequest $request
     * @return Response
     */
    public function login(LoginRequest $request)
    {
        $result = $this->service->login($request);

        if ($result) {
            return $this->success($result, __('login')  . ' ' . __('succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2004);
        }
    }

    /**
     * 用户登录:通过密码进行登录
     *
     * @param RegisterRequest $request request
     *
     * @return Response
     */
    public function register(RegisterRequest $request)
    {
        $result = $this->service->register($request);

        if ($result) {
            return $this->success($result, __('register_succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2004);
        }
    }

    /**
     * 用户登录:微信收取登录
     *
     * @param Request $request
     * @return Response
     */
    public function wechatAuth(Request $request)
    {
        record_log('wechat-auth', '微信公众号授权登录' , 'begin');
        $result = $this->service->wechatAuth($request);
        if ($result) {
//            Log::info($result);
            record_log('wechat-auth', '返回信息:' .json_encode($result));
            record_log('wechat-auth', '微信公众号授权登录' , 'end');
            return $this->success($result, __('login')  . ' ' . __('succeeded'), 0, $result->token);
        } else {
            record_log('wechat-auth', '微信公众号授权登录' , 'end');
            return $this->error($this->service->getMessage(), 2006);
        }
    }

    /**
     * 用户登录:通过密码进行登录
     *
     * @param LoginRequest $request
     * @return Response
     */
    public function loginWithPassword(LoginRequest $request)
    {
        $result = $this->service->loginWithPassword($request);
        if ($result) {
            return $this->success($result, __('login')  . ' ' . __('succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2006);
        }
    }

    /**
     * 通过手机验证码登录
     *
     * @param LoginRequest $request
     * @return Response
     */
    public function loginQuick(LoginRequest $request)
    {
        $result = $this->service->loginQuick($request);
        if ($result) {
            return $this->success($result, __('login') . ' ' . __('succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2006);
        }
    }

    /**
     * 密码重置成功
     *
     * @param ResetPasswordRequest $request
     * @return Response
     */
    public function resetPassword(ResetPasswordRequest $request)
    {
        $result = $this->service->resetPassword($request);
        if ($result) {
            return $this->success($result, __('password_reset_succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2005);
        }
    }

    /**
     * 密码重置成功
     *
     * @param ResetPasswordRequest $request
     * @return Response
     */
    public function retrievePassword(ResetPasswordRequest $request)
    {
        $result = $this->service->retrievePassword($request);
        if ($result) {
            return $this->success($result, __('password_retrieved_succeeded'), 0, $result->token);
        } else {
            return $this->error($this->service->getMessage(), 2005);
        }
    }

    /**
     * 退出
     *
     * @param Request $request
     * @return Response
     */
    public function logout(Request $request)
    {
        $result = $this->service->logout($request);
        if ($result) {
            return $this->success(null, __('logout_succeeded'));
        } else {
            return $this->error($this->service->getMessage(), 2006);
        }
    }
}