using Blahblah.FlowerStory.Server.Data; using Blahblah.FlowerStory.Server.Data.Model; using Microsoft.AspNetCore.Mvc; namespace Blahblah.FlowerStory.Server.Controller; /// /// 事件相关服务 /// [ApiController] [Produces("application/json")] [Route("api/event")] public class EventController : BaseController { /// public EventController(FlowerDatabase database, ILogger? logger = null) : base(database, logger) { } /// /// 获取用户相关所有符合条件的事件 /// /// /// 请求示例: /// /// GET /api/event/query /// Authorization: authorization id /// /// 参数: /// /// cid: int? /// key: string? /// from: long? /// to: long? /// cfrom: decimal? /// cto: decimal? /// /// /// 事件类型 id /// 查询关键字 /// 起始日期 /// 结束日期 /// 会话有效则返回符合条件的花草集 /// 返回符合条件的花草集 /// 未找到登录会话或已过期 /// 用户已禁用 /// 未找到关联用户 [Route("query", Name = "queryEvents")] [ProducesResponseType(StatusCodes.Status200OK)] [ProducesResponseType(StatusCodes.Status401Unauthorized)] [ProducesResponseType(StatusCodes.Status403Forbidden)] [ProducesResponseType(StatusCodes.Status404NotFound)] [HttpGet] public ActionResult GetRecords( [FromQuery(Name = "eid")] int? eventId, [FromQuery] string? key, [FromQuery] long? from, [FromQuery] long? to) { var (result, user) = CheckPermission(); if (result != null) { return result; } if (user == null) { return NotFound(); } SaveDatabase(); var records = database.Records.Where(r => r.OwnerId == user.Id); if (eventId != null) { records = records.Where(r => r.EventId == eventId); } if (key != null) { records = records.Where(r => r.ByUserName != null && r.ByUserName.ToLower().Contains(key.ToLower()) // TODO: notes ); } if (from != null) { records = records.Where(r => r.DateUnixTime >= from); } if (to != null) { records = records.Where(r => r.DateUnixTime <= to); } return Ok(records.ToArray()); } }