UserGroupController.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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. class UserGroupController extends CatchController
  10. {
  11. use ValidatesRequests;
  12. /**
  13. * 用户分群列表
  14. * @param Request $request
  15. */
  16. public function list(Request $request) {
  17. $name = $request->input('name');
  18. DB::table('user_groups')
  19. ->when($name, function ($query, $name){
  20. return $query->where('name', 'like', '%'.$name.'%');
  21. })->where([
  22. 'uid' => $this->getLoginUserId(),
  23. 'is_enabled' => 1
  24. ])->orderBy('id', 'desc')
  25. ->paginate($request->input('limit', 20));
  26. }
  27. /**
  28. * 添加用户分群
  29. * @param Request $request
  30. * @return string
  31. * @throws \Illuminate\Validation\ValidationException
  32. */
  33. public function add(Request $request){
  34. $this->validate($request, [
  35. 'name' => 'required|string|max:64',
  36. 'gzh_ids' => 'required|array',
  37. 'tags' => 'required|array',
  38. 'remark' => 'nullable|string|max:140'
  39. ]);
  40. $model = UserGroupModel::create([
  41. 'name' => $request->input('name'), 'uid' => $this->getLoginUserId(),
  42. 'tags' => \json_encode($request->input('tags', []), JSON_UNESCAPED_UNICODE),
  43. 'remark' => $request->input('remark', '')
  44. ]);
  45. foreach ($request->input('gzh_ids') as $gzh_id) {
  46. GzhUgMapModel::create([
  47. 'ug_id' => $model->id, 'gzh_id' => $gzh_id
  48. ]);
  49. }
  50. return 'ok';
  51. }
  52. /**
  53. * 删除
  54. * @param Request $request
  55. * @return string
  56. * @throws \Illuminate\Validation\ValidationException
  57. */
  58. public function delete(Request $request) {
  59. $this->validate($request, ['id' => 'required']);
  60. $model = UserGroupModel::where([
  61. 'uid' => $this->getLoginUserId(), 'id' => $request->input('id'),
  62. 'is_enabled' => 1,
  63. ])->first();
  64. if($model) {
  65. $model->is_enabled = 0;
  66. $model->save();
  67. GzhUgMapModel::where([
  68. 'ug_id' => $model->id,
  69. 'is_enabled' => 1
  70. ])->update([
  71. 'is_enabled' => 0
  72. ]);
  73. }
  74. return 'ok';
  75. }
  76. }