User.php 9.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. <?php
  2. namespace app\common\controller;
  3. use think\App;
  4. use app\enterprise\model\User as UserModel;
  5. use app\enterprise\model\Group;
  6. use app\admin\model\UserView;
  7. use think\facade\Session;
  8. use app\admin\model\UserSession;
  9. use think\facade\Db;
  10. use GatewayClient\Gateway;
  11. /**
  12. * 控制器基础类
  13. */
  14. class User
  15. {
  16. /**
  17. * Request实例
  18. * @var \think\Request
  19. */
  20. protected $request;
  21. /**
  22. * 应用实例
  23. * @var \think\App
  24. */
  25. protected $app;
  26. protected $lang;
  27. /**
  28. * 构造方法
  29. * @access public
  30. * @param App $app 应用对象
  31. */
  32. public function __construct(App $app)
  33. {
  34. Gateway::$registerAddress = config('gateway.registerAddress');
  35. $this->app = $app;
  36. $this->request = $this->app->request;
  37. $this->lang = request()->header('Lang', 'en');
  38. }
  39. public function login(){
  40. $token = $this->request->param('token');
  41. if (!$token) {
  42. return json(['code' => 400, 'msg' => 'user.token_error']);
  43. }
  44. try {
  45. Db::startTrans();
  46. $user_id = UserSession::where('token',$token)->where('expire_time','>', time())->value('user_id');
  47. if(!$user_id){
  48. return json(['code' => 400, 'msg' => 'user.token_error']);
  49. }
  50. $cs_uid = getAutoCsUid();
  51. $userInfo=UserModel::where('user_id', $user_id)->withoutField('register_ip,login_count,update_time,create_time')->find();
  52. // 如果用户已经有设置
  53. $setting=$userInfo['setting'] ?: '';
  54. if($setting){
  55. $setting['hideMessageName']= $setting['hideMessageName']=='true' ? true : false;
  56. $setting['hideMessageTime']= $setting['hideMessageTime']=='true' ? true : false;
  57. $setting['avatarCricle']= $setting['avatarCricle']=='true' ? true : false;
  58. $setting['isVoice']= $setting['isVoice']=='true' ? true : false;
  59. $setting['sendKey']= 1;//(int)$setting['sendKey'];
  60. $userInfo['setting']=$setting;
  61. }
  62. if($userInfo['status']==0){
  63. return warning(lang('user.forbid'));
  64. }
  65. $update=[
  66. 'last_login_time'=>time(),
  67. 'login_count'=>Db::raw('login_count+1'),
  68. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  69. 'language' => $this->lang,
  70. ];
  71. if ($userInfo['cs_uid'] == 1) {
  72. $update['cs_uid'] = $cs_uid;
  73. }
  74. if (!empty($params['realname'])) {
  75. $update['realname'] = $params['realname'];
  76. }
  77. UserModel::where('user_id',$userInfo['user_id'])->update($update);
  78. //记录用户浏览
  79. if (!empty($_SERVER['HTTP_REFERER']))
  80. UserView::addData($_SERVER['HTTP_REFERER'],$userInfo['user_id']);
  81. Db::commit();
  82. } catch (\Exception $e) {
  83. Db::rollback();
  84. return json(['code' => 400, 'msg' => $e->getMessage()]);
  85. }
  86. //如果登录信息中含有client——id则自动进行绑定
  87. $client_id=$this->request->param('client_id');
  88. if($client_id){
  89. $cid=$this->request->header('cid','');
  90. $this->doBindUid($userInfo['user_id'],$client_id,$cid);
  91. }
  92. $userInfo['qrUrl']=getMainHost().'/scan/u/'.encryptIds($userInfo['user_id']);
  93. unset($userInfo['password'],$userInfo['salt']);
  94. $userInfo['displayName']=$userInfo['realname'];
  95. $userInfo['id']=$userInfo['user_id'];
  96. $authToken=UserModel::refreshToken($userInfo,$param['terminal'] ?? 'web');
  97. $data=[
  98. 'sessionId'=>Session::getId(),
  99. 'authToken'=>$authToken,
  100. 'userInfo'=>$userInfo
  101. ];
  102. return success(lang('user.loginOk'),$data);
  103. }
  104. //客户端登录
  105. public function login2(){
  106. $params=request()->param();
  107. $where['role'] = 0;
  108. if (empty($params['account']) || empty($params['uid']) || empty($params['from'])) {
  109. return json(['code' => 400, 'msg' => '参数错误']);
  110. }
  111. if (!empty($params['account'])) {
  112. $where[] = ['account', '=', $params['account']];
  113. }
  114. if (!empty($params['from'])) {
  115. $where[] = ['from', '=', $params['from']];
  116. }
  117. if (!empty($params['uid'])) {
  118. $where[] = ['uid', '=', $params['uid']];
  119. }
  120. try {
  121. Db::startTrans();
  122. $cs_uid = getAutoCsUid();
  123. $userInfo=UserModel::where($where)->withoutField('register_ip,login_count,update_time,create_time')->find();
  124. if($userInfo==null){
  125. $salt = \utils\Str::random(4);
  126. $userInfo = UserModel::create([
  127. 'account'=>$params['account'],
  128. 'realname'=> !empty($params['realname']) ? $params['realname'] : $params['account'],
  129. 'name_py' => !empty($params['realname']) ? pinyin_sentence($params['realname']) : '',
  130. 'phone'=>!empty($params['phone']) ? $params['phone'] : '',
  131. 'email'=>!empty($params['email']) ? $params['email'] : '',
  132. 'from'=>$params['from'],
  133. 'uid'=>$params['uid'],
  134. 'salt' => $salt,
  135. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  136. 'password' => password_hash_tp(123456,$salt),
  137. 'cs_uid' => $cs_uid,
  138. 'role' => 0,
  139. 'status' =>1,
  140. 'register_ip' => $this->request->ip(),
  141. 'last_login_ip' => $this->request->ip(),
  142. 'last_login_time' => time(),
  143. 'login_count' => 1
  144. ]);
  145. // 监听用户注册后的操作
  146. event('UserRegister',['user_id' => $userInfo['user_id'], 'realname' => $userInfo['realname'], 'language_code' => $this->lang]);
  147. } else {
  148. //$userInfo['avatar']=avatarUrl($userInfo['avatar'],$userInfo['realname'],$userInfo['user_id']);
  149. // 如果用户已经有设置
  150. $setting=$userInfo['setting'] ?: '';
  151. if($setting){
  152. $setting['hideMessageName']= $setting['hideMessageName']=='true' ? true : false;
  153. $setting['hideMessageTime']= $setting['hideMessageTime']=='true' ? true : false;
  154. $setting['avatarCricle']= $setting['avatarCricle']=='true' ? true : false;
  155. $setting['isVoice']= $setting['isVoice']=='true' ? true : false;
  156. $setting['sendKey']= 1;//(int)$setting['sendKey'];
  157. $userInfo['setting']=$setting;
  158. }
  159. }
  160. if($userInfo['status']==0){
  161. return warning(lang('user.forbid'));
  162. }
  163. $update=[
  164. 'last_login_time'=>time(),
  165. 'last_login_ip'=>$this->request->ip(),
  166. 'login_count'=>Db::raw('login_count+1'),
  167. 'avatar' => !empty($params['avatar']) ? $params['avatar'] : '',
  168. 'language' => $this->lang,
  169. ];
  170. if ($userInfo['cs_uid'] == 1) {
  171. $update['cs_uid'] = $cs_uid;
  172. }
  173. if (!empty($params['realname'])) {
  174. $update['realname'] = $params['realname'];
  175. }
  176. UserModel::where('user_id',$userInfo['user_id'])->update($update);
  177. //记录用户浏览
  178. if (!empty($_SERVER['HTTP_REFERER']))
  179. UserView::addData($_SERVER['HTTP_REFERER'],$userInfo['user_id']);
  180. Db::commit();
  181. } catch (\Exception $e) {
  182. Db::rollback();
  183. return json(['code' => 400, 'msg' => $e->getMessage()]);
  184. }
  185. //如果登录信息中含有client——id则自动进行绑定
  186. $client_id=$this->request->param('client_id');
  187. if($client_id){
  188. $cid=$this->request->header('cid','');
  189. $this->doBindUid($userInfo['user_id'],$client_id,$cid);
  190. }
  191. $userInfo['qrUrl']=getMainHost().'/scan/u/'.encryptIds($userInfo['user_id']);
  192. unset($userInfo['password'],$userInfo['salt']);
  193. $userInfo['displayName']=$userInfo['realname'];
  194. $userInfo['id']=$userInfo['user_id'];
  195. $authToken=UserModel::refreshToken($userInfo,$param['terminal'] ?? 'web');
  196. $data=[
  197. 'sessionId'=>Session::getId(),
  198. 'authToken'=>$authToken,
  199. 'userInfo'=>$userInfo
  200. ];
  201. return success(lang('user.loginOk'),$data);
  202. }
  203. // 执行绑定
  204. public function doBindUid($user_id,$client_id,$cid=''){
  205. // 如果当前ID在线,将其他地方登陆挤兑下线
  206. if(Gateway::isUidOnline($user_id)){
  207. wsSendMsg($user_id,'offline',['id'=>$user_id,'client_id'=>$client_id,'isMobile'=>$this->request->isMobile()]);
  208. }
  209. Gateway::bindUid($client_id, $user_id);
  210. // 查询团队,如果有团队则加入团队
  211. $group=Group::getMyGroup(['gu.user_id'=>$user_id,'gu.status'=>1]);
  212. if($group){
  213. $group=$group->toArray();
  214. $group_ids=arrayToString($group,'group_id',false);
  215. foreach($group_ids as $v){
  216. Gateway::joinGroup($client_id, $v);
  217. }
  218. }
  219. if($cid){
  220. bindCid($user_id,$cid);
  221. }
  222. wsSendMsg(0,'isOnline',['id'=>$user_id,'is_online'=>1]);
  223. }
  224. }