using Newtonsoft.Json.Linq; namespace Cis.Application.Cb; /// /// 相机服务 /// [ApiDescriptionSettings(CbInfo.GroupName, Order = CbInfo.GroupOrder)] public class CbCameraService : IDynamicApiController, ITransient { private readonly SqlSugarRepository _baseRep; public CbCameraService(SqlSugarRepository baseRep) { _baseRep = baseRep; } [HttpPost] public async Task Add([FromForm] CbCamera entity) { return await _baseRep.InsertAsync(entity); } [HttpPost] public async Task Update([FromForm] CbCamera entity) { return await _baseRep.UpdateAsync(entity); } [HttpPost] public async Task Delete([FromForm] CbCamera entity) { return await _baseRep.DeleteAsync(entity); } [HttpGet] public async Task Get(long id) { CbCamera entity = await _baseRep.GetByIdAsync(id); return entity; } /// /// /// /// equal:cbCameraParamsId; like:ip,name; between:[startTime,endTime]; /// [HttpGet] public async Task> GetList(string queryJson = "") { JObject queryObj = queryJson.ToJObject(); var exp = Expressionable.Create(); if (queryObj.TryGetValue("cbCameraParamsId", StringComparison.OrdinalIgnoreCase, out JToken cbCameraParamsId)) exp.And(it => it.CbCameraParamsId.Equals(cbCameraParamsId)); if (queryObj.TryGetValue("name", StringComparison.OrdinalIgnoreCase, out JToken name)) exp.And(it => it.Name.Contains(name.ToString())); if (queryObj.TryGetValue("ip", StringComparison.OrdinalIgnoreCase, out JToken ip)) exp.And(it => it.Ip.Contains(ip.ToString())); if (queryObj.TryGetValue("StartTime", StringComparison.OrdinalIgnoreCase, out JToken startTime) && queryObj.TryGetValue("EndTime", StringComparison.OrdinalIgnoreCase, out JToken endTime)) exp.And(it => it.CreateTime >= startTime.ToDateTime() && it.CreateTime <= endTime.ToDateTime()); var list = await _baseRep.AsQueryable() .Where(exp.ToExpression()) .ToListAsync(); return list; } /// /// /// /// equal:cbCameraParamsId; like:ip,name; between:[startTime,endTime]; /// index,size /// [HttpGet] public async Task> GetPageList(string queryJson, string pagination) { JObject queryObj = queryJson.ToJObject(); Pagination pageObj = pagination.ToObject(); var exp = Expressionable.Create(); if (queryObj.TryGetValue("cbCameraParamsId", StringComparison.OrdinalIgnoreCase, out JToken cbCameraParamsId)) exp.And(it => it.CbCameraParamsId.Equals(cbCameraParamsId)); if (queryObj.TryGetValue("name", StringComparison.OrdinalIgnoreCase, out JToken name)) exp.And(it => it.Name.Contains(name.ToString())); if (queryObj.TryGetValue("ip", StringComparison.OrdinalIgnoreCase, out JToken ip)) exp.And(it => it.Ip.Contains(ip.ToString())); if (queryObj.TryGetValue("StartTime", StringComparison.OrdinalIgnoreCase, out JToken startTime) && queryObj.TryGetValue("EndTime", StringComparison.OrdinalIgnoreCase, out JToken endTime)) exp.And(it => it.CreateTime >= startTime.ToDateTime() && it.CreateTime <= endTime.ToDateTime()); var list = await _baseRep.AsQueryable() .Where(exp.ToExpression()) .ToPageListAsync(pageObj.Index, pageObj.Size); return list; } }