mirror of
https://github.com/project-redbud/FunGame-Server.git
synced 2025-04-21 11:39:36 +08:00

* PayloadModel 添加 event 属性,添加 Room,Main 的 API 控制器 * 实现 SQLHelper 的自增 ID、异步版本功能 * 填充一些请求控制器的方法 * 添加报价的核心操作 * 涉及库存的物品获取应该使用 Guid 而不是 ItemId * 添加 InventoryController * 添加更新房间设置和用户房间的状态管理 * 优化 API Token 秘钥管理;修复服务器统一报错信息 BUG * 优雅的关闭服务器;补全了所有数据请求实现;API Token 加密方式修改;添加了服务器初始化时创建管理员账号的必要步骤 * 完善 Web API 控制器 --------- Co-authored-by: yeziuku <yezi@wrss.org>
84 lines
3.0 KiB
C#
84 lines
3.0 KiB
C#
using Microsoft.AspNetCore.Authorization;
|
|
using Microsoft.AspNetCore.Mvc;
|
|
using Milimoe.FunGame.Core.Library.Constant;
|
|
using Milimoe.FunGame.WebAPI.Models;
|
|
|
|
namespace Milimoe.FunGame.WebAPI.Controllers
|
|
{
|
|
[ApiController]
|
|
[Route("[controller]")]
|
|
[Authorize]
|
|
public class DataRequestController(RESTfulAPIModel model, ILogger<DataRequestController> logger) : ControllerBase
|
|
{
|
|
private readonly ILogger<DataRequestController> _logger = logger;
|
|
|
|
[HttpPost]
|
|
public async Task<IActionResult> Post([FromBody] PayloadModel<DataRequestType> payload)
|
|
{
|
|
try
|
|
{
|
|
PayloadModel<DataRequestType> response = new()
|
|
{
|
|
Event = "data_request",
|
|
RequestType = payload.RequestType
|
|
};
|
|
|
|
if (payload.RequestType == DataRequestType.RunTime_Logout || payload.RequestType == DataRequestType.Reg_Reg ||
|
|
payload.RequestType == DataRequestType.Login_Login || payload.RequestType == DataRequestType.Login_GetFindPasswordVerifyCode)
|
|
{
|
|
response.StatusCode = 400;
|
|
response.Message = $"请求类型 {DataRequestSet.GetTypeString(payload.RequestType)} 不允许通过此接口处理!";
|
|
return StatusCode(400, response);
|
|
}
|
|
|
|
if (model.RequestID == Guid.Empty)
|
|
{
|
|
Guid uid = Guid.NewGuid();
|
|
model.RequestID = uid;
|
|
|
|
using CancellationTokenSource cts = model.SetRequestTimeout(uid);
|
|
Dictionary<string, object> result = [];
|
|
try
|
|
{
|
|
result = await model.DataRequestController.GetResultData(payload.RequestType, payload.Data);
|
|
}
|
|
catch (TimeoutException)
|
|
{
|
|
_logger.LogWarning("请求超时。");
|
|
return StatusCode(408);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
_logger.LogError("Error: {e}", e);
|
|
return StatusCode(500);
|
|
}
|
|
finally
|
|
{
|
|
model.RequestID = Guid.Empty;
|
|
}
|
|
|
|
response.StatusCode = 200;
|
|
response.Data = result;
|
|
return Ok(response);
|
|
}
|
|
else
|
|
{
|
|
response.StatusCode = 400;
|
|
response.Message = "请求未执行完毕,请等待!";
|
|
return BadRequest(response);
|
|
}
|
|
}
|
|
catch (TimeoutException)
|
|
{
|
|
_logger.LogWarning("请求超时。");
|
|
return StatusCode(408);
|
|
}
|
|
catch (Exception e)
|
|
{
|
|
_logger.LogError("Error: {e}", e);
|
|
return StatusCode(500);
|
|
}
|
|
}
|
|
}
|
|
}
|