where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'status' => 1])->select('id, admin_id')->asArray()->one(); if($salesman){ $agent = Admin::findOne($salesman['admin_id']); if($agent['type'] != Admin::ADMIN_TYPE_BD_AGENT){ $salesman = null; } } //判断是否为代理 $admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'admin'])->select('id')->one(); //判断是否为推广代理 $db_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => Admin::ADMIN_TYPE_BD_AGENT])->select('id')->one(); //判断是否为推广代理 $goods_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => Admin::ADMIN_TYPE_GOODS_AGENT])->select('id')->one(); //判断是否为商城管理员 $store_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'store'])->select('type_id')->one(); $store_admin_store_id = 0; if ($store_admin) { $store_admin_store_id = $store_admin->type_id; } else { $store_audit = StoreAudit::findOne(['saas_user_id' => $saas_user->id, 'status' => 1]); if ($store_audit) { $MerchantInfo = MerchantInfo::findOne($store_audit->merchant_info_id); if ($MerchantInfo) { $store_admin_store_id = $MerchantInfo->bind_store_id; } } } $store = Store::findOne(['id' => $store_admin_store_id, 'is_delete' => 0]); //判断是否有采购权限 $storeCloud = StoreCloud::findOne(['is_delete' => 0, 'is_enable' => 1, 'saas_user_id' => $saas_user->id]); $admin_ = Admin::findOne(['saas_user_id' => $saas_user->id, 'type' => 'store']); if ($admin_ && !empty($storeCloud) && empty($storeCloud->store_id)) { $storeCloud->store_id = $admin_->type_id; $storeCloud->save(); } $is_can_distribution = $storeCloud && !empty($storeCloud->store_id) ? 1 : 0;// 是否有商城(是否可以铺货) $is_can_distribution = $is_can_distribution && !empty($storeCloud->can_distribution) ? 1 : 0;// 否具备 一键铺货选品的权限 $driver = Driver::findOne(['saas_user_id' => $saas_user->id, 'is_delete' => 0]); if($driver){ $agent = Admin::findOne($driver['admin_id']); if($agent['type'] != Admin::ADMIN_TYPE_FRONT_AGENT){ $driver = null; } } $is_rider = 0; $rider = LocalDeliveryCourier::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'state' => 2])->asArray()->one(); if(!empty($rider)) { $is_rider = 1; $area = Json::decode($rider['area'], true); $village = District::findOne($area[0]['village_id']); $town = District::findOne($area[0]['town_id']); $district = District::findOne($area[0]['district_id']); $city = District::findOne($area[0]['city_id']); $province = District::findOne($area[0]['province_id']); if ($village) { $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name . '/' . $town->name . '/' . $village->name; } elseif ($town) { $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name . '/' . $town->name; } elseif ($district) { $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name; } else { $rider['area_name'] = ''; } }else{ $rider = LocalDeliveryCourier::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'state' => 1])->asArray()->one(); if($rider){ $rider = [ 'code' => 1, 'msg' => '正在审核,暂时无法操作', 'data' => $rider, ]; } } //同城配送设置相关 $values = Option::find()->where(['store_id' => 0, 'group' => OptionSetting::LOCAL_DELIVERY_GROUP_NAME, 'name' => OptionSetting::LOCAL_DELIVERY_SETTING])->select('value')->one(); if($values){ $local_setting = json_decode($values->value, true); }else{ $local_setting = null; } //判断是否为运营人员 $storeOperations = StoreOperations::findOne(['saas_id' => $saas_user->id, 'is_delete' => 0, 'status' => 1]); $is_store_operations = 0; if (!empty($storeOperations)) { $is_store_operations = 1; } /* end */ return $this->asJson([ 'code' => 0, 'msg' => 'success', 'data' => [ 'info' => [ 'name' => $saas_user->name, 'avatar' => $saas_user->avatar ], 'auth' => [ 'is_driver' => !empty($driver) ? 1 : 0, 'is_salesman' => !empty($salesman) ? 1 : 0, 'is_admin' => !empty($admin) ? 1 : 0, 'is_store_admin' => !empty($store) ? 1 : 0, 'is_purchase' => !empty($storeCloud) ? 1 : 0, 'is_can_distribution' => $is_can_distribution, // 是否有商城(是否可以铺货) 'can_distribution' => $storeCloud['can_distribution'], // 否具备 一键铺货选品的权限 'is_db_admin' => !empty($db_admin) ? 1 : 0, 'is_goods_admin' => !empty($goods_admin) ? 1 : 0, 'is_rider' => $is_rider, //是否为骑手 'is_store_operations' => $is_store_operations ], 'local_setting' => $local_setting, 'courier' => $rider, 'store_list' => store::find()->where(['is_delete' => 0])->select('id,name')->all(), ] ]); } catch (\Exception $e) { return $this->asJson([ 'code' => 1, 'msg' => $e->getMessage() . $e->getLine() . $e->getFile() ]); } } /** * 检测是否可免登录 */ public function actionCheckLogin() { try { $access_token = input_params('access_token'); $saas_user = SaasUser::findOne(['access_token' => $access_token]); if (!$saas_user) { return $this->asJson([ 'code' => 401, 'msg' => '请重新登录' ]); } try { \Yii::$app->jwt->getPayload(); return $this->asJson([ 'code' => 0, 'msg' => '登录成功' ]); } catch (\Exception $e) { } $type_id = 0; $admin = Admin::findOne(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'store', 'type_id' => get_store_id()]); if ($admin) { $store = Store::findOne(['id' => $admin->type_id, 'is_delete' => 0]); if ($store) { $type_id = $admin->type_id; } } else { $store_admin = StoreAdmin::findOne(['is_delete' => 0, 'saas_id' => $saas_user->id, 'store_id' => get_store_id()]); if ($store_admin) { $store = Store::findOne(['id' => $store_admin->store_id, 'is_delete' => 0]); if ($store) { $type_id = $store_admin->store_id; } } } if (isset($store)) { $token = $this->setToken($type_id, 1, $store_admin->id ?? 0); return $this->asJson([ 'code' => 0, 'msg' => '登录成功', 'data' => [ 'Authorization' => $token ] ]); } else { return $this->asJson([ 'code' => 0, 'msg' => '未找到管理信息,需要手动登陆', 'status' => 401 ]); } } catch (\Exception $e) { return $this->asJson([ 'code' => 1, 'msg' => $e->getMessage() ]); } } //手机端管理员登录 public function actionLogin() { $model = new AdminForm(); $model->attributes = post_params(); $model->validatePassword('password'); if ($model->login()) { try { $admin = $model->getAdmin(); if ($admin->type !== Admin::ADMIN_TYPE_MINI_ADMIN) { throw new \Exception('账户类型错误'); } $store_admin = StoreAdmin::findOne(['id' => $admin->type_id, 'is_delete' => 0, 'status' => 1]); if (empty($store_admin)) { throw new \Exception('账户错误,或被禁用'); } $token = $this->setToken($store_admin->id); return $this->asJson([ 'code' => 0, 'msg' => '登录成功', 'data' => [ 'Authorization' => $token ] ]); } catch (\Throwable $throwable) { return $this->asJson([ 'code' => 1, 'msg' => $throwable->getMessage(), ]); } } return $this->asJson([ 'code' => 1, 'msg' => $model->getFirstErrors()['password'] ]); } //生成token public function setToken($id, $type = 0, $store_admin_id = 0) { if ($type) { $admin_type = Admin::ADMIN_TYPE_STORE; // $store_admin_id = 0; } else { $store_admin = StoreAdmin::findOne($id); $admin_type = Admin::ADMIN_TYPE_MINI_ADMIN; $store_admin_id = $store_admin->id; } $admin = Admin::findOne(['type' => $admin_type, 'type_id' => $id, 'is_delete' => 0]); $time = time(); $payload = [ 'iss' => \Yii::$app->request->hostInfo, 'iat' => $time, 'exp' => $time + 86400, 'admin_id' => $admin->id, 'username' => $admin->username, 'store_admin_id' => $store_admin_id ]; return \Yii::$app->jwt->createToken($payload); } }