CharController.php 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4. use App\Models\Char\CharBase;
  5. use App\Models\Char\CharCashItem_OutputBox;
  6. class CharController extends Controller
  7. {
  8. /**
  9. * Получение всех персонажей из базы данных с пагинацией.
  10. * *
  11. * @return \Illuminate\Http\JsonResponse
  12. */
  13. public function GetAllCharacters(Request $request)
  14. {
  15. // 1. Валидация и параметры запроса
  16. $validated = $request->validate([
  17. 'per_page' => 'sometimes|integer|min:1|max:100',
  18. 'search' => 'sometimes|string|nullable|max:50',
  19. ]);
  20. $perPage = $validated['per_page'] ?? 15;
  21. $search = trim($validated['search'] ?? '');
  22. $sortField = $request->input('sort_field', 'DBKey');
  23. $sortOrder = strtolower($request->input('sort_order', 'asc')) === 'desc' ? 'desc' : 'asc';
  24. // whitelist для полей сортировки и выборки
  25. $allowedSortFields = ['DBKey', 'Name', 'Level', 'AccountName'];
  26. if (!in_array($sortField, $allowedSortFields, true)) {
  27. $sortField = 'DBKey';
  28. }
  29. // 2. Запрос с выборкой только нужных полей
  30. $query = CharBase::query()->select($allowedSortFields);
  31. if ($search !== '') {
  32. $query->where(function ($q) use ($search) {
  33. $q->where('Name', 'like', "%{$search}%")
  34. ->orWhere('AccountName', 'like', "%{$search}%");
  35. if (ctype_digit($search)) {
  36. $q->orWhere('DBKey', (int) $search);
  37. }
  38. });
  39. }
  40. // 3. Сортировка и пагинация
  41. $charactersPaginator = $query->orderBy($sortField, $sortOrder)->paginate($perPage);
  42. // 4. Ответ
  43. // Если по запросу не найдено ни одного персонажа, возвращаем специальный ответ
  44. // для сохранения обратной совместимости API.
  45. if ($charactersPaginator->total() === 0) {
  46. return response()->json([
  47. 'characters' => (object) [],
  48. 'code' => -2,
  49. 'msg' => 'Characters not found.'
  50. ], 200);
  51. }
  52. // Laravel автоматически преобразует пагинатор в корректный JSON,
  53. // включая только выбранные через select() поля.
  54. return response()->json([
  55. 'code' => 0,
  56. 'msg' => 'Characters successfully received.',
  57. 'characters' => $charactersPaginator,
  58. ], 200);
  59. }
  60. /**
  61. * Получение всех персонажей пользователя по AccountDBID.
  62. *
  63. * @param string $username
  64. * @return \Illuminate\Http\JsonResponse
  65. */
  66. public function GetUserCharacters($username)
  67. {
  68. // Получаем всех персонажей по $username
  69. $characters = CharBase::where('AccountName', $username)->get();
  70. // Проверяем, найдены ли персонажи
  71. if ($characters->isEmpty()) {
  72. return response()->json(['characters' => [], 'code' => -2, 'msg' => 'Characters not found for this user.'], 200);
  73. }
  74. // Подсчитываем общее время в игре для всех персонажей пользователя
  75. $totalPlayTime = $characters->sum('TotalPlayTime');
  76. // Возвращаем только DBKey, Name, Level, GuildDBKey, TotalPlayTime персонажей
  77. $characters = $characters->map(function ($character) {
  78. return [
  79. 'DBKey' => $character->DBKey,
  80. 'Name' => $character->Name,
  81. 'Level' => $character->Level,
  82. 'GuildDBKey' => $character->GuildDBKey,
  83. 'CharPlayTime' => $character->TotalPlayTime
  84. ];
  85. });
  86. return response()->json([
  87. 'code' => 0,
  88. 'msg' => 'Characters successfully received.',
  89. 'characters' => $characters,
  90. 'totalPlayTime' => $totalPlayTime
  91. ], 200);
  92. }
  93. public function SendItemToCharacter(Request $request)
  94. {
  95. $character = CharBase::where('DBKey', $request->Owner)->first();
  96. if (!$character) {
  97. return response()->json(['code' => -1, 'msg' => 'Character not found.'], 404);
  98. }
  99. $validator = \Validator::make($request->all(), [
  100. 'Owner' => 'required',
  101. 'Kind' => 'required',
  102. 'RecId' => 'required',
  103. 'Amount' => 'required|numeric',
  104. 'Period' => 'required|numeric',
  105. 'evPType' => 'required',
  106. 'Comment' => 'required'
  107. ], [], [
  108. 'Owner' => '',
  109. 'Kind' => '',
  110. 'RecId' => '',
  111. 'Amount' => '',
  112. 'Period' => '',
  113. 'evPType' => '',
  114. 'Comment' => ''
  115. ]);
  116. if (!$validator->passes())
  117. return response()->json(['code' => -1, 'msg' => $validator->errors()], 400);
  118. CharCashItem_OutputBox::SENDITEMOUTPUTBOX($request);
  119. return response()->json([
  120. 'code' => 0,
  121. 'msg' => 'Items successfully sent.'
  122. ], 200);
  123. }
  124. }