Userfollow.php 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210
  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. $type = input('type', 0, 'intval'); //类型:0关注 1好友
  15. $where = [];
  16. if ($type == 1) {
  17. $where['follow.status'] = 1;
  18. }
  19. $list = Db::name('user_follow')
  20. ->alias('follow')
  21. ->join('user','follow.follow_uid = user.id','LEFT')
  22. ->field('user.id,user.nickname,user.avatar,user.real_status,user.idcard_status,user.birthday,user.gender,follow.status')
  23. ->where('follow.uid',$this->auth->id)->where($where)->order('follow.id desc')->autopage()->select();
  24. $list = list_domain_image($list,['avatar']);
  25. $list = list_birthday_age($list);
  26. if ($list) {
  27. $mt_user_wallet = Db::name('user_wallet'); //钱包
  28. $mt_wealth_level = Db::name('wealth_level'); //财富等级
  29. $mt_charm_level = Db::name('charm_level'); //魅力等级
  30. foreach ($list as &$val) {
  31. //查询财富等级和魅力等级
  32. $wallet_info = $mt_user_wallet->where(['user_id' => $val['id']])->find();
  33. $wealth_level = $mt_wealth_level->where(['value' => ['elt', $wallet_info['pay_money']]])->order('id desc')->find();
  34. if ($wealth_level) {
  35. $val['wealth_level'] = $wealth_level['name'];
  36. } else {
  37. $val['wealth_level'] = '';
  38. }
  39. $charm_level = $mt_charm_level->where(['value' => ['elt', $wallet_info['get_money']]])->order('id desc')->find();
  40. if ($charm_level) {
  41. $val['charm_level'] = $charm_level['name'];
  42. } else {
  43. $val['charm_level'] = '';
  44. }
  45. }
  46. }
  47. $this->success('success',$list);
  48. }
  49. //我的粉丝列表
  50. public function my_fans_list(){
  51. $list = Db::name('user_follow')
  52. ->alias('follow')
  53. ->join('user','follow.uid = user.id','LEFT')
  54. ->field('user.id,user.nickname,user.avatar,user.real_status,user.idcard_status,user.birthday,user.gender,follow.status')
  55. ->where('follow.follow_uid',$this->auth->id)->order('follow.id desc')->autopage()->select();
  56. $list = list_domain_image($list,['avatar']);
  57. $list = list_birthday_age($list);
  58. if ($list) {
  59. $mt_user_wallet = Db::name('user_wallet'); //钱包
  60. $mt_wealth_level = Db::name('wealth_level'); //财富等级
  61. $mt_charm_level = Db::name('charm_level'); //魅力等级
  62. foreach ($list as &$val) {
  63. //查询财富等级和魅力等级
  64. $wallet_info = $mt_user_wallet->where(['user_id' => $val['id']])->find();
  65. $wealth_level = $mt_wealth_level->where(['value' => ['elt', $wallet_info['pay_money']]])->order('id desc')->find();
  66. if ($wealth_level) {
  67. $val['wealth_level'] = $wealth_level['name'];
  68. } else {
  69. $val['wealth_level'] = '';
  70. }
  71. $charm_level = $mt_charm_level->where(['value' => ['elt', $wallet_info['get_money']]])->order('id desc')->find();
  72. if ($charm_level) {
  73. $val['charm_level'] = $charm_level['name'];
  74. } else {
  75. $val['charm_level'] = '';
  76. }
  77. }
  78. }
  79. $this->success('success',$list);
  80. }
  81. //关注某人
  82. public function follow_one(){
  83. // 接口防并发
  84. if (!$this->apiLimit(1, 1)) {
  85. $this->error(__('Operation frequently'));
  86. }
  87. $follow_uid = input('follow_uid',0);
  88. // $gift_id = input('gift_id');// 礼物ID
  89. // $number = input('number',1,'intval');//数量
  90. if(!$follow_uid){
  91. $this->error(__('Invalid parameters'));
  92. }
  93. $checkuser = Db::name('user')->find($follow_uid);
  94. if(empty($checkuser)){
  95. $this->error('此用户不存在');
  96. }
  97. if($follow_uid == $this->auth->id){
  98. $this->error('不能关注自己');
  99. }
  100. $map = [
  101. 'uid' => $this->auth->id,
  102. 'follow_uid' => $follow_uid,
  103. ];
  104. $check = Db::name('user_follow')->where($map)->find();
  105. if($check){
  106. $this->error('已经关注此人');
  107. }
  108. //查询对方是否关注自己
  109. $where = [
  110. 'uid' => $follow_uid,
  111. 'follow_uid' => $this->auth->id
  112. ];
  113. $count = Db::name('user_follow')->where($where)->count('id');
  114. if ($count) {
  115. $map['status'] = 1; //状态:0=关注,1=互为关注
  116. }
  117. $return_data['money'] = ''; //获得金额
  118. $return_data['level_remark'] = ''; //亲密度等级提示语
  119. //开启事务
  120. Db::startTrans();
  121. $id = Db::name('user_follow')->insertGetId($map);
  122. if(!$id){
  123. Db::rollback();
  124. $this->error('您的网络开小差啦~');
  125. }
  126. if ($count) {
  127. //若对方已关注, 则将状态改为 互为关注
  128. $rs = Db::name('user_follow')->where($where)->where(['status' => 0])->setField('status', 1);
  129. if (!$rs) {
  130. Db::rollback();
  131. $this->error('您的网络开小差啦~');
  132. }
  133. }
  134. //系统消息
  135. $msg_id = \app\common\model\Message::addMessage($this->auth->id,'喜欢','您已喜欢用户' . $checkuser['nickname']);
  136. Db::commit();
  137. $this->success('操作成功', $return_data);
  138. }
  139. //取关某人
  140. public function un_follow_one(){
  141. $follow_uid = input('follow_uid',0);
  142. if(!$follow_uid){
  143. $this->error(__('Invalid parameters'));
  144. }
  145. $checkuser = Db::name('user')->find($follow_uid);
  146. if(empty($checkuser)){
  147. $this->error('此用户不存在');
  148. }
  149. $map = [
  150. 'uid' => $this->auth->id,
  151. 'follow_uid' => $follow_uid,
  152. ];
  153. $info = Db::name('user_follow')->where($map)->find();
  154. if (!$info) {
  155. $this->error('您尚未关注此人~');
  156. }
  157. //开启事务
  158. Db::startTrans();
  159. $rs = Db::name('user_follow')->where($map)->delete();
  160. if (!$rs) {
  161. Db::rollback();
  162. $this->error('您的网络开小差啦~');
  163. }
  164. $where = [
  165. 'uid' => $follow_uid,
  166. 'follow_uid' => $this->auth->id,
  167. ];
  168. $count = Db::name('user_follow')->where($where)->count('id');
  169. if ($count) {
  170. $rt = Db::name('user_follow')->where($where)->where(['status' => 1])->setField('status', 0);
  171. if (!$rt) {
  172. Db::rollback();
  173. $this->error('您的网络开小差啦~');
  174. }
  175. }
  176. Db::commit();
  177. $this->success('操作成功');
  178. }
  179. }