|  |  | @ -1,4 +1,6 @@ | 
			
		
	
		
			
				
					|  |  |  | 'use strict'; | 
			
		
	
		
			
				
					|  |  |  | const fs = require('fs'); | 
			
		
	
		
			
				
					|  |  |  | const moment = require('moment') | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | async function getCameraProject (ctx, next) { | 
			
		
	
		
			
				
					|  |  |  |    try { | 
			
		
	
	
		
			
				
					|  |  | @ -238,21 +240,130 @@ async function del (ctx) { | 
			
		
	
		
			
				
					|  |  |  |    } | 
			
		
	
		
			
				
					|  |  |  | } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | async function cameraExport(ctx){ | 
			
		
	
		
			
				
					|  |  |  | async function cameraExport (ctx) { | 
			
		
	
		
			
				
					|  |  |  |    try { | 
			
		
	
		
			
				
					|  |  |  |       const { models } = ctx.fs.dc | 
			
		
	
		
			
				
					|  |  |  |       const { userId, token } = ctx.fs.api | 
			
		
	
		
			
				
					|  |  |  |       const { utils: { simpleExcelDown } } = ctx.app.fs | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       const header = [{ | 
			
		
	
		
			
				
					|  |  |  |          title: "设备名称", | 
			
		
	
		
			
				
					|  |  |  |          key: "name", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "设备厂家", | 
			
		
	
		
			
				
					|  |  |  |          key: "vender", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "接入类型", | 
			
		
	
		
			
				
					|  |  |  |          key: "type", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "设备状态", | 
			
		
	
		
			
				
					|  |  |  |          key: "state", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "云台支持", | 
			
		
	
		
			
				
					|  |  |  |          key: "cloudControl", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "内存卡信息", | 
			
		
	
		
			
				
					|  |  |  |          key: "memoryCard", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "设备创建时间", | 
			
		
	
		
			
				
					|  |  |  |          key: "createTime", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "设备添加账号", | 
			
		
	
		
			
				
					|  |  |  |          key: "createUser", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "项目名称", | 
			
		
	
		
			
				
					|  |  |  |          key: "projectName", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "pcode", | 
			
		
	
		
			
				
					|  |  |  |          key: "pcode", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "结构物", | 
			
		
	
		
			
				
					|  |  |  |          key: "structure", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "测点", | 
			
		
	
		
			
				
					|  |  |  |          key: "stationName", | 
			
		
	
		
			
				
					|  |  |  |       }, { | 
			
		
	
		
			
				
					|  |  |  |          title: "监测因素", | 
			
		
	
		
			
				
					|  |  |  |          key: "factor", | 
			
		
	
		
			
				
					|  |  |  |       },]; | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       const cameraRes = await models.Camera.findAll({ | 
			
		
	
		
			
				
					|  |  |  |          where: { | 
			
		
	
		
			
				
					|  |  |  |             createUserId: userId, | 
			
		
	
		
			
				
					|  |  |  |             recycleTime: null, | 
			
		
	
		
			
				
					|  |  |  |             delete: false | 
			
		
	
		
			
				
					|  |  |  |          }, | 
			
		
	
		
			
				
					|  |  |  |          include: [{ | 
			
		
	
		
			
				
					|  |  |  |             model: models.CameraAbility | 
			
		
	
		
			
				
					|  |  |  |          }, { | 
			
		
	
		
			
				
					|  |  |  |             model: models.CameraKind | 
			
		
	
		
			
				
					|  |  |  |          }, { | 
			
		
	
		
			
				
					|  |  |  |             model: models.Vender | 
			
		
	
		
			
				
					|  |  |  |          }] | 
			
		
	
		
			
				
					|  |  |  |       }) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       // const filePath = await simpleExcelDown({ data: exportData, header, fileName: `NVR信息列表_${userId}_${moment().format('YYYYMMDDHHmmss')}` })
 | 
			
		
	
		
			
				
					|  |  |  |       // const fileData = fs.readFileSync(filePath);
 | 
			
		
	
		
			
				
					|  |  |  |       // let fileName = filePath.split('/').pop()
 | 
			
		
	
		
			
				
					|  |  |  |       // ctx.status = 200;
 | 
			
		
	
		
			
				
					|  |  |  |       // ctx.set('Content-Type', 'application/x-xls');
 | 
			
		
	
		
			
				
					|  |  |  |       // ctx.set('Content-disposition', 'attachment; filename=' + encodeURI(fileName));
 | 
			
		
	
		
			
				
					|  |  |  |       // ctx.body = fileData;
 | 
			
		
	
		
			
				
					|  |  |  |       let cameraIds = [] | 
			
		
	
		
			
				
					|  |  |  |       let createUserIds = new Set() | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       for (let c of cameraRes) { | 
			
		
	
		
			
				
					|  |  |  |          cameraIds.push(c.dataValues.id) | 
			
		
	
		
			
				
					|  |  |  |          createUserIds.add(c.dataValues.createUserId) | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       // 查在安心云绑定的数据
 | 
			
		
	
		
			
				
					|  |  |  |       const axbindCameraRes = await ctx.app.fs.axyRequest.get('vcmp/camera/project', { query: { token, cameraId: cameraIds.join(',') } }) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       // 查对应创建者信息
 | 
			
		
	
		
			
				
					|  |  |  |       const corUsers = await ctx.app.fs.authRequest.get(`user/${[...createUserIds].join(',') || -1}/message`, { query: { token } }) | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       let exportData = [] | 
			
		
	
		
			
				
					|  |  |  |       let typeMap = { | 
			
		
	
		
			
				
					|  |  |  |          yingshi: '萤石云平台摄像头', | 
			
		
	
		
			
				
					|  |  |  |          nvr: 'NVR摄像头', | 
			
		
	
		
			
				
					|  |  |  |          ipc: 'IPC 网络摄像头', | 
			
		
	
		
			
				
					|  |  |  |          cascade: '不明厂家', | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  |       for (let { dataValues: camera } of cameraRes) { | 
			
		
	
		
			
				
					|  |  |  |          camera.vender = camera.vender ? camera.vender.name : '' | 
			
		
	
		
			
				
					|  |  |  |          camera.type = typeMap[camera.type] | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |          const corUser = corUsers.find(u => u.id == camera.createUserId) | 
			
		
	
		
			
				
					|  |  |  |          camera.createUser = corUser ? corUser.username : '' | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |          let stationName = new Set(), | 
			
		
	
		
			
				
					|  |  |  |             projectName = new Set(), | 
			
		
	
		
			
				
					|  |  |  |             pcode = new Set(), | 
			
		
	
		
			
				
					|  |  |  |             structure = new Set(), | 
			
		
	
		
			
				
					|  |  |  |             factor = new Set() | 
			
		
	
		
			
				
					|  |  |  |          const corBindCamera = axbindCameraRes.find(b => b.cameraId == camera.id) | 
			
		
	
		
			
				
					|  |  |  |          if (corBindCamera) { | 
			
		
	
		
			
				
					|  |  |  |             for (let station of corBindCamera.stations) { | 
			
		
	
		
			
				
					|  |  |  |                stationName.add(station.name) | 
			
		
	
		
			
				
					|  |  |  |                factor.add(station.factor.name) | 
			
		
	
		
			
				
					|  |  |  |                structure.add(station.structure.name) | 
			
		
	
		
			
				
					|  |  |  |                for (let project of station.structure.projects) { | 
			
		
	
		
			
				
					|  |  |  |                   projectName.add(project.name) | 
			
		
	
		
			
				
					|  |  |  |                   pcode.add(project.url) | 
			
		
	
		
			
				
					|  |  |  |                } | 
			
		
	
		
			
				
					|  |  |  |             } | 
			
		
	
		
			
				
					|  |  |  |          } | 
			
		
	
		
			
				
					|  |  |  |          camera.stationName = [...stationName].join('\r\n') | 
			
		
	
		
			
				
					|  |  |  |          camera.factor = [...factor].join('\r\n') | 
			
		
	
		
			
				
					|  |  |  |          camera.projectName = [...projectName].join('\r\n') | 
			
		
	
		
			
				
					|  |  |  |          camera.pcode = [...pcode].join('\r\n') | 
			
		
	
		
			
				
					|  |  |  |          camera.structure = [...structure].join('\r\n') | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |          exportData.push(camera) | 
			
		
	
		
			
				
					|  |  |  |       } | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  | 
 | 
			
		
	
		
			
				
					|  |  |  |       const filePath = await simpleExcelDown({ data: exportData, header, fileName: `摄像头信息列表_${userId}_${moment().format('YYYYMMDDHHmmss')}` }) | 
			
		
	
		
			
				
					|  |  |  |       const fileData = fs.readFileSync(filePath); | 
			
		
	
		
			
				
					|  |  |  |       let fileName = filePath.split('/').pop() | 
			
		
	
		
			
				
					|  |  |  |       ctx.status = 200; | 
			
		
	
		
			
				
					|  |  |  |       ctx.set('Content-Type', 'application/x-xls'); | 
			
		
	
		
			
				
					|  |  |  |       ctx.set('Content-disposition', 'attachment; filename=' + encodeURI(fileName)); | 
			
		
	
		
			
				
					|  |  |  |       ctx.body = fileData; | 
			
		
	
		
			
				
					|  |  |  |    } catch (error) { | 
			
		
	
		
			
				
					|  |  |  |       ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); | 
			
		
	
		
			
				
					|  |  |  |       ctx.status = 400; | 
			
		
	
	
		
			
				
					|  |  | 
 |