Userfollow.php 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. <?php
  2. namespace app\api\controller;
  3. use app\common\controller\Api;
  4. use think\Db;
  5. /**
  6. * 关注
  7. */
  8. class Userfollow extends Api
  9. {
  10. protected $noNeedLogin = [];
  11. protected $noNeedRight = ['*'];
  12. //我的关注列表
  13. public function my_follow_list(){
  14. $user_id = input('user_id',0);
  15. if(empty($user_id)){
  16. $user_id = $this->auth->id;
  17. }
  18. $list = Db::name('user_follow')
  19. ->alias('follow')
  20. ->join('user','follow.follow_uid = user.id','LEFT')
  21. ->join('user_wallet uw','user.id = uw.user_id','LEFT')
  22. ->field('user.id,user.username,user.nickname,user.avatar,user.bio,user.birthday,user.gender,user.attribute,uw.vip_endtime')
  23. ->where('follow.uid',$user_id)->order('follow.id desc')->autopage()->select();
  24. $list = list_domain_image($list,['avatar']);
  25. $list = list_birthday_age($list);
  26. //我的关注uids
  27. $my_follow_uids = $this->my_follow_uids();
  28. if(!empty($list)){
  29. foreach($list as $key => &$val){
  30. //用户vip
  31. $val['is_vip'] = $val['vip_endtime'] > time() ? 1 : 0;
  32. unset($val['vip_endtime']);
  33. //是否关注
  34. $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
  35. }
  36. }
  37. $this->success('success',$list);
  38. }
  39. //我的粉丝列表
  40. public function my_fans_list(){
  41. $user_id = input('user_id',0);
  42. if(empty($user_id)){
  43. $user_id = $this->auth->id;
  44. }
  45. $list = Db::name('user_follow')
  46. ->alias('follow')
  47. ->join('user','follow.uid = user.id','LEFT')
  48. ->join('user_wallet uw','user.id = uw.user_id','LEFT')
  49. ->field('user.id,user.username,user.nickname,user.avatar,user.bio,user.birthday,user.gender,user.attribute,uw.vip_endtime')
  50. ->where('follow.follow_uid',$user_id)->order('follow.id desc')->autopage()->select();
  51. $list = list_domain_image($list,['avatar']);
  52. $list = list_birthday_age($list);
  53. //我的关注uids
  54. $my_follow_uids = $this->my_follow_uids();
  55. if(!empty($list)){
  56. foreach($list as $key => &$val){
  57. //用户vip
  58. $val['is_vip'] = $val['vip_endtime'] > time() ? 1 : 0;
  59. unset($val['vip_endtime']);
  60. //是否关注
  61. $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
  62. }
  63. }
  64. $this->success('success',$list);
  65. }
  66. //我的好友,拿粉丝列表改的
  67. public function my_friend_list(){
  68. $list = Db::name('user_follow')
  69. ->alias('follow')
  70. ->join('user','follow.uid = user.id','LEFT')
  71. ->join('user_wallet uw','user.id = uw.user_id','LEFT')
  72. ->field('user.id,user.username,user.nickname,user.avatar,user.bio,user.birthday,user.gender,user.attribute,uw.vip_endtime')
  73. ->where('follow.follow_uid',$this->auth->id)->order('follow.id desc')->autopage()->select();
  74. $list = list_domain_image($list,['avatar']);
  75. $list = list_birthday_age($list);
  76. //我的关注uids
  77. $my_follow_uids = $this->my_follow_uids();
  78. $new_rs = []; //另起
  79. if(!empty($list)){
  80. foreach($list as $key => &$val){
  81. //用户vip
  82. $val['is_vip'] = $val['vip_endtime'] > time() ? 1 : 0;
  83. unset($val['vip_endtime']);
  84. //是否关注
  85. $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
  86. //我的粉丝,且是我的关注的,另起
  87. if($val['is_follow'] == 1){
  88. $new_rs[] = $val;
  89. }
  90. }
  91. }
  92. $this->success('success',$new_rs);
  93. }
  94. //好友审核列表。粉丝列表改的。关注了我,我还没关注他的
  95. //接口废弃,使用 newfriend_list
  96. public function my_fans_unfollow_list(){
  97. //我的关注uids
  98. $my_follow_uids = $this->my_follow_uids();
  99. $list = Db::name('user_follow')
  100. ->alias('follow')
  101. ->join('user','follow.uid = user.id','LEFT')
  102. ->join('user_wallet uw','user.id = uw.user_id','LEFT')
  103. ->field('user.id,user.username,user.nickname,user.avatar,user.bio,user.birthday,user.gender,user.attribute,uw.vip_endtime')
  104. ->where('follow.follow_uid',$this->auth->id)->where('user.id','NOT IN',$my_follow_uids)->order('follow.id desc')->autopage()->select();
  105. $list = list_domain_image($list,['avatar']);
  106. $list = list_birthday_age($list);
  107. if(!empty($list)){
  108. foreach($list as $key => &$val){
  109. //用户vip
  110. $val['is_vip'] = $val['vip_endtime'] > time() ? 1 : 0;
  111. unset($val['vip_endtime']);
  112. //是否关注
  113. $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
  114. }
  115. }
  116. $this->success('success',$list);
  117. }
  118. //好友待审核列表。
  119. public function newfriend_list(){
  120. //我的关注uids
  121. $my_follow_uids = $this->my_follow_uids();
  122. // dump($my_follow_uids);
  123. $list = Db::name('message')->alias('msg')
  124. ->join('user user','user.id = msg.infotype_id','LEFT')
  125. ->join('user_wallet uw','user.id = uw.user_id','LEFT')
  126. ->field('msg.id as msg_id,user.id,user.username,user.nickname,user.avatar,user.bio,user.birthday,user.gender,user.attribute,uw.vip_endtime')
  127. ->where(['msg.infotype'=>'newfriend','msg.user_id'=>$this->auth->id,'msg.status'=>0])
  128. ->where('msg.infotype_id','NOT IN',$my_follow_uids)
  129. ->order('msg.id desc')->autopage()->select();
  130. $list = list_domain_image($list,['avatar']);
  131. $list = list_birthday_age($list);
  132. if(!empty($list)){
  133. foreach($list as $key => &$val){
  134. //用户vip
  135. $val['is_vip'] = $val['vip_endtime'] > time() ? 1 : 0;
  136. unset($val['vip_endtime']);
  137. //是否关注
  138. $val['is_follow'] = in_array($val['id'],$my_follow_uids) ? 1 : 0;
  139. }
  140. }
  141. $this->success('success',$list);
  142. }
  143. //拒绝好友请求
  144. public function refuse_newfriend(){
  145. $id = input('msg_id',0);
  146. $msg_info = Db::name('message')->where('id',$id)->find();
  147. Db::name('message')->where('id',$id)->update(['status'=>1]);
  148. //拒绝给个消息
  149. if($msg_info['infotype'] == 'newfriend' && !empty($msg_info['infotype_id'])){
  150. $msg_id = \app\common\model\Message::addMessage($msg_info['infotype_id'],'好友申请被拒绝',$this->auth->nickname.'拒绝了您的好友请求');
  151. }
  152. $this->success('已拒绝');
  153. }
  154. //关注某人
  155. public function follow_one(){
  156. $follow_uid = input('follow_uid',0);
  157. $msg_id = input('msg_id',0);
  158. if(!$follow_uid){
  159. $this->error(__('Invalid parameters'));
  160. }
  161. $checkuser = Db::name('user')->find($follow_uid);
  162. if(empty($checkuser)){
  163. $this->error('此用户不存在');
  164. }
  165. if($follow_uid == $this->auth->id){
  166. $this->error('不能关注自己');
  167. }
  168. $map = [
  169. 'uid' => $this->auth->id,
  170. 'follow_uid' => $follow_uid,
  171. ];
  172. $check = Db::name('user_follow')->where($map)->find();
  173. if($check){
  174. //取关
  175. $rs = Db::name('user_follow')->where($map)->delete();
  176. $this->success('操作成功');
  177. }
  178. Db::startTrans();
  179. $id = Db::name('user_follow')->insertGetId($map);
  180. if(!$id){
  181. Db::rollback();
  182. $this->error('关注失败');
  183. }
  184. //被关注人如果没有关注我,发一条消息,让他加好友,也就是让他回关
  185. $map2 = [
  186. 'uid' => $follow_uid,
  187. 'follow_uid' => $this->auth->id,
  188. ];
  189. $check = Db::name('user_follow')->where($map2)->find();
  190. if(empty($check) && $this->user_power($this->auth->id,'yinsi') != 1){
  191. $message = [
  192. 'user_id' => $follow_uid,
  193. 'title' => '好友请求',
  194. 'content' => '有人关注了你,回关TA成为好友',
  195. 'createtime' => time(),
  196. 'status' => 0,
  197. 'infotype' => 'newfriend',//关注,请求好友
  198. 'infotype_id' => $this->auth->id,
  199. ];
  200. Db::name('message')->insertGetId($message);
  201. }
  202. //我从好友审核列表过来的,我又回关了
  203. if(!empty($msg_id)){
  204. $msg_id = \app\common\model\Message::addMessage($follow_uid,'好友申请已通过',$this->auth->nickname.'同意了您的好友请求');
  205. }
  206. Db::commit();
  207. $this->success('操作成功',$id);
  208. }
  209. //取关某人
  210. public function un_follow_one(){
  211. $follow_uid = input('follow_uid',0);
  212. if(!$follow_uid){
  213. $this->error(__('Invalid parameters'));
  214. }
  215. $checkuser = Db::name('user')->find($follow_uid);
  216. if(empty($checkuser)){
  217. $this->error('此用户不存在');
  218. }
  219. $map = [
  220. 'uid' => $this->auth->id,
  221. 'follow_uid' => $follow_uid,
  222. ];
  223. //不检查,全删
  224. $rs = Db::name('user_follow')->where($map)->delete();
  225. $this->success('操作成功');
  226. }
  227. //我的关注uids
  228. private function my_follow_uids(){
  229. return Db::name('user_follow')->where('uid',$this->auth->id)->column('follow_uid');
  230. }
  231. //我的粉丝uids
  232. private function my_fans_uids(){
  233. return Db::name('user_follow')->where('follow_uid',$this->auth->id)->column('uid');
  234. }
  235. }