index.ts 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. import request from '@/config/axios'
  2. // IoT 设备 VO
  3. export interface DeviceVO {
  4. id: number // 设备 ID,主键,自增
  5. deviceKey: string // 设备唯一标识符
  6. deviceName: string // 设备名称
  7. productId: number // 产品编号
  8. productKey: string // 产品标识
  9. deviceType: number // 设备类型
  10. nickname: string // 设备备注名称
  11. gatewayId: number // 网关设备 ID
  12. status: number // 设备状态
  13. statusLastUpdateTime: Date // 设备状态最后更新时间
  14. lastOnlineTime: Date // 最后上线时间
  15. lastOfflineTime: Date // 最后离线时间
  16. activeTime: Date // 设备激活时间
  17. createTime: Date // 创建时间
  18. ip: string // 设备的 IP 地址
  19. firmwareVersion: string // 设备的固件版本
  20. deviceSecret: string // 设备密钥,用于设备认证,需安全存储
  21. mqttClientId: string // MQTT 客户端 ID
  22. mqttUsername: string // MQTT 用户名
  23. mqttPassword: string // MQTT 密码
  24. authType: string // 认证类型
  25. latitude: number // 设备位置的纬度
  26. longitude: number // 设备位置的经度
  27. areaId: number // 地区编码
  28. address: string // 设备详细地址
  29. serialNumber: string // 设备序列号
  30. groupIds?: number[] // 添加分组 ID
  31. }
  32. export interface DeviceUpdateStatusVO {
  33. id: number // 设备 ID,主键,自增
  34. status: number // 设备状态
  35. }
  36. // IoT 设备数据 VO
  37. export interface DeviceDataVO {
  38. deviceId: number // 设备编号
  39. thinkModelFunctionId: number // 物模型编号
  40. productKey: string // 产品标识
  41. deviceName: string // 设备名称
  42. identifier: string // 属性标识符
  43. name: string // 属性名称
  44. dataType: string // 数据类型
  45. updateTime: Date // 更新时间
  46. value: string // 最新值
  47. }
  48. // IoT 设备数据 VO
  49. export interface DeviceHistoryDataVO {
  50. time: number // 时间
  51. data: string // 数据
  52. }
  53. // 设备 API
  54. export const DeviceApi = {
  55. // 查询设备分页
  56. getDevicePage: async (params: any) => {
  57. return await request.get({ url: `/iot/device/page`, params })
  58. },
  59. // 查询设备详情
  60. getDevice: async (id: number) => {
  61. return await request.get({ url: `/iot/device/get?id=` + id })
  62. },
  63. // 新增设备
  64. createDevice: async (data: DeviceVO) => {
  65. return await request.post({ url: `/iot/device/create`, data })
  66. },
  67. // 修改设备
  68. updateDevice: async (data: DeviceVO) => {
  69. return await request.put({ url: `/iot/device/update`, data })
  70. },
  71. // 修改设备状态
  72. updateDeviceStatus: async (data: DeviceUpdateStatusVO) => {
  73. return await request.put({ url: `/iot/device/update-status`, data })
  74. },
  75. // 删除设备
  76. deleteDevice: async (id: number) => {
  77. return await request.delete({ url: `/iot/device/delete?id=` + id })
  78. },
  79. // 导出设备
  80. exportDeviceExcel: async (params: any) => {
  81. return await request.download({ url: `/iot/device/export-excel`, params })
  82. },
  83. // 获取设备数量
  84. getDeviceCount: async (productId: number) => {
  85. return await request.get({ url: `/iot/device/count?productId=` + productId })
  86. },
  87. // 获取设备的精简信息列表
  88. getSimpleDeviceList: async (deviceType?: number) => {
  89. return await request.get({ url: `/iot/device/simple-list?`, params: { deviceType } })
  90. },
  91. // 获取设备属性最新数据
  92. getDevicePropertiesLatestData: async (params: any) => {
  93. return await request.get({ url: `/iot/device/data/latest`, params })
  94. },
  95. // 获取设备属性历史数据
  96. getDevicePropertiesHistoryData: async (params: any) => {
  97. return await request.get({ url: `/iot/device/data/history`, params })
  98. }
  99. }