Userfollow.php 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239
  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. $vip_endtime = Db::name('user_wallet')->where('user_id',$this->auth->id)->value('vip_endtime');
  110. $time = time();
  111. if ($vip_endtime < $time) {
  112. $user_id = $follow_uid;// 赠送对象
  113. if (!$gift_id) {
  114. $this->error('请选择要赠送的礼物');
  115. }
  116. if ($number < 1) {
  117. $this->error('请输入正确赠送礼物数量');
  118. }
  119. // 获取礼物信息
  120. $giftinfo = Db::name('gift')->where('id',$gift_id)->find();
  121. if (!$giftinfo)
  122. {
  123. $this->error("请选择礼物");
  124. }
  125. $giftvalue = bcmul($giftinfo['value'],$number);
  126. //被赠送人信息
  127. $touserinfo = $checkuser;
  128. // 判断当前用户余额
  129. $user_gold = model('wallet')->getWallet($this->auth->id,'gold');
  130. if($user_gold < $giftvalue)
  131. {
  132. $this->error("您的金币余额不足");
  133. }
  134. }*/
  135. //查询对方是否关注自己
  136. $where = [
  137. 'uid' => $follow_uid,
  138. 'follow_uid' => $this->auth->id
  139. ];
  140. $count = Db::name('user_follow')->where($where)->count('id');
  141. if ($count) {
  142. $map['status'] = 1; //状态:0=关注,1=互为关注
  143. }
  144. $return_data['money'] = ''; //获得金额
  145. $return_data['level_remark'] = ''; //亲密度等级提示语
  146. //开启事务
  147. Db::startTrans();
  148. $id = Db::name('user_follow')->insertGetId($map);
  149. if(!$id){
  150. Db::rollback();
  151. $this->error('您的网络开小差啦~');
  152. }
  153. if ($count) {
  154. //若对方已关注, 则将状态改为 互为关注
  155. $rs = Db::name('user_follow')->where($where)->where(['status' => 0])->setField('status', 1);
  156. if (!$rs) {
  157. Db::rollback();
  158. $this->error('您的网络开小差啦~');
  159. }
  160. }
  161. //系统消息
  162. $msg_id = \app\common\model\Message::addMessage($this->auth->id,'喜欢','您已喜欢用户' . $checkuser['nickname']);
  163. Db::commit();
  164. $this->success('操作成功', $return_data);
  165. }
  166. //取关某人
  167. public function un_follow_one(){
  168. $follow_uid = input('follow_uid',0);
  169. if(!$follow_uid){
  170. $this->error(__('Invalid parameters'));
  171. }
  172. $checkuser = Db::name('user')->find($follow_uid);
  173. if(empty($checkuser)){
  174. $this->error('此用户不存在');
  175. }
  176. $map = [
  177. 'uid' => $this->auth->id,
  178. 'follow_uid' => $follow_uid,
  179. ];
  180. $info = Db::name('user_follow')->where($map)->find();
  181. if (!$info) {
  182. $this->error('您尚未关注此人~');
  183. }
  184. //开启事务
  185. Db::startTrans();
  186. $rs = Db::name('user_follow')->where($map)->delete();
  187. if (!$rs) {
  188. Db::rollback();
  189. $this->error('您的网络开小差啦~');
  190. }
  191. $where = [
  192. 'uid' => $follow_uid,
  193. 'follow_uid' => $this->auth->id,
  194. ];
  195. $count = Db::name('user_follow')->where($where)->count('id');
  196. if ($count) {
  197. $rt = Db::name('user_follow')->where($where)->where(['status' => 1])->setField('status', 0);
  198. if (!$rt) {
  199. Db::rollback();
  200. $this->error('您的网络开小差啦~');
  201. }
  202. }
  203. Db::commit();
  204. $this->success('操作成功');
  205. }
  206. }