__load__.py 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389
  1. #!/usr/bin/env python
  2. # -*- coding: utf-8 -*-
  3. """
  4. demeter load
  5. author:rabin
  6. """
  7. from demeter.web import *
  8. class Load(Base):
  9. KEYS = ('user', 'farm')
  10. def setting(self):
  11. self.user()
  12. def user(self):
  13. ajax = self.input('ajax')
  14. if ajax:
  15. self.data['ajax'] = True
  16. else:
  17. self.data['ajax'] = False
  18. self.data['auth'] = True
  19. if 'user' in self.data['setting'] and self.data['setting']['user'] > 0:
  20. self.data['setting']['userInfo'] = self.service('common').one('farm_user', id=self.data['setting']['user'])
  21. self.data['setting']['farm'] = self.data['setting']['userInfo']['farm_id']
  22. else:
  23. return
  24. if 'farm' in self.data['setting'] and self.data['setting']['farm'] > 0:
  25. self.data['setting']['farmInfo'] = self.service('common').one('farm', id=self.data['setting']['farm'])
  26. self.data['setting']['msgNum'] = len(self.service('common').list('msg', search={'status':False, "farm_id":self.data['setting']['farm']}, limit='0,100'))
  27. if self.data['setting']['msgNum'] > 99:
  28. self.data['setting']['msgNum'] = str(99) + '+'
  29. self.data['setting']['web'] = Demeter.config['web']['url']
  30. self.data['setting']['farmurl'] = Demeter.config['web']['farmurl']
  31. cur = 'main'
  32. if '/' in self.request.uri:
  33. temp = self.request.uri.split('/')
  34. slen = len(temp)
  35. if slen > 1 and temp[1]:
  36. cur = temp[1]
  37. self.data['setting']['cur'] = cur
  38. class Device(object):
  39. @staticmethod
  40. def init(self, search={}):
  41. type = self.input('type')
  42. id = self.input('id')
  43. if not id:
  44. self.view('404.html')
  45. return (None, type)
  46. if 'stat' in self.request.uri:
  47. self.data['device_cur'] = 'stat'
  48. elif 'log' in self.request.uri:
  49. self.data['device_cur'] = 'log'
  50. elif 'pic' in self.request.uri:
  51. self.data['device_cur'] = 'pic'
  52. else:
  53. self.data['device_cur'] = 'data'
  54. self.data['show'] = True
  55. self.data['url'] = Device.url('type='+type+'&id=' + id)
  56. if not search:
  57. search = {}
  58. self.data['info'] = {}
  59. self.data['device'] = []
  60. if type == 'gateway':
  61. self.data['info'] = self.service('common').one('device_gateway', id=id)
  62. if not self.data['info']:
  63. self.view('404.html')
  64. return (None, type)
  65. search['gateway_id'] = id
  66. self.data['device'] = Device.get(self, search=search)
  67. if self.data['device_cur'] in ('stat', 'log'):
  68. self.data['pic'] = Device.get(self, search={'gateway_id':id, 'hardware_type':6})
  69. elif type == 'page':
  70. self.data['info'] = self.service('common').one('device_page', id=id)
  71. if not self.data['info']:
  72. self.view('404.html')
  73. return (None, type)
  74. search['page_id'] = id
  75. self.data['group'] = self.service('common').list('device_group', search={'page_id':id}, order='inorder asc,cdate desc')
  76. if self.data['group']:
  77. Device.group(self, search)
  78. else:
  79. self.data['info'] = self.data['setting']['farmInfo']
  80. if not self.data['info']:
  81. self.view('404.html')
  82. return (None, type)
  83. self.data['device'] = Device.get(self, search=search)
  84. if not self.data['device'] or not self.data['info']:
  85. self.view('404.html')
  86. return (None, type)
  87. self.data['input'] = {}
  88. self.data['input']['type'] = type
  89. self.data['input']['id'] = id
  90. return (id, type)
  91. @staticmethod
  92. def set(self):
  93. if 'condition' in self.request.uri:
  94. self.data['set_cur'] = 'condition'
  95. elif 'timing' in self.request.uri:
  96. self.data['set_cur'] = 'timing'
  97. elif 'loop' in self.request.uri:
  98. self.data['set_cur'] = 'loop'
  99. else:
  100. self.data['set_cur'] = 'mul'
  101. self.data['url'] = Device.setUrl()
  102. @staticmethod
  103. def setCronOper(self):
  104. self.data['oper'] = ({'id':1, 'name':'打开'},{'id':2, 'name':'关闭'})
  105. self.data['looptype'] = ({'id':1, 'name':'按日周期', 'list':'每天'},{'id':2, 'name':'按周周期', 'list':'每周'}, {'id': 3, 'name': '按月周期', 'list':'每月'})
  106. self.data['opers'] = ({'id':1, 'name':'无操作'}, {'id':2, 'name':'打开'},{'id':3, 'name':'关闭'})
  107. self.data['week'] = ({'id':1, 'name':'周一'},{'id':2, 'name':'周二'}, {'id': 3, 'name': '周三'}, {'id': 4, 'name': '周四'}, {'id': 5, 'name': '周五'}, {'id': 6, 'name': '周六'}, {'id': 7, 'name': '周日'})
  108. self.data['condition'] = ({'id':1, 'name':'大于', 'exp':'>'}, {'id':2, 'name':'小于', 'exp':'<'},{'id':3, 'name':'等于','exp':'='})
  109. self.data['day'] = []
  110. for i in range(31):
  111. i = i + 1
  112. self.data['day'].append({'id':i, 'name':i})
  113. self.data['hour'] = []
  114. for i in range(24):
  115. i = i + 1
  116. self.data['hour'].append({'id':i, 'name':Demeter.hour(i)})
  117. self.data['minute'] = []
  118. for i in range(60):
  119. self.data['minute'].append({'id':i, 'name':Demeter.hour(i)})
  120. @staticmethod
  121. def get(self, search):
  122. if 'id--ins' in search and search['id--ins']:
  123. search['id--ins'] = tuple(eval(search['id--ins']))
  124. return self.service('common').list('device_info', state=True, search=search, order='type_id asc,udate asc,id asc')
  125. @staticmethod
  126. def getByGateway(self, search={}):
  127. device = Device.get(self, search=search)
  128. result = {}
  129. if device:
  130. for value in device:
  131. if value['gateway_id'] not in result:
  132. result[value['gateway_id']] = []
  133. result[value['gateway_id']].append(value)
  134. return result
  135. @staticmethod
  136. def data(self):
  137. id, type = Device.init(self)
  138. if not id:
  139. return
  140. method = type + '_data'
  141. if hasattr(Device, method):
  142. func = getattr(Device, method)
  143. data = func(self, id)
  144. else:
  145. self.view('404.html')
  146. return
  147. #self.data = dict(self.data, **data)
  148. @staticmethod
  149. def gateway_data(self, id):
  150. power = []
  151. sensor = []
  152. control = []
  153. self.data['stat'] = {}
  154. self.data['pic'] = []
  155. self.data['camera'] = []
  156. if self.data['device']:
  157. for value in self.data['device']:
  158. if value['type_id'] > 0:
  159. type_info = self.service('common').one('device_type', id=value['type_id'])
  160. value['unit'] = type_info['unit']
  161. value['typeName'] = type_info['name']
  162. # 获取网关状态
  163. if value['hardware_type'] == 5:
  164. power.append(value)
  165. # 获取电源设备
  166. if value['hardware_type'] == 4:
  167. power.append(value)
  168. """
  169. if not self.data['stat']:
  170. self.data['stat'] = value
  171. """
  172. # 获取采集设备
  173. if value['hardware_type'] == 2:
  174. sensor.append(value)
  175. if not self.data['stat']:
  176. self.data['stat'] = value
  177. # 获取控制设备
  178. if value['hardware_type'] == 3:
  179. control.append(value)
  180. # 获取摄像头
  181. if value['hardware_type'] == 6:
  182. value['value'] = value['value'] + '?' + Demeter.date(Demeter.time(), '%Y%m%d%H')
  183. self.data['pic'].append(value)
  184. # 获取摄像机
  185. if value['hardware_type'] == 7:
  186. self.data['camera'].append(value)
  187. """
  188. if power:
  189. power.reverse()
  190. """
  191. self.data['list'] = ({'name': '设备状态', 'device': power}, {'name': '数据采集', 'device': sensor}, {'name': '实时设备控制', 'device': control})
  192. @staticmethod
  193. def page_data(self, id):
  194. self.data['list'] = self.data['group']
  195. @staticmethod
  196. def group(self, search):
  197. self.data['show'] = False
  198. self.data['pic'] = []
  199. self.data['camera'] = []
  200. self.data['stat'] = {}
  201. for key, value in enumerate(self.data['group']):
  202. if value['devices']:
  203. search['id--ins'] = value['devices']
  204. if self.data['device_cur'] == 'stat':
  205. search['hardware_type--ins'].append(6)
  206. self.data['group'][key]['device'] = Device.get(self, search=search)
  207. if self.data['group'][key]['device']:
  208. for k, v in enumerate(self.data['group'][key]['device']):
  209. if v['hardware_type'] == 2 or v['hardware_type'] == 4:
  210. if v['hardware_type'] == 2 and self.data['info']['stat'] == True and not self.data['stat']:
  211. self.data['stat'] = v
  212. self.data['show'] = True
  213. if v['type_id'] > 0:
  214. type_info = self.service('common').one('device_type', id=v['type_id'])
  215. self.data['group'][key]['device'][k]['unit'] = type_info['unit']
  216. self.data['group'][key]['device'][k]['typeName'] = type_info['name']
  217. if self.data['device_cur'] == 'data':
  218. if v['hardware_type'] == 6:
  219. slen = len(self.data['group'][key]['device'])
  220. if slen < 2:
  221. del self.data['group'][key]['device']
  222. v['name'] = self.data['group'][key]['name']
  223. v['value'] = v['value'] + '?' + Demeter.date(Demeter.time(), '%Y%m%d%H')
  224. self.data['pic'].append(v)
  225. if v['hardware_type'] == 7:
  226. slen = len(self.data['group'][key]['device'])
  227. if slen < 2:
  228. del self.data['group'][key]['device']
  229. v['name'] = self.data['group'][key]['name']
  230. self.data['camera'].append(v)
  231. if self.data['device_cur'] == 'stat':
  232. if v['hardware_type'] == 6:
  233. self.data['pic'] = True
  234. else:
  235. self.data['device'].append(v)
  236. else:
  237. self.data['device'].append(v)
  238. @staticmethod
  239. def pic(self):
  240. id, type = Device.init(self, search={'hardware_type':6})
  241. if not id:
  242. return
  243. state = Device.get(self, search={'hardware_type--ins':(2,4)})
  244. if state:
  245. self.data['show'] = True
  246. device = self.input('device')
  247. if not device:
  248. #如果没有,就获取第一个
  249. self.data['deviceInfo'] = self.data['device'][0]
  250. else:
  251. self.data['deviceInfo'] = self.service('common').one('device_info', id=device)
  252. if not self.data['deviceInfo']:
  253. self.view('404.html')
  254. return
  255. self.data['pic'] = self.service('common').list('device_pic', search={'device_id':self.data['deviceInfo']['id']}, page={'num':12}, order='sdate desc')
  256. if self.data['pic']:
  257. for key, value in enumerate(self.data['pic']):
  258. self.data['pic'][key]['cdates'] = Demeter.date(value['sdate'])
  259. @staticmethod
  260. def statBase(self, deviceInfo={}):
  261. device = self.input('device')
  262. method = self.input('method', 'maxmin')
  263. if not device:
  264. #如果没有,就获取sensor的第一个
  265. self.data['deviceInfo'] = deviceInfo
  266. else:
  267. self.data['deviceInfo'] = self.service('common').one('device_info', id=device)
  268. if not self.data['deviceInfo']:
  269. self.view('404.html')
  270. return
  271. self.data['type'] = self.service('common').one('device_type', id=self.data['deviceInfo']['type_id'])
  272. model = Demeter.model('data', 'tsdb')
  273. self.data['group'] = model.dateConfig()
  274. search_group = self.input('group')
  275. search_start = self.input('start')
  276. search_end = self.input('end')
  277. search = {}
  278. search['device'] = self.data['deviceInfo']['id']
  279. if search_group:
  280. search['group'] = search_group
  281. else:
  282. search['group'] = '1'
  283. if search_start:
  284. search['start'] = search_start
  285. if search_end:
  286. search['end'] = search_end
  287. search['type'] = type
  288. search['id'] = id
  289. self.data['search'] = search
  290. self.data['statList'] = model.getData(method, search, self.data['deviceInfo'])
  291. @staticmethod
  292. def stat(self):
  293. id, type = Device.init(self, search={'hardware_type--ins':[2,4]})
  294. if not id:
  295. return
  296. Device.statBase(self, self.data['device'][0])
  297. self.data['url'] = Device.url('type='+type+'&id=' + id)
  298. @staticmethod
  299. def log(self):
  300. id, type = Device.init(self)
  301. if not id:
  302. return
  303. ids = []
  304. device_type = {}
  305. device_hard = {}
  306. device_list = []
  307. for value in self.data['device']:
  308. ids.append(value['id'])
  309. value['cdates'] = Demeter.date(value['udate'], '%Y.%m.%d')
  310. if value['type_id'] > 0:
  311. info = self.service('common').one('device_type', id=value['type_id'])
  312. if info['id'] not in device_type:
  313. device_type[info['id']] = {'name':info['name'], 'num':1, 'cdate':value['cdates']}
  314. else:
  315. num = device_type[info['id']]['num'] + 1
  316. device_type[info['id']] = {'name':info['name'], 'num':num, 'cdate':value['cdates']}
  317. elif '网关' in value['name']:
  318. value['name'] = '通讯网关'
  319. device_list.append({'name':value['name'], 'num':1, 'cdate':value['cdates']})
  320. elif value['hardware_type'] > 0:
  321. info = self.service('common').one('hardware_type', id=value['hardware_type'])
  322. if info['id'] not in device_hard:
  323. device_hard[info['id']] = {'name':info['name'], 'num':1, 'cdate':value['cdates']}
  324. else:
  325. num = device_hard[info['id']]['num'] + 1
  326. device_hard[info['id']] = {'name':info['name'], 'num':num, 'cdate':value['cdates']}
  327. if device_hard:
  328. for key, value in device_hard.items():
  329. device_list.append({'name':value['name'], 'num':value['num'], 'cdate':value['cdate']})
  330. if device_type:
  331. for key, value in device_type.items():
  332. device_list.append({'name':value['name'], 'num':value['num'], 'cdate':value['cdate']})
  333. self.data['list'] = device_list
  334. # 获取设备日志
  335. self.data['logs'] = self.service('common').list('msg', state=True, search={'device_id-input-ins':ids}, page={'num':6})
  336. if self.data['logs']:
  337. for key, value in enumerate(self.data['logs']):
  338. type_info = self.service('common').one('msg_type', id=value['type_id'])
  339. self.data['logs'][key]['type'] = type_info['name']
  340. self.data['logs'][key]['cdates'] = Demeter.date(value['cdate'])
  341. @staticmethod
  342. def url(param):
  343. config = {}
  344. config['data'] = '/device/data?' + param;
  345. config['stat'] = '/device/stat?' + param;
  346. config['log'] = '/device/log?' + param;
  347. config['pic'] = '/device/pic?' + param;
  348. return config
  349. @staticmethod
  350. def setUrl():
  351. config = {}
  352. config['mul'] = '/device/set_mul'
  353. config['timing'] = '/device/set_timing'
  354. config['loop'] = '/device/set_loop'
  355. config['condition'] = '/device/set_condition'
  356. return config