GenerateShopItemsJsonCommand.php 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. <?php
  2. namespace App\Module\Shop\Commands;
  3. use App\Module\Game\DCache\ShopItemsJsonConfig;
  4. use App\Module\Game\Models\GameRewardItem;
  5. use App\Module\Game\Services\JsonConfigService;
  6. use Carbon\Carbon;
  7. use Illuminate\Console\Command;
  8. use App\Module\Shop\Models\ShopItem;
  9. use Illuminate\Support\Facades\Log;
  10. use Uraus\Kku\Common\REWARD_TYPE;
  11. /**
  12. * 生成商店商品配置表JSON数据命令
  13. *
  14. * 该命令用于从数据库中的商店商品表生成商品JSON数据文件,供客户端使用。
  15. * 生成的JSON文件包含商品的基本信息,如ID、名称、描述、消耗组、奖励组和展示属性等。
  16. * 该命令通常在商店商品数据更新后运行,以确保客户端获取最新的商品数据。
  17. */
  18. class GenerateShopItemsJsonCommand extends Command
  19. {
  20. /**
  21. * 命令名称和签名
  22. *
  23. * @var string
  24. */
  25. protected $signature = 'shop:generate-json';
  26. /**
  27. * 命令描述
  28. *
  29. * @var string
  30. */
  31. protected $description = 'Generate shop_items.json from ShopItem table';
  32. /**
  33. * 执行命令
  34. */
  35. /**
  36. * 生成商店商品JSON数据
  37. *
  38. * @return array|bool 生成的数据或失败标志
  39. */
  40. public static function generateJson()
  41. {
  42. try {
  43. // 查询ShopItem表中的激活商品数据,并预加载关联数据
  44. $shopItems = ShopItem::query()
  45. ->with([
  46. 'category',
  47. 'consumeGroup.consumeItems',
  48. 'rewardGroup.rewardItems',
  49. 'activePurchaseLimits'
  50. ])
  51. ->where('is_active', 1)
  52. ->where(function ($query) {
  53. // 检查上架时间
  54. $query->whereNull('start_time')
  55. ->orWhere('start_time', '<=', now());
  56. })
  57. ->where(function ($query) {
  58. // 检查下架时间
  59. $query->whereNull('end_time')
  60. ->orWhere('end_time', '>=', now());
  61. })
  62. ->orderBy('sort_order', 'desc')
  63. ->orderBy('id', 'asc')
  64. ->get()
  65. ->map(function ($item) {
  66. // 构建商品数据
  67. $itemData = [
  68. 'id' => $item->id,
  69. 'name' => $item->name,
  70. 'description' => $item->description,
  71. 'category_name' => $item->category_name,
  72. 'consume_group_id' => $item->consume_group_id,
  73. 'reward_group_id' => $item->reward_group_id,
  74. 'max_single_buy' => $item->max_single_buy,
  75. 'sort_order' => $item->sort_order,
  76. 'display_attributes' => $item->display_attributes,
  77. 'start_time' => $item->start_time ? $item->start_time->toDateTimeString() : null,
  78. 'end_time' => $item->end_time ? $item->end_time->toDateTimeString() : null,
  79. ];
  80. // 添加消耗组信息
  81. if ($item->consumeGroup) {
  82. $itemData['consume_group'] = [
  83. 'id' => $item->consumeGroup->id,
  84. 'name' => $item->consumeGroup->name,
  85. 'description' => $item->consumeGroup->description,
  86. 'items' => $item->consumeGroup->consumeItems->map(function ( \App\Module\Game\Models\GameConsumeItem $consumeItem) {
  87. // todo GameConsumeItem 转 \Uraus\Kku\Common\Deduct::class
  88. \Uraus\Kku\Common\Deduct::class;
  89. $res = [
  90. 'type' => $consumeItem->consume_type,
  91. 'target_id' => $consumeItem->target_id,
  92. 'param1' => $consumeItem->param1,
  93. 'param2' => $consumeItem->param2,
  94. 'quantity' => $consumeItem->quantity,
  95. 'name' => $consumeItem->name,
  96. ];
  97. dd($res,$consumeItem);
  98. })->toArray()
  99. ];
  100. $itemData['consume_group'] = $itemData['consume_group'] ['items'];
  101. }
  102. // 添加奖励组信息
  103. if ($item->rewardGroup) {
  104. $itemData['reward_group'] = [
  105. 'id' => $item->rewardGroup->id,
  106. 'name' => $item->rewardGroup->name,
  107. 'description' => $item->rewardGroup->description,
  108. 'items' => $item->rewardGroup->rewardItems->map(function ( GameRewardItem $rewardItem) {
  109. // todo GameConsumeItem 转 \Uraus\Kku\Common\Reward::class;
  110. \Uraus\Kku\Common\Reward::class;
  111. return [
  112. 'type' => $rewardItem->type,
  113. 'target_id' => $rewardItem->target_id,
  114. 'min_quantity' => $rewardItem->min_quantity,
  115. 'max_quantity' => $rewardItem->max_quantity,
  116. 'probability' => $rewardItem->probability,
  117. 'is_guaranteed' => $rewardItem->is_guaranteed,
  118. 'name' => $rewardItem->name,
  119. ];
  120. })->toArray()
  121. ];
  122. $itemData['reward_group'] = $itemData['reward_group'] ['items'];
  123. }
  124. // 添加限购信息
  125. if ($item->activePurchaseLimits->isNotEmpty()) {
  126. $itemData['purchase_limits'] = $item->activePurchaseLimits->map(function ($limit) {
  127. return [
  128. 'id' => $limit->id,
  129. 'type' => $limit->type,
  130. 'period' => $limit->period,
  131. 'max_quantity' => $limit->max_quantity,
  132. 'description' => $limit->description,
  133. ];
  134. })->toArray();
  135. }
  136. return $itemData;
  137. })
  138. ->toArray();
  139. // 准备完整数据,包含生成时间
  140. $data = [
  141. 'generated_ts' => time(),
  142. 'generated_at' => now()->toDateTimeString(),
  143. 'shop_items' => $shopItems
  144. ];
  145. return $data;
  146. } catch (\Exception $e) {
  147. Log::error('Generate shop_items.json failed: ' . $e->getMessage());
  148. return false;
  149. }
  150. }
  151. public function handle()
  152. {
  153. if (ShopItemsJsonConfig::getData([], true)) {
  154. $this->info('Successfully generated shop_items.json with timestamp');
  155. } else {
  156. $this->error('Failed to generate shop_items.json');
  157. }
  158. }
  159. }