UserGroupController.php 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. namespace Modules\Audience\Http\Controllers;
  3. use Catch\Base\CatchController;
  4. use Illuminate\Foundation\Validation\ValidatesRequests;
  5. use Illuminate\Http\Request;
  6. use Illuminate\Support\Facades\DB;
  7. use Modules\Audience\Models\GzhUgMapModel;
  8. use Modules\Audience\Models\UserGroupModel;
  9. use Modules\Audience\Services\UserGroupService;
  10. class UserGroupController extends CatchController
  11. {
  12. use ValidatesRequests;
  13. /**
  14. * 用户分群列表
  15. * @param Request $request
  16. */
  17. public function list(Request $request) {
  18. $name = $request->input('name');
  19. return DB::table('user_groups')
  20. ->when($name, function ($query, $name){
  21. return $query->where('name', 'like', '%'.$name.'%');
  22. })->where([
  23. 'uid' => $this->getLoginUserId(),
  24. 'is_enabled' => 1
  25. ])->orderBy('id', 'desc')
  26. ->paginate($request->input('limit', 20));
  27. }
  28. /**
  29. * 详情
  30. * @param Request $request
  31. * @throws \Illuminate\Validation\ValidationException
  32. */
  33. public function detail(Request $request) {
  34. $this->validate($request, ['id' => 'required']);
  35. $uid = $this->getLoginUserId();
  36. $obj = DB::table('user_groups')
  37. ->where([
  38. 'uid' => $uid, 'is_enabled' => 1,
  39. 'id' => $request->input('id')
  40. ])->first();
  41. if($obj) {
  42. $gzhInfo = DB::table('gzh_ug_maps as a')
  43. ->join('wechat_authorization_infos as b', function($query) use ($uid) {
  44. $query->on('a.gzh_id', '=', 'b.id')
  45. ->where([
  46. 'b.is_enabled' => 1,
  47. 'b.user_id' => $uid
  48. ]);
  49. })->where([
  50. 'a.ug_id' => $request->input('id')
  51. ])->select('b.nick_name', 'b.authorizer_appid')->get();
  52. $tags = \json_decode($obj->tags, true);
  53. $tags['gzh_appids'] = $gzhInfo->pluck('authorizer_appid')->toArray();
  54. $tags['in_48_hour'] = 1;
  55. $uids = UserGroupService::getSQL($tags)->distinct()->select('a.uid')->get()->pluck('uid')->toArray();
  56. $uids = UserGroupService::dealHistoryReadBooks(UserGroupService::dealPayVideo($uids, $tags), $tags);
  57. $obj->user_num = count($uids);
  58. $obj->tags_arr = $tags;
  59. $obj->gzh_names = $gzhInfo->pluck('nick_name')->toArray();
  60. }
  61. return $obj;
  62. }
  63. /**
  64. * 添加用户分群
  65. * @param Request $request
  66. * @return string
  67. * @throws \Illuminate\Validation\ValidationException
  68. */
  69. public function add(Request $request){
  70. $this->validate($request, [
  71. 'name' => 'required|string|max:64',
  72. 'gzh_ids' => 'required|array',
  73. 'tags' => 'required|array',
  74. 'remark' => 'nullable|string|max:140'
  75. ]);
  76. $model = UserGroupModel::create([
  77. 'name' => $request->input('name'), 'uid' => $this->getLoginUserId(),
  78. 'tags' => \json_encode($request->input('tags', []), JSON_UNESCAPED_UNICODE),
  79. 'remark' => $request->input('remark', '')
  80. ]);
  81. foreach ($request->input('gzh_ids') as $gzh_id) {
  82. GzhUgMapModel::create([
  83. 'ug_id' => $model->id, 'gzh_id' => $gzh_id
  84. ]);
  85. }
  86. return 'ok';
  87. }
  88. /**
  89. * 批量删除
  90. * @param Request $request
  91. * @return string
  92. * @throws \Illuminate\Validation\ValidationException
  93. */
  94. public function delete(Request $request) {
  95. $this->validate($request, ['ids' => 'required|array']);
  96. foreach ($request->input('ids') as $id) {
  97. $model = UserGroupModel::where([
  98. 'uid' => $this->getLoginUserId(), 'id' => $id,
  99. 'is_enabled' => 1,
  100. ])->first();
  101. if($model) {
  102. $model->is_enabled = 0;
  103. $model->save();
  104. GzhUgMapModel::where([
  105. 'ug_id' => $model->id,
  106. 'is_enabled' => 1
  107. ])->update([
  108. 'is_enabled' => 0
  109. ]);
  110. }
  111. }
  112. return 'ok';
  113. }
  114. }