| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289 |
- <?php
- /**
- * 重庆赤晓店信息科技有限公司
- * https://www.chixiaodian.com
- * Copyright (c) 2023 赤店商城 All rights reserved.
- */
- namespace app\modules\alliance\controllers\merchant;
- use app\constants\OptionSetting;
- use app\models\Admin;
- use app\models\District;
- use app\models\MerchantInfo;
- use app\models\SaasUser;
- use app\models\Salesman;
- use app\models\Store;
- use app\models\StoreAdmin;
- use app\models\StoreAudit;
- use app\models\StoreCloud;
- use app\models\Driver;
- use app\models\LocalDeliveryCourier;
- use app\models\Option;
- use app\models\StoreOperations;
- use app\modules\admin\models\AdminForm;
- use app\modules\admin\models\MerchantForm;
- use app\modules\alliance\controllers\BaseController;
- use yii\helpers\Json;
- class MerchantInfoController extends BaseController
- {
- public function actionIndex()
- {
- try {
- $saas_user = get_saas_user();
- //判断是否为业务员
- $salesman = Salesman::find()->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, 'status' => 1]);
- 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,
- 'is_agent_staff' => !empty(\app\models\AgentFrontStaff::findOne(['saas_id' => $saas_user->id, 'is_delete' => 0, 'status' => 1]))
- ],
- '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']);
- 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]);
- 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;
- } 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);
- }
- }
|