MerchantInfoController.php 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289
  1. <?php
  2. /**
  3. * 重庆赤晓店信息科技有限公司
  4. * https://www.chixiaodian.com
  5. * Copyright (c) 2023 赤店商城 All rights reserved.
  6. */
  7. namespace app\modules\client\controllers\v1\merchant;
  8. use app\constants\OptionSetting;
  9. use app\models\Admin;
  10. use app\models\District;
  11. use app\models\MerchantInfo;
  12. use app\models\SaasUser;
  13. use app\models\Salesman;
  14. use app\models\Store;
  15. use app\models\StoreAdmin;
  16. use app\models\StoreAudit;
  17. use app\models\StoreCloud;
  18. use app\models\Driver;
  19. use app\models\LocalDeliveryCourier;
  20. use app\models\Option;
  21. use app\models\StoreOperations;
  22. use app\modules\admin\models\AdminForm;
  23. use app\modules\admin\models\MerchantForm;
  24. use app\modules\alliance\controllers\BaseController;
  25. use yii\helpers\Json;
  26. class MerchantInfoController extends BaseController
  27. {
  28. public function actionIndex()
  29. {
  30. try {
  31. $saas_user = get_saas_user();
  32. //判断是否为业务员
  33. $salesman = Salesman::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'status' => 1])->select('id, admin_id')->asArray()->one();
  34. if($salesman){
  35. $agent = Admin::findOne($salesman['admin_id']);
  36. if($agent['type'] != Admin::ADMIN_TYPE_BD_AGENT){
  37. $salesman = null;
  38. }
  39. }
  40. //判断是否为代理
  41. $admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'admin'])->select('id')->one();
  42. //判断是否为推广代理
  43. $db_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => Admin::ADMIN_TYPE_BD_AGENT])->select('id')->one();
  44. //判断是否为推广代理
  45. $goods_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => Admin::ADMIN_TYPE_GOODS_AGENT])->select('id')->one();
  46. //判断是否为商城管理员
  47. $store_admin = Admin::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'store'])->select('type_id')->one();
  48. $store_admin_store_id = 0;
  49. if ($store_admin) {
  50. $store_admin_store_id = $store_admin->type_id;
  51. } else {
  52. $store_audit = StoreAudit::findOne(['saas_user_id' => $saas_user->id, 'status' => 1]);
  53. if ($store_audit) {
  54. $MerchantInfo = MerchantInfo::findOne($store_audit->merchant_info_id);
  55. if ($MerchantInfo) {
  56. $store_admin_store_id = $MerchantInfo->bind_store_id;
  57. }
  58. }
  59. }
  60. $store = Store::findOne(['id' => $store_admin_store_id, 'is_delete' => 0]);
  61. //判断是否有采购权限
  62. $storeCloud = StoreCloud::findOne(['is_delete' => 0, 'is_enable' => 1, 'saas_user_id' => $saas_user->id]);
  63. $admin_ = Admin::findOne(['saas_user_id' => $saas_user->id, 'type' => 'store']);
  64. if ($admin_ && !empty($storeCloud) && empty($storeCloud->store_id)) {
  65. $storeCloud->store_id = $admin_->type_id;
  66. $storeCloud->save();
  67. }
  68. $is_can_distribution = $storeCloud && !empty($storeCloud->store_id) ? 1 : 0;// 是否有商城(是否可以铺货)
  69. $is_can_distribution = $is_can_distribution && !empty($storeCloud->can_distribution) ? 1 : 0;// 否具备 一键铺货选品的权限
  70. $driver = Driver::findOne(['saas_user_id' => $saas_user->id, 'is_delete' => 0]);
  71. if($driver){
  72. $agent = Admin::findOne($driver['admin_id']);
  73. if($agent['type'] != Admin::ADMIN_TYPE_FRONT_AGENT){
  74. $driver = null;
  75. }
  76. }
  77. $is_rider = 0;
  78. $rider = LocalDeliveryCourier::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'state' => 2])->asArray()->one();
  79. if(!empty($rider)) {
  80. $is_rider = 1;
  81. $area = Json::decode($rider['area'], true);
  82. $village = District::findOne($area[0]['village_id']);
  83. $town = District::findOne($area[0]['town_id']);
  84. $district = District::findOne($area[0]['district_id']);
  85. $city = District::findOne($area[0]['city_id']);
  86. $province = District::findOne($area[0]['province_id']);
  87. if ($village) {
  88. $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name . '/' . $town->name . '/' . $village->name;
  89. } elseif ($town) {
  90. $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name . '/' . $town->name;
  91. } elseif ($district) {
  92. $rider['area_name'] = $province->name . '/' . $city->name . '/' . $district->name;
  93. } else {
  94. $rider['area_name'] = '';
  95. }
  96. }else{
  97. $rider = LocalDeliveryCourier::find()->where(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'state' => 1])->asArray()->one();
  98. if($rider){
  99. $rider = [
  100. 'code' => 1,
  101. 'msg' => '正在审核,暂时无法操作',
  102. 'data' => $rider,
  103. ];
  104. }
  105. }
  106. //同城配送设置相关
  107. $values = Option::find()->where(['store_id' => 0,
  108. 'group' => OptionSetting::LOCAL_DELIVERY_GROUP_NAME, 'name' => OptionSetting::LOCAL_DELIVERY_SETTING])->select('value')->one();
  109. if($values){
  110. $local_setting = json_decode($values->value, true);
  111. }else{
  112. $local_setting = null;
  113. }
  114. //判断是否为运营人员
  115. $storeOperations = StoreOperations::findOne(['saas_id' => $saas_user->id, 'is_delete' => 0, 'status' => 1]);
  116. $is_store_operations = 0;
  117. if (!empty($storeOperations)) {
  118. $is_store_operations = 1;
  119. }
  120. /* end */
  121. return $this->asJson([
  122. 'code' => 0,
  123. 'msg' => 'success',
  124. 'data' => [
  125. 'info' => [
  126. 'name' => $saas_user->name,
  127. 'avatar' => $saas_user->avatar
  128. ],
  129. 'auth' => [
  130. 'is_driver' => !empty($driver) ? 1 : 0,
  131. 'is_salesman' => !empty($salesman) ? 1 : 0,
  132. 'is_admin' => !empty($admin) ? 1 : 0,
  133. 'is_store_admin' => !empty($store) ? 1 : 0,
  134. 'is_purchase' => !empty($storeCloud) ? 1 : 0,
  135. 'is_can_distribution' => $is_can_distribution, // 是否有商城(是否可以铺货)
  136. 'can_distribution' => $storeCloud['can_distribution'], // 否具备 一键铺货选品的权限
  137. 'is_db_admin' => !empty($db_admin) ? 1 : 0,
  138. 'is_goods_admin' => !empty($goods_admin) ? 1 : 0,
  139. 'is_rider' => $is_rider, //是否为骑手
  140. 'is_store_operations' => $is_store_operations
  141. ],
  142. 'local_setting' => $local_setting,
  143. 'courier' => $rider,
  144. 'store_list' => store::find()->where(['is_delete' => 0])->select('id,name')->all(),
  145. ]
  146. ]);
  147. } catch (\Exception $e) {
  148. return $this->asJson([
  149. 'code' => 1,
  150. 'msg' => $e->getMessage() . $e->getLine() . $e->getFile()
  151. ]);
  152. }
  153. }
  154. /**
  155. * 检测是否可免登录
  156. */
  157. public function actionCheckLogin() {
  158. try {
  159. $access_token = input_params('access_token');
  160. $saas_user = SaasUser::findOne(['access_token' => $access_token]);
  161. if (!$saas_user) {
  162. return $this->asJson([
  163. 'code' => 401,
  164. 'msg' => '请重新登录'
  165. ]);
  166. }
  167. try {
  168. \Yii::$app->jwt->getPayload();
  169. return $this->asJson([
  170. 'code' => 0,
  171. 'msg' => '登录成功'
  172. ]);
  173. } catch (\Exception $e) {
  174. }
  175. $type_id = 0;
  176. $admin = Admin::findOne(['saas_user_id' => $saas_user->id, 'is_delete' => 0, 'type' => 'store', 'type_id' => get_store_id()]);
  177. if ($admin) {
  178. $store = Store::findOne(['id' => $admin->type_id, 'is_delete' => 0]);
  179. if ($store) {
  180. $type_id = $admin->type_id;
  181. }
  182. } else {
  183. $store_admin = StoreAdmin::findOne(['is_delete' => 0, 'saas_id' => $saas_user->id, 'store_id' => get_store_id()]);
  184. if ($store_admin) {
  185. $store = Store::findOne(['id' => $store_admin->store_id, 'is_delete' => 0]);
  186. if ($store) {
  187. $type_id = $store_admin->store_id;
  188. }
  189. }
  190. }
  191. if (isset($store)) {
  192. $token = $this->setToken($type_id, 1, $store_admin->id ?? 0);
  193. return $this->asJson([
  194. 'code' => 0,
  195. 'msg' => '登录成功',
  196. 'data' => [
  197. 'Authorization' => $token
  198. ]
  199. ]);
  200. } else {
  201. return $this->asJson([
  202. 'code' => 0,
  203. 'msg' => '未找到管理信息,需要手动登陆',
  204. 'status' => 401
  205. ]);
  206. }
  207. } catch (\Exception $e) {
  208. return $this->asJson([
  209. 'code' => 1,
  210. 'msg' => $e->getMessage()
  211. ]);
  212. }
  213. }
  214. //手机端管理员登录
  215. public function actionLogin() {
  216. $model = new AdminForm();
  217. $model->attributes = post_params();
  218. $model->validatePassword('password');
  219. if ($model->login()) {
  220. try {
  221. $admin = $model->getAdmin();
  222. if ($admin->type !== Admin::ADMIN_TYPE_MINI_ADMIN) {
  223. throw new \Exception('账户类型错误');
  224. }
  225. $store_admin = StoreAdmin::findOne(['id' => $admin->type_id, 'is_delete' => 0, 'status' => 1]);
  226. if (empty($store_admin)) {
  227. throw new \Exception('账户错误,或被禁用');
  228. }
  229. $token = $this->setToken($store_admin->id);
  230. return $this->asJson([
  231. 'code' => 0,
  232. 'msg' => '登录成功',
  233. 'data' => [
  234. 'Authorization' => $token
  235. ]
  236. ]);
  237. } catch (\Throwable $throwable) {
  238. return $this->asJson([
  239. 'code' => 1,
  240. 'msg' => $throwable->getMessage(),
  241. ]);
  242. }
  243. }
  244. return $this->asJson([
  245. 'code' => 1,
  246. 'msg' => $model->getFirstErrors()['password']
  247. ]);
  248. }
  249. //生成token
  250. public function setToken($id, $type = 0, $store_admin_id = 0) {
  251. if ($type) {
  252. $admin_type = Admin::ADMIN_TYPE_STORE;
  253. // $store_admin_id = 0;
  254. } else {
  255. $store_admin = StoreAdmin::findOne($id);
  256. $admin_type = Admin::ADMIN_TYPE_MINI_ADMIN;
  257. $store_admin_id = $store_admin->id;
  258. }
  259. $admin = Admin::findOne(['type' => $admin_type, 'type_id' => $id, 'is_delete' => 0]);
  260. $time = time();
  261. $payload = [
  262. 'iss' => \Yii::$app->request->hostInfo,
  263. 'iat' => $time,
  264. 'exp' => $time + 86400,
  265. 'admin_id' => $admin->id,
  266. 'username' => $admin->username,
  267. 'store_admin_id' => $store_admin_id
  268. ];
  269. return \Yii::$app->jwt->createToken($payload);
  270. }
  271. }