ActivityReward.php 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. <?php
  2. namespace App\Http\Controllers\api;
  3. use App\Constants\HttpStatus;
  4. use App\Models\ActivityReward as ActivityRewardModel;
  5. use App\Models\ActivityUser;
  6. use App\Services\ActivityRewardService;
  7. use App\Services\ActivityUserService;
  8. use App\Services\UserService;
  9. use Illuminate\Http\JsonResponse;
  10. use Illuminate\Support\Facades\DB;
  11. use Illuminate\Validation\ValidationException;
  12. use Exception;
  13. class ActivityReward extends BaseController
  14. {
  15. public function participate(): JsonResponse
  16. {
  17. DB::beginTransaction();
  18. try {
  19. request()->validate([
  20. 'member_id' => ['required', 'integer', 'exists:users,member_id'],
  21. 'activity_id' => ['required', 'integer'],
  22. ]);
  23. $memberId = request()->input('member_id');
  24. $user = UserService::findOne(['member_id' => $memberId]);
  25. if (empty($user->phone)) throw new Exception('请先绑定手机号', HttpStatus::NOT_BIND_PHONE);
  26. if (ActivityUser::where('member_id', $memberId)->where('status', 0)->exists()) {
  27. throw new Exception('完成活动才可以参与新活动', HttpStatus::CUSTOM_ERROR);
  28. }
  29. $activityId = request()->input('activity_id');
  30. if (ActivityUser::where('member_id', $memberId)->where('activity_id', $activityId)->exists()) {
  31. throw new Exception('已参与过此活动,每个活动仅可参加一次', HttpStatus::CUSTOM_ERROR);
  32. }
  33. $time = time();
  34. $activity = ActivityRewardService::findOne([
  35. 'start_time' => ['<=', $time],
  36. 'end_time' => ['>=', $time],
  37. 'status' => ActivityRewardModel::STATUS_UP,
  38. 'id' => $activityId
  39. ]);
  40. if (!$activity) throw new Exception('活动不存在', HttpStatus::CUSTOM_ERROR);
  41. ActivityUserService::submit([
  42. 'activity_id' => $activityId,
  43. 'title' => $activity->title,
  44. 'sub_title' => $activity->sub_title,
  45. 'start_time' => $activity->start_time,
  46. 'end_time' => $activity->end_time,
  47. 'detail_image' => $activity->detail_image,
  48. 'part_in_time' => $time,
  49. 'member_id' => $memberId,
  50. 'status' => 0
  51. ]);
  52. DB::commit();
  53. } catch (ValidationException $e) {
  54. DB::rollBack();
  55. return $this->error($e->validator->errors()->first());
  56. } catch (Exception $e) {
  57. DB::rollBack();
  58. return $this->error($e->getMessage(), [], $e->getCode());
  59. }
  60. return $this->success();
  61. }
  62. public function index(): JsonResponse
  63. {
  64. try {
  65. request()->validate(['member_id' => ['nullable', 'integer']]);
  66. $memberId = request()->input('member_id');
  67. $time = time();
  68. $query = ActivityRewardModel::where(ActivityRewardService::getWhere([
  69. 'start_time' => ['<=', $time],
  70. 'end_time' => ['>=', $time],
  71. 'status' => ActivityRewardModel::STATUS_UP
  72. ]));
  73. if (!empty($memberId)) {
  74. $query->with(['activityUser' => function ($query1) use ($memberId) {
  75. $query1->where('member_id', $memberId);
  76. }]);
  77. }
  78. $list = $query->orderByDesc('id')->get();
  79. $list->transform(function ($activity) use ($memberId) {
  80. if (!empty($memberId)) {
  81. $activity->is_claimed = $activity->activityUser->isNotEmpty();
  82. } else {
  83. $activity->is_claimed = false;
  84. }
  85. unset($activity->activityUser);
  86. return $activity;
  87. })->toArray();
  88. } catch (ValidationException $e) {
  89. return $this->error($e->validator->errors()->first());
  90. } catch (Exception $e) {
  91. return $this->error($e->getMessage());
  92. }
  93. return $this->success($list);
  94. }
  95. }