ningshuxia
2022-12-12 e81ca048ef4e9345e904b74ffffd3e8413d18a7e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
using Microsoft.AspNetCore.Mvc;
using System.Net;
using System.Net.Http.Headers;
using Microsoft.Extensions.Hosting.Internal;
using Microsoft.AspNetCore.Http.Extensions;
using IStation.Untity;
using Furion.DynamicApiController;
using System.ComponentModel.DataAnnotations;
using Mapster;
using Microsoft.AspNetCore.Http;
using Furion.DependencyInjection;
using Microsoft.AspNetCore.Authorization;
using Furion.DataEncryption;
using Furion.FriendlyException;
 
namespace IStation.Application
{
    /// <summary>
    /// 运行
    /// </summary>
    [AllowAnonymous]
    [Route("LargeScreen/Szjt/Run")]
    [ApiDescriptionSettings("LargeScreen", Name = "苏州金庭(运行)", Order = 999)]
    public class SzjtRun_Controller : IDynamicApiController, ITransient
    {
        private readonly IHttpContextAccessor _httpContextAccessor;
 
        /// <summary>
        /// 
        /// </summary>
        public SzjtRun_Controller(IHttpContextAccessor httpContextAccessor)
        {
            _httpContextAccessor = httpContextAccessor;
        }
 
        private const long _corpId = 3;
 
        /// <summary>
        /// 通过 MonitorPointIds  获取最近一条数据
        /// </summary>
        [Route("GetLastRecordByMonitorPointIds")]
        [HttpGet]
        public List<SzjtMonitorRecordDto> GetLastRecordByMonitorPointIds([FromQuery][Required] MonitorPointIdsInput input)
        {
            var ids = LongListHelper.ToList(input.MonitorPointIds);
            var list = new Service.MonitorRecord().GetLastRecord(_corpId,ids);
            return list?.Select(x => new SzjtMonitorRecordDto(x)).ToList();
        }
 
        /// <summary>
        /// 通过 MonitorPointID 获取某天的实时数据
        /// </summary>
        [Route("GetRealRecordListByMonitorPointIDOfDay")]
        [HttpGet]
        public List<SzjtMonitorRealRecordDto> GetRealRecordListByMonitorPointIDOfDay
            (
                [Required, Range(1, long.MaxValue, ErrorMessage = "MonitorPointID 必须大于0")]
                long MonitorPointID,
                [Required]
                DateTime Day
            )
        {
            var list = new Service.MonitorRealRecord().GetByMonitorPointIDOfDay(_corpId, MonitorPointID, Day);
            return list?.Select(x => new SzjtMonitorRealRecordDto(x)).ToList();
        }
 
    }
}