You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
iot/projects/IoTCenter/Areas/Admin/Controllers/IoT/DataController.cs

105 lines
4.0 KiB

using System;
using System.Collections.Generic;
using System.Linq;
using Application.Domain.Entities;
using Application.Models;
using Infrastructure.Data;
using Infrastructure.Extensions;
using Infrastructure.Web.Mvc;
using IoTCenter.Services;
using IoTShared.Controllers;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.SignalR;
using Microsoft.EntityFrameworkCore;
namespace IoTCenter.Areas.Admin.Controllers
{
[Authorize]
[Area(nameof(Admin))]
public class DataController : CrudController<Data, DataSearchModel, EditDataModel, EditDataModel>
{
private readonly IRepository<Data> _repo;
private readonly AjaxController _ajax;
private readonly IHubContext<PageHub> _pageHubContext;
public DataController(IRepository<Data> repo, AjaxController ajax, IHubContext<PageHub> pageHubContext) : base(repo)
{
this._repo = repo;
this._ajax = ajax;
this._pageHubContext = pageHubContext;
}
public override IQueryable<Data> Include(IQueryable<Data> query)
{
return query.Include(o => o.Device).ThenInclude(o => o.Node);
}
public override IQueryable<Data> Query(DataSearchModel model, IQueryable<Data> query)
{
if (model == null)
{
throw new ArgumentNullException(nameof(model));
}
ViewData.SelectList(o => model.NodeId, () => this._ajax.GetNodeSelectList(model.NodeId));
ViewData.SelectList(o => model.DeviceId, () => this._ajax.GetDeviceSelectList(model.NodeId.Value, model.DeviceId), model.NodeId.HasValue);
return query.WhereIf(model.NodeId.HasValue, o => o.Device.NodeId == model.NodeId.Value)
.WhereIf(model.DeviceId.HasValue, o => o.DeviceId == model.DeviceId.Value)
.WhereIf(!string.IsNullOrEmpty(model.Keyword), o => o.Name.Contains(model.Keyword));
}
public override void ToModel(Data entity, EditDataModel model)
{
if (entity == null)
{
throw new ArgumentNullException(nameof(entity));
}
if (model == null)
{
throw new ArgumentNullException(nameof(model));
}
model.DeviceNumber = entity.Device.Number;
model.NodeNumber = entity.Device.Node.Number;
}
public override IActionResult Edit(EditDataModel model)
{
if (model == null)
{
throw new ArgumentNullException(nameof(model));
}
if (ModelState.IsValid)
{
this._pageHubContext.Clients.Group(model.NodeNumber).SendAsync(Methods.ServerToClient, Methods.EditDataRequest, model.ToJson(), null);
return RedirectTo();
}
ModelState.AddModelError("", "<22><><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><ECB3A3><EFBFBD><EFBFBD><EFBFBD>Ժ<EFBFBD><D4BA><EFBFBD><EFBFBD><EFBFBD>");
return View(model);
}
[System.Diagnostics.CodeAnalysis.SuppressMessage("Design", "CA1031:<3A><><EFBFBD><EFBFBD><EFBFBD>񳣹<EFBFBD><F1B3A3B9><EFBFBD><ECB3A3><EFBFBD><EFBFBD>", Justification = "<<3C><><EFBFBD><EFBFBD>>")]
public override IActionResult Delete(List<Guid> list)
{
if (list == null)
{
throw new ArgumentNullException(nameof(list));
}
foreach (var id in list)
{
try
{
var entity = this._repo.ReadOnlyTable().Include(o => o.Device).ThenInclude(o => o.Node).FirstOrDefault(o => o.Id == id);
var model = entity.To<EditDataModel>();
model.DeviceNumber = entity.Device.Number;
this._pageHubContext.Clients.Group(entity.Device.Node.Number).SendAsync(Methods.ServerToClient, Methods.DeleteDataRequest, model.ToJson(), null);
}
catch (Exception ex)
{
ex.PrintStack();
return RedirectTo(rawMesage: ex.Message);
}
}
return RedirectTo();
}
}
}