using Cis.Core.Common; using Newtonsoft.Json.Linq; namespace Cis.Application.Cb; /// /// 相机服务 /// [ApiDescriptionSettings(CbInfo.GroupName, Order = CbInfo.CbCameraGroupOrder)] public class CbCameraService : ServiceBase, ITransient { protected readonly SqlSugarRepository _cbCameraParamsRep; public CbCameraService(SqlSugarRepository baseRep, SqlSugarRepository cbCameraParamsRep) : base(baseRep) { _cbCameraParamsRep = cbCameraParamsRep; } /// /// 获取实体类 /// /// equal:cbCameraParamsId,id,isDelete; like:ip,name; between:[startTime,endTime]; /// [HttpGet] public override async Task GetByQ([Required] 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("Id", StringComparison.OrdinalIgnoreCase, out JToken Id)) exp.And(it => it.Id.Equals(Id)); if (queryObj.TryGetValue("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete)) exp.And(it => it.IsDelete.Equals(isDelete)); 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 entity = await _baseRep.AsQueryable() .Where(exp.ToExpression()) .FirstAsync(); return entity; } /// /// 批量获取实体类 /// /// equal:cbCameraParamsId,isDelete; like:ip,name; between:[startTime,endTime]; /// [HttpGet] public override 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("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete)) exp.And(it => it.IsDelete.Equals(isDelete)); 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,isDelete; like:ip,name; between:[startTime,endTime]; /// index,size /// [HttpGet] public override async Task> GetPageList([Required] string pagination, string queryJson = "") { 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("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete)) exp.And(it => it.IsDelete.Equals(isDelete)); 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; } #region BO /// /// 获取实体类 BO /// /// 实体类 id /// [HttpGet] public async Task GetBO([Required] long id) { CbCamera camera = await _baseRep.GetByIdAsync(id); if (camera == null) return null; CbCameraParams cameraParams = await _cbCameraParamsRep.GetByIdAsync(camera.CbCameraParamsId); if (cameraParams == null) return null; CbCameraBO bo = CbCameraBO.New(camera.Id, camera, cameraParams); return bo; } /// /// 批量获取实体类 BO /// /// equal:cbCameraParamsId,isDelete; like:ip,name; between:[startTime,endTime]; /// [HttpGet] public async Task> GetBOList(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("IsDelete", StringComparison.OrdinalIgnoreCase, out JToken isDelete)) exp.And(it => it.IsDelete.Equals(isDelete)); 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()); List cameraList = await _baseRep.AsQueryable() .Where(exp.ToExpression()) .ToListAsync(); HashSet paramsIdSet = new(); foreach (var item in cameraList) paramsIdSet.Add(item.CbCameraParamsId); List paramsList = await _cbCameraParamsRep.AsQueryable() .Where(it => paramsIdSet.ToList().Contains(it.Id)) .ToListAsync(); Dictionary paramsDict = new(); foreach (var item in paramsList) paramsDict.Add(item.Id, item); List boList = new(); foreach (var item in cameraList) boList.Add(CbCameraBO.New(item.Id, item, paramsDict[item.CbCameraParamsId])); return boList; } #endregion BO }