GameBuyBonusConfigController.php 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. <?php
  2. namespace App\Http\Controllers\Admin;
  3. use Illuminate\Http\Request;
  4. use Illuminate\Support\Facades\DB;
  5. use Illuminate\Support\Facades\Redis;
  6. class GameBuyBonusConfigController
  7. {
  8. /**
  9. * Bonus购买回报配置列表(可编辑)
  10. */
  11. public function index(Request $request)
  12. {
  13. $configs = DB::connection('write')
  14. ->table('QPPlatformDB.dbo.GameBuyBonusConfig')
  15. ->orderBy('MultiMin', 'asc')
  16. ->get();
  17. return view('admin.game_buy_bonus_config.index', compact('configs'));
  18. }
  19. /**
  20. * 批量更新配置(只更新有变动的数据)
  21. */
  22. public function update(Request $request)
  23. {
  24. try {
  25. $configs = $request->input('configs', []);
  26. if (empty($configs)) {
  27. return apiReturnFail('没有需要更新的数据');
  28. }
  29. DB::beginTransaction();
  30. $updatedIds = [];
  31. $updatedCount = 0;
  32. foreach ($configs as $configId => $data) {
  33. // 构建更新数据(只包含提交的字段)
  34. $updateData = [];
  35. if (isset($data['MultiMin'])) {
  36. $updateData['MultiMin'] = round((float)$data['MultiMin'], 2);
  37. }
  38. if (isset($data['MultiMax'])) {
  39. $updateData['MultiMax'] = round((float)$data['MultiMax'], 2);
  40. }
  41. if (isset($data['Weight'])) {
  42. $updateData['Weight'] = (int)$data['Weight'];
  43. }
  44. if (isset($data['WeightAdjust'])) {
  45. $updateData['WeightAdjust'] = $data['WeightAdjust'];
  46. }
  47. // 只有有数据时才更新
  48. if (!empty($updateData)) {
  49. DB::connection('write')
  50. ->table('QPPlatformDB.dbo.GameBuyBonusConfig')
  51. ->where('ConfigID', $configId)
  52. ->update($updateData);
  53. $updatedIds[] = $configId;
  54. $updatedCount++;
  55. }
  56. }
  57. DB::commit();
  58. // 清除可能的缓存
  59. Redis::del('game_buy_bonus_config_cache');
  60. \Log::info('Bonus购买回报配置更新成功', [
  61. 'admin_id' => $request->session()->get('admin')->id ?? 0,
  62. 'updated_count' => $updatedCount,
  63. 'config_ids' => $updatedIds
  64. ]);
  65. return apiReturnSuc("配置更新成功,共更新 {$updatedCount} 条数据");
  66. } catch (\Exception $e) {
  67. DB::rollBack();
  68. \Log::error('Bonus购买回报配置更新失败', [
  69. 'error' => $e->getMessage(),
  70. 'trace' => $e->getTraceAsString()
  71. ]);
  72. return apiReturnFail('更新失败: ' . $e->getMessage());
  73. }
  74. }
  75. }