User.php 9.5 KB

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