ItemTemp.php 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <?php
  2. namespace App\Module\Game\Logics;
  3. use App\Module\Game\Dtos\ItemChangeTempDto;
  4. use App\Module\GameItems\Events\ItemQuantityChanged;
  5. use Illuminate\Support\Facades\Log;
  6. use UCore\Helper\Cache;
  7. /**
  8. * 物品临时数据逻辑类
  9. *
  10. * 负责处理物品变更事件的临时数据存储逻辑,包括:
  11. * 1. 将物品变更数据临时存储
  12. * 2. 按照用户进行存储
  13. * 3. 同一物品多次变更进行数据覆盖
  14. */
  15. class ItemTemp
  16. {
  17. /**
  18. * 临时数据键前缀
  19. */
  20. const TEMP_KEY_PREFIX = 'game:item:changed:';
  21. /**
  22. * 临时数据过期时间(秒)
  23. */
  24. const TEMP_TTL = 3600; // 1小时
  25. /**
  26. * 处理物品数量变更事件
  27. *
  28. * 将物品变更数据临时存储,按用户ID和物品ID进行存储
  29. * 同一物品多次变更会覆盖之前的数据
  30. *
  31. * @param ItemQuantityChanged $event 物品数量变更事件
  32. * @return void
  33. */
  34. public static function handleItemQuantityChanged(ItemQuantityChanged $event): void
  35. {
  36. try {
  37. // 构建临时数据键,按用户ID进行存储
  38. $tempKey = self::TEMP_KEY_PREFIX . $event->userId;
  39. // 获取当前用户的物品变更临时数据
  40. $userItemsTemp = Cache::get($tempKey, []);
  41. // 构建物品变更数据
  42. $itemData = [
  43. 'item_id' => $event->itemId,
  44. 'instance_id' => $event->instanceId,
  45. 'old_quantity' => $event->oldQuantity,
  46. 'new_quantity' => $event->newQuantity,
  47. 'change_amount' => $event->changeAmount,
  48. 'user_item_id' => $event->userItemId,
  49. 'updated_at' => time(),
  50. ];
  51. // 使用物品ID作为键,实现同一物品多次变更的数据覆盖
  52. $userItemsTemp[$event->itemId] = $itemData;
  53. // 将更新后的数据存回临时存储
  54. Cache::put($tempKey, $userItemsTemp, self::TEMP_TTL);
  55. Log::info('物品变更数据已临时存储', [
  56. 'user_id' => $event->userId,
  57. 'item_id' => $event->itemId,
  58. 'change_amount' => $event->changeAmount,
  59. ]);
  60. } catch (\Exception $e) {
  61. Log::error('物品变更数据临时存储失败', [
  62. 'error' => $e->getMessage(),
  63. 'user_id' => $event->userId,
  64. 'item_id' => $event->itemId,
  65. ]);
  66. }
  67. }
  68. /**
  69. * 获取用户的物品变更临时数据
  70. *
  71. * @param int $userId 用户ID
  72. * @return ItemChangeTempDto[] 用户的物品变更数据
  73. */
  74. public static function getUserItemChanges(int $userId): array
  75. {
  76. $tempKey = self::TEMP_KEY_PREFIX . $userId;
  77. $rawData = Cache::get($tempKey, []);
  78. $result = [];
  79. foreach ($rawData as $itemId => $itemData) {
  80. $result[$itemId] = ItemChangeTempDto::fromArray($itemData);
  81. }
  82. return $result;
  83. }
  84. /**
  85. * 获取用户特定物品的变更临时数据
  86. *
  87. * @param int $userId 用户ID
  88. * @param int $itemId 物品ID
  89. * @return ItemChangeTempDto|null 物品变更数据,不存在时返回null
  90. */
  91. public static function getUserItemChange(int $userId, int $itemId): ?ItemChangeTempDto
  92. {
  93. $userItemChanges = self::getUserItemChanges($userId);
  94. return $userItemChanges[$itemId] ?? null;
  95. }
  96. /**
  97. * 清除用户的物品变更临时数据
  98. *
  99. * @param int $userId 用户ID
  100. * @return void
  101. */
  102. public static function clearUserItemChanges(int $userId): void
  103. {
  104. $tempKey = self::TEMP_KEY_PREFIX . $userId;
  105. Cache::put($tempKey, [], 0);
  106. }
  107. }