Files

34 lines
1.4 KiB
PHP
Raw Permalink Normal View History

<?php
// +----------------------------------------------------------------------
// | Author: ScottPan Team
// +----------------------------------------------------------------------
namespace app\http\middleware\api;
use app\services\message\service\StoreServiceServices;
use app\services\store\DeliveryServiceServices;
use app\services\store\SystemStoreStaffServices;
use crmeb\interfaces\MiddlewareInterface;
use app\Request;
class CustomerMiddleware implements MiddlewareInterface
{
public function handle(Request $request, \Closure $next)
{
$uid = (int)$request->uid();
/** @var StoreServiceServices $services */
$services = app()->make(StoreServiceServices::class);
/** @var SystemStoreStaffServices $storeServices */
$storeServices = app()->make(SystemStoreStaffServices::class);
$rule = trim(strtolower($request->rule()->getRule()));
/** @var DeliveryServiceServices $deliveryService */
$deliveryService = app()->make(DeliveryServiceServices::class);
$isDelivery = $deliveryService->checkoutIsService($uid);
$withRule = ['/api/order/order_verific', "/api/admin/order/detail/<orderId>"];
if (((!$services->checkoutIsService(['uid' => $uid, 'account_status' => 1, 'customer' => 1]) && !$storeServices->verifyStatus($uid)) && !$isDelivery) && !(in_array($rule, $withRule)))
return app('json')->fail('权限不足');
return $next($request);
}
}