MemberController.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. <?php
  2. namespace backend\controllers;
  3. use backend\helpers\PaginationHelper;
  4. use backend\helpers\ValidatorHelper;
  5. use backend\models\Member;
  6. use backend\models\Mt4Users;
  7. use backend\models\Open;
  8. use backend\models\UserMember;
  9. use backend\helpers\LogHelper;
  10. use Yii;
  11. class MemberController extends BaseController
  12. {
  13. /**
  14. * 用户信息
  15. * @return \yii\web\Response
  16. */
  17. public function actionInfo()
  18. {
  19. $id = Yii::$app->getRequest()->get('id');
  20. $fields = Yii::$app->getRequest()->get('fields');
  21. if ($fields == null || trim($fields) === '') {
  22. $fields = Member::getTableSchema()->getColumnNames();
  23. unset($fields['password']);
  24. } elseif (!is_array($fields)) {
  25. $fields = preg_split('/\s*,\s*/', $fields, -1, PREG_SPLIT_NO_EMPTY);
  26. }
  27. $model = Member::find()->select($fields)->where(['id' => $id])->limit(1)->one();
  28. $data = $model->getAttributes();
  29. $data['member_id'] = UserMember::find()->select('member_id')->where(['login' => $data['logins']])->limit(1)->one()->member_id;
  30. if ($model == null) {
  31. return $this->outJson(0, [], '用户不存在');
  32. }
  33. return $this->outJson(1, $data, 'OK');
  34. }
  35. /**
  36. * 切换MT4账户
  37. * @return \yii\web\Response
  38. */
  39. public function actionSwitch()
  40. {
  41. $id = Yii::$app->getRequest()->get('id');
  42. $login = Yii::$app->getRequest()->get('login');
  43. /** @var Member $model */
  44. $model = Member::find()->where(['id' => $id])->limit(1)->one();
  45. if ($model == null) {
  46. return $this->outJson(0, [], '用户不存在');
  47. }
  48. $loginArr = explode(',', $model['logins']);
  49. if (in_array($login, $loginArr)) {
  50. $model->main_login = $login;
  51. if ($model->save()) {
  52. return $this->outJson(1, [], 'OK');
  53. } else {
  54. return $this->outJson(0, [], $model->getErrors());
  55. }
  56. } else {
  57. return $this->outJson(0, [], 'login不属于当前用户');
  58. }
  59. }
  60. /**
  61. * 获取下级代理商
  62. */
  63. public function actionGetIbs()
  64. {
  65. $id = (int) Yii::$app->request->get('id');
  66. $model = new Member();
  67. $ibs = $model->findChildrenIncludeSelf($id);
  68. return $this->outJson(1, $ibs, '');
  69. }
  70. /**
  71. * @return \yii\web\Response
  72. */
  73. public function actionCheckemailexist()
  74. {
  75. $email = trim(Yii::$app->getRequest()->get('email'));
  76. if ($email == '') {
  77. return $this->outJson(0, [], '邮箱不能为空');
  78. }
  79. //if (Member::checkEmailExist($email) || Open::checkEmailExist($email)) {
  80. if (Member::checkEmailExist($email)) {
  81. return $this->outJson(0, [], '邮箱已被注册');
  82. }
  83. return $this->outJson(1, [], '邮箱未被注册');
  84. }
  85. /**
  86. * @return \yii\web\Response
  87. */
  88. public function actionCheckidnoexist()
  89. {
  90. $idNo = trim(Yii::$app->getRequest()->get('id_no'));
  91. if ($idNo == '') {
  92. return $this->outJson(0, [], '身份证不能为空');
  93. }
  94. // if (Member::checkIdNoExist($idNo) || Open::checkIdNoExist($idNo)) {
  95. if (Member::checkIdNoExist($idNo)) {
  96. return $this->outJson(0, [], '身份证已被注册');
  97. }
  98. return $this->outJson(1, [], '身份证未被注册');
  99. }
  100. /**
  101. * 名下代理详情页
  102. */
  103. public function actionGetView()
  104. {
  105. $model = new Member();
  106. $result = $model->getView(Yii::$app->request->post());
  107. if ($result['code']) {
  108. return $this->outJson(1, $result['data']);
  109. } else {
  110. return $this->outJson(0, [], $result['message']);
  111. }
  112. }
  113. /**
  114. * 用户列表
  115. * @return \yii\web\Response
  116. */
  117. public function actionList()
  118. {
  119. $data = Yii::$app->getRequest()->get();
  120. $data['type'] = isset($data['type']) ? trim($data['type']) : '';
  121. $data['search'] = isset($data['search']) ? trim($data['search']) : '';
  122. $data['page'] = isset($data['page']) ? max(intval($data['page']), 1) : 1;
  123. $data['pageSize'] = isset($data['pageSize']) ? intval($data['pageSize']) : 20;
  124. $data['orderBy'] = isset($data['orderBy']) ? trim($data['orderBy']) : 'id desc';
  125. $data = ValidatorHelper::validateData($data, [
  126. ['type', 'required'],
  127. ['search', 'string'],
  128. ['page', 'integer', 'min' => 1],
  129. ['pageSize', 'integer', 'min' => 1],
  130. ['orderBy', 'string'],
  131. ], $errors);
  132. if ($data == false) {
  133. return $this->outJson(0, '', $errors);
  134. }
  135. $query = Member::find()->orderBy($data['orderBy']);
  136. $query->andWhere(['type' => $data['type']]);
  137. $query->andFilterWhere(['or',
  138. ['like', 'username', $data['search']],
  139. ['like', 'name', $data['search']],
  140. ['like', 'ip', $data['search']],
  141. ['like', 'logins', $data['search']],
  142. ]);
  143. $result = PaginationHelper::queryPage($query, $data['page'], $data['pageSize']);
  144. return $this->outJson(1, $result);
  145. }
  146. /**
  147. * 修改用户信息
  148. * @return \yii\web\Response
  149. */
  150. public function actionUpdate()
  151. {
  152. $id = intval(Yii::$app->getRequest()->post('id'));
  153. if ($id <= 0) {
  154. return $this->outJson(0, [], '未指定数据对象');
  155. }
  156. /** @var Member $member */
  157. $member = Member::find()->where(['id' => $id])->one();
  158. if ($member == null) {
  159. return $this->outJson(0, [], '用户不存在');
  160. }
  161. $data = Yii::$app->getRequest()->post();
  162. $username_num = Member::find()->select(['username'])->where(['username' => $data['username']])->andWhere(['!=', 'id', $data['id']])->limit(1)->asArray()->scalar();
  163. if ($username_num) {
  164. return $this->outJson(0, [], '电子邮箱已存在');
  165. }
  166. if(isset($data['password']) && trim($data['password']) != '') {
  167. $data['password'] = $member->hash($data['password']);
  168. } else {
  169. unset($data['password']);
  170. }
  171. $transaction = Member::getDb()->beginTransaction();
  172. try {
  173. //修改客户上级直属代理
  174. if(!empty($data['member_id'])){
  175. $userModel = UserMember::find()->where(['login' => $data['logins']])->limit(1)->one();
  176. $userModel->member_id = $data['member_id'];
  177. $userModel->save();
  178. }
  179. // 修改了ref_id的话,同时也修改ref_path,同时修改他下级代理的ref_path
  180. if (!empty($data['ref_id'])) {
  181. $ref = Member::find()->where(['id' => intval($data['ref_id'])])->limit(1)->asArray()->one();
  182. if ($ref) {
  183. $data['ref_path'] = rtrim($ref['ref_path'], ',') . ',' . $ref['id'] . ','; // 以逗号结尾
  184. $model = new Member();
  185. $ibs = $model->findChildrenIncludeSelf($id);
  186. foreach ($ibs as $k => $v) {
  187. // 把代理其下级代理商的原上级代理的父辈结构改成新代理的父辈结构加上上级代理本身
  188. // 例如,当前代理为260,ref_path为“70,75,1204,”,
  189. // 某个下级代理为491,ref_path为“70,75,1204,260,500,”
  190. // 260的上级代理改成1509,那么其ref_path改成“70,1196,67,1482,1509,”
  191. // 491的ref_path改成“70,1196,67,1482,1509,260,500,”
  192. $ibModel = Member::find()->where(['id' => $v['id']])->limit(1)->one();
  193. $ibModel->ref_path = ltrim(str_replace(','.$member->ref_path, ','.$data['ref_path'], ','.$ibModel->ref_path), ',');
  194. $ibModel->save();
  195. }
  196. } else {
  197. unset($data['ref_id']);
  198. }
  199. }
  200. $member->setAttributes($data);
  201. $res = $member->save();
  202. $transaction->commit();
  203. } catch (\Exception $e) {
  204. $res = false;
  205. $transaction->rollBack();
  206. }
  207. if ($res) {
  208. return $this->outJson(1, $member->getAttributes(null, ['password']), '操作成功');
  209. } else {
  210. return $this->outJson(0, [], '操作失败');
  211. }
  212. }
  213. /**
  214. * 后台代理商列表数据
  215. * @return array
  216. */
  217. public function actionAdminIbList()
  218. {
  219. $model = new Member();
  220. $result = $model->getAdminIbList(Yii::$app->request->post());
  221. if ($result['code']) {
  222. return $this->outJson(1, $result['data']);
  223. } else {
  224. return $this->outJson(0, [], $result['message']);
  225. }
  226. }
  227. /**
  228. * 后台添加代理商
  229. * @return array
  230. */
  231. public function actionAddAdminIb()
  232. {
  233. $model = new Member();
  234. $result = $model->addAdminIb(Yii::$app->request->post());
  235. if ($result['code']) {
  236. return $this->outJson(1, $result['data']);
  237. } else {
  238. return $this->outJson(0, $result['data'], $result['message']);
  239. }
  240. }
  241. /**
  242. * 后台添加用户
  243. * @return array
  244. */
  245. public function actionAddAdminMember()
  246. {
  247. $model = new Member();
  248. $result = $model->addAdminMember(Yii::$app->request->post());
  249. if ($result['code']) {
  250. return $this->outJson(1, $result['data']);
  251. } else {
  252. return $this->outJson(0, $result['data'], $result['message']);
  253. }
  254. }
  255. /**
  256. * 后台代理商名下客户列表数据
  257. * @return array
  258. */
  259. public function actionAdminIbUsersList()
  260. {
  261. $model = new Mt4Users();
  262. $post = Yii::$app->request->post();
  263. $post['member_id'] = $post['id'];
  264. unset($post['id']);
  265. $result = $model->getList($post, false);
  266. if ($result['code']) {
  267. return $this->outJson(1, $result['data']);
  268. } else {
  269. return $this->outJson(0, [], $result['message']);
  270. }
  271. }
  272. /**
  273. * 后台代理商详情页
  274. */
  275. public function actionGetAdminIbView()
  276. {
  277. $model = new Member();
  278. $result = $model->getAdminIbView(Yii::$app->request->post());
  279. if ($result['code']) {
  280. return $this->outJson(1, $result['data']);
  281. } else {
  282. return $this->outJson(0, [], $result['message']);
  283. }
  284. }
  285. /**
  286. * 后台管理员列表数据
  287. * @return array
  288. */
  289. public function actionAdminAdminList()
  290. {
  291. $model = new Member();
  292. $result = $model->getAdminAdminList(Yii::$app->request->post());
  293. if ($result['code']) {
  294. return $this->outJson(1, $result['data']);
  295. } else {
  296. return $this->outJson(0, [], $result['message']);
  297. }
  298. }
  299. /**
  300. * 后台添加管理员
  301. * @return array
  302. */
  303. public function actionAddAdminAdmin()
  304. {
  305. $model = new Member();
  306. $result = $model->addAdminAdmin(Yii::$app->request->post());
  307. if ($result['code']) {
  308. return $this->outJson(1, $result['data']);
  309. } else {
  310. return $this->outJson(0, [], $result['message']);
  311. }
  312. }
  313. /**
  314. * 后台编辑管理员
  315. * @return array
  316. */
  317. public function actionEditAdminAdmin()
  318. {
  319. $model = new Member();
  320. $result = $model->editAdminAdmin(Yii::$app->request->post());
  321. if ($result['code']) {
  322. return $this->outJson(1, $result['data']);
  323. } else {
  324. return $this->outJson(0, [], $result['message']);
  325. }
  326. }
  327. public function actionDelete()
  328. {
  329. $id = intval(Yii::$app->getRequest()->post('id'));
  330. if ($id <= 0) {
  331. return $this->outJson(0, [], '参数非法');
  332. }
  333. $admin_id = intval(Yii::$app->getRequest()->post('admin_id'));
  334. $member_info = Member::findById($id);
  335. $member_info = json_encode($member_info);
  336. LogHelper::writeLog($admin_id,$id,'Member/delete','删除用户',$member_info);
  337. $result = Member::deleteById($id);
  338. if ($result['code'] == 1) {
  339. return $this->outJson(1, [], $result['message']);
  340. } else {
  341. return $this->outJson(0,$result['data'], $result['message']);
  342. }
  343. }
  344. /**
  345. * 通过logins获取member_id
  346. */
  347. public function actionGetIdByLogin()
  348. {
  349. $login = Yii::$app->getRequest()->get('login');
  350. $rs = Member::findByLogin($login, 2);
  351. return $this->outJson(1, $rs['id']);
  352. }
  353. }