| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216 | <?phpnamespace App\Http\Controllers\admin;use App\Constants\HttpStatus;use App\Constants\Util;use App\Http\Controllers\Controller;use App\Models\Config;use App\Models\RoomUser;use App\Services\RoomService;use App\Services\SettlementService;use Illuminate\Support\Facades\DB;use Illuminate\Validation\ValidationException;use Exception;use Telegram\Bot\Api;class Room extends Controller{    /**     * @api {post} /admin/room/completed 结算     * @apiGroup 房间管理     *     * @apiUse result     * @apiUse header     * @apiVersion 1.0.0     * @apiParam {string} room_id 房间号     */    public function completed()    {        DB::beginTransaction();        try {            request()->validate([                'room_id' => ['required', 'string', 'min:1'],            ]);            $roomId = request()->input('room_id');            $list = RoomUser::where('status', 3)                ->where('room_id', $roomId)                ->orderBy('score', 'desc')->get();            $count = RoomUser::where('room_id', $roomId)->count();            if ($count > 0 && count($list) == $count) {                $totalAmount = RoomUser::where('status', 3)                    ->where('room_id', $roomId)->sum('score');                if ($totalAmount == 0) {                    $list = $list->toArray();                    $item = $list[0];                    $res = (new SettlementService())->submitSettle($item['member_id'], $item['score']);                    if ($res['status']) {                        $telegram = new Api(config('services.telegram.token'));                        foreach ($res['data'] as $r) $telegram->sendMessage($r);                    } else {                        throw new Exception("结算失败", HttpStatus::CUSTOM_ERROR);                    }                } else {                    throw new Exception("经过系统结算,盈利额与亏损额度无法匹配,无法进行结算", HttpStatus::CUSTOM_ERROR);                }            } else {                throw new Exception("用户还没有全部提交得分", HttpStatus::CUSTOM_ERROR);            }            DB::commit();        } catch (ValidationException $e) {            DB::rollBack();            return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());        } catch (Exception $e) {            DB::rollBack();            return $this->error(intval($e->getCode()), $e->getMessage());        }        return $this->success();    }    /**     * @api {post} /admin/room/setScore 设置用户的得分     * @apiGroup 房间管理     *     * @apiUse result     * @apiUse header     * @apiVersion 1.0.0     * @apiParam {int} id 房间详情ID     * @apiParam {int} score 游戏得分     */    public function setScore()    {        DB::beginTransaction();        try {            request()->validate([                'id' => ['required', 'integer', 'min:1'],                'score' => ['required', 'integer']            ]);            $id = request()->input('id');            $score = intval(request()->input('score'));            $ru = RoomUser::where('id', $id)                ->whereIn('status', [2,3])                ->first();            if (!$ru) throw new Exception('结算数据不存在', HttpStatus::CUSTOM_ERROR);            $ru->score = $score;            if($ru->status == 2) {                $ru->status = 3; // 设置为待结算状态            }            $ru->save();            DB::commit();        } catch (ValidationException $e) {            DB::rollBack();            return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());        } catch (Exception $e) {            DB::rollBack();            return $this->error(intval($e->getCode()), $e->getMessage());        }        return $this->success();    }    /**     * @api {get} /admin/room/details 对局详情     * @apiGroup 房间管理     *     * @apiUse result     * @apiUse header     * @apiVersion 1.0.0     * @apiParam {string} room_id 房间号     *     * @apiSuccess (data) {Object} data     * @apiSuccess (data) {int} data.id 详情ID     * @apiSuccess (data) {string} data.room_id 房间号     * @apiSuccess (data) {string} data.member_id 会员ID     * @apiSuccess (data) {string} data.game_id 游戏ID     * @apiSuccess (data) {int} data.status 人员状态     * - 0 待准备     * - 1 已准备     * - 2 游戏中     * - 3 待结算     * - 4 已结算     * @apiSuccess (data) {int} data.score 得分     * @apiSuccess (data) {float} data.brokerage 抽佣金额     * @apiSuccess (data) {float} data.real_score 真实获得的金额     * @apiSuccess (data) {string} data.screenshot 结算截图     * @apiSuccess (data) {string} data.first_name 用户昵称     */    public function details()    {        try {            request()->validate([                'room_id' => ['required', 'string', 'min:1']            ]);            $roomId = request()->input('room_id');            $res = RoomUser::where('room_id', $roomId)                ->with('room')->get();            foreach ($res as $item) {                $item['screenshot'] = Util::ensureUrl($item['screenshot']);            }        } catch (ValidationException $e) {            return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());        } catch (Exception $e) {            return $this->error(intval($e->getCode()), $e->getMessage());        }        return $this->success($res);    }    /**     * @api {get} /admin/room 游戏房间     * @apiGroup 房间管理     *     * @apiUse result     * @apiUse header     * @apiVersion 1.0.0     *     * @apiParam {int} [page=1]     * @apiParam {int} [limit=10]     * @apiParam {string} [room_id] 房间号     * @apiParam {string} [member_id] 房主 tg会员ID     * @apiParam {int} [status] 状态     * - 0 创建中     * - 1 创建完成     * - 2 游戏中     * - 3 已结算     * @apiSuccess (data) {Object} data     * @apiSuccess (data) {int} data.total 数量     * @apiSuccess (data) {Object[]} data.data 列表     * @apiSuccess (data) {int} data.data.id     * @apiSuccess (data) {string} data.data.room_id 房间号     * @apiSuccess (data) {int} data.data.member_id 房主 tg会员id     * @apiSuccess (data) {string} data.data.game_name 游戏名称     * @apiSuccess (data) {string} data.data.base_score 底分     * @apiSuccess (data) {string} data.data.participants 人数     * @apiSuccess (data) {string} data.data.rounds 局数     * @apiSuccess (data) {string} data.data.join_count 已加入人数     * @apiSuccess (data) {string} data.data.updated_at     * @apiSuccess (data) {string} data.data.created_at     * @apiSuccess (data) {int} data.data.status 状态     * - 0 创建中     * - 1 创建完成     * - 2 游戏中     * - 3 已结算     */    public function index()    {        try {            request()->validate([                'room_id' => ['nullable', 'string', 'min:1'],                'member_id' => ['nullable', 'string', 'min:1'],                'status' => ['nullable', 'integer', 'min:0', 'max:3']            ]);            $search = request()->all();            $search['not_status'] = 0;            $search['like_room_id'] = true; // 模糊查询房间号            $result = RoomService::paginate($search);        } catch (ValidationException $e) {            return $this->error(HttpStatus::CUSTOM_ERROR, $e->validator->errors()->first());        } catch (Exception $e) {            return $this->error(intval($e->getCode()), $e->getMessage());        }        return $this->success($result);    }}
 |