using Api.DBAccess; using Api.Models; using Api.Models.Devices; using Api.Models.Users; using Microsoft.AspNetCore.Mvc; using Microsoft.EntityFrameworkCore; namespace Api.BusinessLogic { public class DeviceLogic { private readonly DbAccess _dbAccess; private readonly IConfiguration _configuration; public DeviceLogic(IConfiguration configuration, DbAccess dbAccess) { _dbAccess = dbAccess; _configuration = configuration; } /// /// Gets the user from dbaccess using the userId and checks if the user exists /// Gets all devices that match the userId and checks if there are any devices connected to the user /// /// UserId that matches a user that owns the devices /// returns the devices in a OkObjectResult and if there is some error it returns a ConflictObjectResult and a message that explain the reason public async Task GetDevices(int userId) { var userDetails = await _dbAccess.ReadUserDetails(userId); if (userDetails.Devices.Count == 0) { return new OkObjectResult(new { message = "Could not find any devices connected to the user" }); } List devices = new List(); foreach (var item in userDetails.Devices) { var latestLog = item.Logs?.OrderByDescending(log => log.Date).FirstOrDefault(); // Get the latest log GetDeviceDTO device = new GetDeviceDTO { Id = item.Id, Name = item.Name, TempHigh = item.TempHigh, TempLow = item.TempLow, ReferenceId = item.ReferenceId, LatestLog = latestLog }; devices.Add(device); } return new OkObjectResult(devices); } /// /// Checks if the user that the device is trying to be added to exists /// Then it is send to dbaccess /// /// The new device /// The user that owns the device /// returns true in a OkObjectResult and if there is some error it returns a ConflictObjectResult and a message that explain the reason public async Task AddDevice(string referenceId, int userId) { var user = await _dbAccess.ReadUserDetails(userId); var possibleDevice = _dbAccess.ReadDevice(referenceId); if (possibleDevice != null) { return new ConflictObjectResult(new { message = "Device with given referenceId already exists" }); } if (user == null) { return new ConflictObjectResult(new { message = "Could not find user" }); } Device device = new Device { Name = "Undefined", TempHigh = 0, TempLow = 0, ReferenceId = referenceId, Logs = new List(), }; user.Devices.Add(device); return await _dbAccess.CreateDevice(user); } /// /// Checks if the deviceId matches a device /// /// The updated info /// The device to be edited /// returns the updated device in a OkObjectResult and if there is some error it returns a ConflictObjectResult and a message that explain the reason public async Task EditDevice(EditDeviceRequest request, int deviceId) { var device = await _dbAccess.ReadDevice(deviceId); if (device != null) { if (device.Name == "" || device.Name == null) return new ConflictObjectResult(new { message = "Please enter a name" }); device.Name = request.Name; device.TempLow = request.TempLow; device.TempHigh = request.TempHigh; } return await _dbAccess.EditDevice(device); } /// /// deletes a device /// /// the id used to delete /// Used for deleting device from devices list in user /// returns OK public async Task DeleteDevice(int deviceId) { var device = await _dbAccess.ReadDevice(deviceId); if (device != null) { return await _dbAccess.DeleteDevice(device); } return new ConflictObjectResult(new { message = "Invalid user" }); } /// /// Checks if the device exist that is trying to be read from /// Gets the logs and checks if there are any in the list /// Checks if the datetimeRange have 2 values that are the same bc that means they want all logs /// Then it makes a new list with all data that are in the range of the 2 datetimes /// /// The deviceId that you want from the logs /// returns the logs in a OkObjectResult and if there is some error it returns a ConflictObjectResult and a message that explain the reason public async Task GetLogs(DateTimeRange dateTimeRange, int deviceId) { var device = await _dbAccess.ReadDevice(deviceId); if (device == null) { return new ConflictObjectResult(new { message = "Could not find device" }); } var logs = await _dbAccess.ReadLogs(deviceId, dateTimeRange); return new OkObjectResult(logs); } } }