AuthIdentifier.php 1.63 KB
<?php

namespace App\Http\Middleware;

use App\Helper\AesEncrypt;
use App\Helper\ErrorCode;
use App\Helper\Identifier;
use App\Helper\Response;
use App\Models\Legal\Stakeholder;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Log;

/**
 * Class AuthIdentifier
 * @package App\Http\Middleware
 */
class AuthIdentifier
{
    protected $auth = [
        'api'
    ];

    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle(Request $request, Closure $next)
    {
        $prefix = current(explode('/', $request->path()));
        if (!in_array($prefix, $this->auth)) goto AUTH;

        $identifier = $request->header('identifier');

        if (env('APP_ENV') == 'local' && empty($identifier)) {
            $identifier = env('identifier');
        }

        Log::info(__METHOD__. '解析前:', ['identifier'=>$identifier]);

        !empty($identifier) && $identifier = Identifier::resolve($identifier);

        Log::info(__METHOD__. '解析后', ['identifier'=>$identifier]);

        if (empty($identifier)) return Response::error(ErrorCode::IDENTIFIER_FAIL);

        $identifier = json_decode($identifier);

        //通过身份证查询id
        $stakeholder_ids = Stakeholder::stakeholderIds($identifier);
        if (empty($stakeholder_ids)) return Response::error(ErrorCode::MATCH_IDENTIFIER_FAIL);

        $request->attributes->add([
            'identifier' => $identifier,
            'stakeholder_ids' => $stakeholder_ids,
        ]);

        AUTH:

        return $next($request);
    }
}