UpgradeLogLogic.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. <?php
  2. namespace App\Module\Farm\Logics;
  3. use App\Module\Farm\Enums\UPGRADE_TYPE;
  4. use App\Module\Farm\Models\FarmUpgradeLog;
  5. use Illuminate\Database\Eloquent\Collection;
  6. use Illuminate\Support\Facades\Log;
  7. /**
  8. * 升级记录逻辑
  9. *
  10. * 提供升级记录数据的业务逻辑处理。
  11. */
  12. class UpgradeLogLogic
  13. {
  14. /**
  15. * 获取用户的升级记录
  16. *
  17. * @param int $userId
  18. * @param int $limit
  19. * @return Collection
  20. */
  21. public function findByUserId(int $userId, int $limit = 100): Collection
  22. {
  23. try {
  24. return FarmUpgradeLog::where('user_id', $userId)
  25. ->orderByDesc('upgrade_time')
  26. ->limit($limit)
  27. ->get();
  28. } catch (\Exception $e) {
  29. Log::error('获取用户升级记录失败', [
  30. 'user_id' => $userId,
  31. 'error' => $e->getMessage(),
  32. 'trace' => $e->getTraceAsString()
  33. ]);
  34. return collect();
  35. }
  36. }
  37. /**
  38. * 获取用户的房屋升级记录
  39. *
  40. * @param int $userId
  41. * @param int $limit
  42. * @return Collection
  43. */
  44. public function findHouseUpgradesByUserId(int $userId, int $limit = 100): Collection
  45. {
  46. try {
  47. return FarmUpgradeLog::where('user_id', $userId)
  48. ->where('upgrade_type', UPGRADE_TYPE::HOUSE->value)
  49. ->orderByDesc('upgrade_time')
  50. ->limit($limit)
  51. ->get();
  52. } catch (\Exception $e) {
  53. Log::error('获取用户房屋升级记录失败', [
  54. 'user_id' => $userId,
  55. 'error' => $e->getMessage(),
  56. 'trace' => $e->getTraceAsString()
  57. ]);
  58. return collect();
  59. }
  60. }
  61. /**
  62. * 获取用户的土地升级记录
  63. *
  64. * @param int $userId
  65. * @param int $limit
  66. * @return Collection
  67. */
  68. public function findLandUpgradesByUserId(int $userId, int $limit = 100): Collection
  69. {
  70. try {
  71. return FarmUpgradeLog::where('user_id', $userId)
  72. ->where('upgrade_type', UPGRADE_TYPE::LAND->value)
  73. ->orderByDesc('upgrade_time')
  74. ->limit($limit)
  75. ->get();
  76. } catch (\Exception $e) {
  77. Log::error('获取用户土地升级记录失败', [
  78. 'user_id' => $userId,
  79. 'error' => $e->getMessage(),
  80. 'trace' => $e->getTraceAsString()
  81. ]);
  82. return collect();
  83. }
  84. }
  85. /**
  86. * 获取指定时间段内的升级记录
  87. *
  88. * @param string $startTime
  89. * @param string $endTime
  90. * @return Collection
  91. */
  92. public function findByTimeRange(string $startTime, string $endTime): Collection
  93. {
  94. try {
  95. return FarmUpgradeLog::whereBetween('upgrade_time', [$startTime, $endTime])
  96. ->orderByDesc('upgrade_time')
  97. ->get();
  98. } catch (\Exception $e) {
  99. Log::error('获取时间段升级记录失败', [
  100. 'start_time' => $startTime,
  101. 'end_time' => $endTime,
  102. 'error' => $e->getMessage(),
  103. 'trace' => $e->getTraceAsString()
  104. ]);
  105. return collect();
  106. }
  107. }
  108. /**
  109. * 清理过期的升级记录
  110. *
  111. * @param int $days 保留天数
  112. * @return int
  113. */
  114. public function cleanupOldLogs(int $days = 90): int
  115. {
  116. try {
  117. $date = now()->subDays($days);
  118. return FarmUpgradeLog::where('upgrade_time', '<', $date)->delete();
  119. } catch (\Exception $e) {
  120. Log::error('清理过期升级记录失败', [
  121. 'days' => $days,
  122. 'error' => $e->getMessage(),
  123. 'trace' => $e->getTraceAsString()
  124. ]);
  125. return 0;
  126. }
  127. }
  128. }