main.py 53 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371
  1. # fastapi
  2. from fastapi import FastAPI, Request, Response, HTTPException, status, Depends , Form
  3. from fastapi import templating
  4. from fastapi.templating import Jinja2Templates
  5. from fastapi.responses import HTMLResponse, RedirectResponse, JSONResponse
  6. from fastapi.middleware.cors import CORSMiddleware
  7. from fastapi.staticfiles import StaticFiles
  8. # fastapi view function parameters
  9. from typing import List, Optional
  10. import json
  11. # path
  12. import sys
  13. from pydantic.errors import ArbitraryTypeError
  14. from sqlalchemy.sql.elements import False_
  15. # time
  16. # import datetime
  17. from datetime import timedelta, datetime
  18. # db
  19. import dataset
  20. from passlib import context
  21. from sqlalchemy.sql.expression import true
  22. import models
  23. from random import randint,uniform
  24. # authorize
  25. from passlib.context import CryptContext
  26. pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto")
  27. import jwt
  28. from fastapi_jwt_auth import AuthJWT
  29. from fastapi_jwt_auth.exceptions import AuthJWTException
  30. from fastapi.security import OAuth2AuthorizationCodeBearer, OAuth2PasswordRequestForm
  31. import numpy as np
  32. import pymysql
  33. class dateEncode(json.JSONEncoder):
  34. def default(self, obj):
  35. if isinstance(obj, datetime):
  36. return obj.strftime('%Y-%m-%d %H:%M:%S')
  37. else:
  38. return json.JSONEncoder.default(self, obj)
  39. pymysql.install_as_MySQLdb()
  40. db_settings = {
  41. "host": "db.ptt.cx",
  42. "port": 3306,
  43. "user": "choozmo",
  44. "password": "pAssw0rd",
  45. "db": "Water_tower",
  46. "charset": "utf8mb4"
  47. }
  48. # app
  49. app = FastAPI()
  50. app.add_middleware(
  51. CORSMiddleware,
  52. allow_origins=["*"],
  53. allow_credentials=True,
  54. allow_methods=["*"],
  55. allow_headers=["*"],
  56. )
  57. SECRET_KEY = "df2f77bd544240801a048bd4293afd8eeb7fff3cb7050e42c791db4b83ebadcd"
  58. ALGORITHM = "HS256"
  59. ACCESS_TOKEN_EXPIRE_MINUTES = 3000
  60. pwd_context = CryptContext(schemes=["bcrypt"], deprecated="auto")
  61. #
  62. app.mount(path='/templates', app=StaticFiles(directory='templates'), name='templates')
  63. app.mount(path='/static', app=StaticFiles(directory='static'), name='static ')
  64. #
  65. templates = Jinja2Templates(directory='templates')
  66. @AuthJWT.load_config
  67. def get_config():
  68. return models.Settings()
  69. # view
  70. @app.get('/', response_class=HTMLResponse)
  71. async def index(request: Request):
  72. print(request)
  73. return templates.TemplateResponse(name='index.html', context={'request': request})
  74. @app.get('/login', response_class=HTMLResponse)
  75. async def login(request: Request):
  76. return templates.TemplateResponse(name='login.html', context={'request': request})
  77. @app.post("/login")
  78. async def login_for_access_token(request: Request, form_data: OAuth2PasswordRequestForm = Depends(), Authorize: AuthJWT = Depends()):
  79. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  80. user = authenticate_user(form_data.username, form_data.password)
  81. if not user:
  82. raise HTTPException(
  83. status_code=status.HTTP_401_UNAUTHORIZED,
  84. detail="Incorrect username or password",
  85. headers={"WWW-Authenticate": "Bearer"},
  86. )
  87. access_token_expires = timedelta(minutes=ACCESS_TOKEN_EXPIRE_MINUTES)
  88. access_token = create_access_token(
  89. data={"sub": user.username}, expires_delta=access_token_expires
  90. )
  91. table = db['users']
  92. user.token = access_token
  93. print(user)
  94. table.update(dict(user), ['username'],['password'])
  95. access_token = Authorize.create_access_token(subject=user.username)
  96. refresh_token = Authorize.create_refresh_token(subject=user.username)
  97. Authorize.set_access_cookies(access_token)
  98. Authorize.set_refresh_cookies(refresh_token)
  99. #return templates.TemplateResponse("home.html", {"request": request, "msg": 'Login'})
  100. return {"access_token": access_token, "token_type": "bearer"} # 回傳token給前端
  101. @app.get('/register', response_class=HTMLResponse)
  102. async def login(request: Request):
  103. return templates.TemplateResponse(name='rigister_test.html', context={'request': request})
  104. @app.post('/register')
  105. async def register(request: Request, form_data: OAuth2PasswordRequestForm = Depends()):
  106. user = models.User(**await request.form())
  107. print(form_data.username, form_data.password, user)
  108. user.id = randint(1000, 9999)
  109. user.isAdmin = 0 #預設為非管理者
  110. user.roleType = 0 #預設為employee
  111. # 密碼加密
  112. #user.password = get_password_hash(user.password)
  113. # 存入DB
  114. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  115. user_table = db['users']
  116. user_table.insert(dict(user))
  117. # 跳轉頁面至登入
  118. return templates.TemplateResponse(name='login.html', context={'request': request})
  119. @app.post('/record_tower')
  120. async def record_tower(request: Request,data : models.record_tower_data,key:str):
  121. #data = models.tower_data(**await request.form())
  122. if key!="21232f297a57a5a743894a0e4a801fc3":
  123. return {'msg':'no access'}
  124. loc_dt = datetime.today()
  125. loc_dt_format = loc_dt.strftime("%Y-%m-%d %H:%M:%S")
  126. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  127. cmd ="SELECT * FROM device"
  128. cmd2={}
  129. check = False
  130. # for row in db.query(cmd):
  131. # if row['id']== tower_id:
  132. # check = True
  133. if check :
  134. result={'msg':"success"}
  135. else:
  136. result = {'msg':"no device"}
  137. return json.dumps(result,ensure_ascii=False)
  138. @app.post('/record_dcs')
  139. async def record_dcs(request: Request,data : models.record_tower_data,key:str):
  140. #data = models.tower_data(**await request.form())
  141. if key!="21232f297a57a5a743894a0e4a801fc3":
  142. return {'msg':'no access'}
  143. loc_dt = datetime.today()
  144. loc_dt_format = loc_dt.strftime("%Y-%m-%d %H:%M:%S")
  145. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  146. cmd ="SELECT * FROM device"
  147. cmd2={}
  148. check = False
  149. if check :
  150. result={'msg':"success"}
  151. else:
  152. result = {'msg':"no device"}
  153. return json.dumps(result,ensure_ascii=False)
  154. @app.post('/record_diagnosis')
  155. async def record_diagnosis(request: Request,data : models.record_diagnosis_data,key:str):
  156. #data = models.tower_data(**await request.form())
  157. if key!="21232f297a57a5a743894a0e4a801fc3":
  158. return {'msg':'no access'}
  159. loc_dt = datetime.today()
  160. loc_dt_format = loc_dt.strftime("%Y-%m-%d %H:%M:%S")
  161. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  162. dict_tmp = data.__dict__
  163. dict_tmp['createTime']=loc_dt_format
  164. result = db['record_diagnosis'].update(dict(dict_tmp),['vibration_id'])
  165. #print(result)
  166. if result :
  167. result={'msg':'success insert'}
  168. else :
  169. result={'msg':'fail to insert'}
  170. return json.dumps(result,ensure_ascii=False)
  171. @app.post('/record_health')
  172. async def record_health(request: Request,data : models.record_health_data,key:str):
  173. #data = models.tower_data(**await request.form())
  174. if key!="21232f297a57a5a743894a0e4a801fc3":
  175. return {'msg':'no access'}
  176. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  177. dict_tmp = data.__dict__
  178. result = db['record_health'].insert(dict(dict_tmp))
  179. #print(result)
  180. if result :
  181. result={'msg':'success insert'}
  182. else :
  183. result={'msg':'fail to insert'}
  184. return json.dumps(result,ensure_ascii=False)
  185. @app.post('/record_performance')
  186. async def record_performance(request: Request,data : models.record_performance_data,key:str):
  187. #data = models.tower_data(**await request.form())
  188. if key!="21232f297a57a5a743894a0e4a801fc3":
  189. return {'msg':'no access'}
  190. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  191. dict_tmp = data.__dict__
  192. result = db['record_performance'].insert(dict(dict_tmp))
  193. #print(result)
  194. if result :
  195. result={'msg':'success insert'}
  196. else :
  197. result={'msg':'fail to insert'}
  198. return json.dumps(result,ensure_ascii=False)
  199. @app.post('/record_prediction')
  200. async def record_prediction(request: Request,data : models.record_prediction_data,key:str):
  201. #data = models.tower_data(**await request.form())
  202. if key!="21232f297a57a5a743894a0e4a801fc3":
  203. return {'msg':'no access'}
  204. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  205. dict_tmp = data.__dict__
  206. result = db['record_prediction'].insert(dict(dict_tmp))
  207. #print(result)
  208. if result :
  209. result={'msg':'success insert'}
  210. else :
  211. result={'msg':'fail to insert'}
  212. return json.dumps(result,ensure_ascii=False)
  213. @app.post('/record_prediction_upd')
  214. async def record_prediction(request: Request,data : models.record_prediction_upd_data,key:str):
  215. #data = models.tower_data(**await request.form())
  216. if key!="21232f297a57a5a743894a0e4a801fc3":
  217. return {'msg':'no access'}
  218. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  219. dict_tmp = data.__dict__
  220. result = db['record_prediction_upd'].insert(dict(dict_tmp))
  221. #print(result)
  222. if result :
  223. result={'msg':'success insert'}
  224. else :
  225. result={'msg':'fail to insert'}
  226. return json.dumps(result,ensure_ascii=False)
  227. @app.get('/add_tower')
  228. async def home(request: Request, Authorize: AuthJWT = Depends()):
  229. return templates.TemplateResponse(name='add_tower.html', context={'request': request})
  230. @app.post('/add_tower')
  231. async def home(request: Request, Authorize: AuthJWT = Depends()):
  232. data=request.form()
  233. print(data.device)
  234. @app.get('/home', response_class=HTMLResponse)
  235. async def home(request: Request, Authorize: AuthJWT = Depends()):
  236. try:
  237. Authorize.jwt_required()
  238. except Exception as e:
  239. print(e)
  240. return RedirectResponse('/login')
  241. #add_data()
  242. return templates.TemplateResponse(name='home.html', context={'request': request})
  243. @app.get('/home/show', response_class=HTMLResponse)
  244. async def home(request: Request, Authorize: AuthJWT = Depends()):
  245. try:
  246. Authorize.jwt_required()
  247. except Exception as e:
  248. print(e)
  249. return RedirectResponse('/login')
  250. current_user = Authorize.get_jwt_subject()
  251. result = [{'user_role':check_role_type(current_user)}]
  252. result.append(check_tower_health(current_user))
  253. #print(result)
  254. return json.dumps(result,ensure_ascii=False)
  255. @app.get('/org', response_class=HTMLResponse)
  256. async def tower(request: Request, Authorize: AuthJWT = Depends()):
  257. try:
  258. Authorize.jwt_required()
  259. except Exception as e:
  260. print(e)
  261. return RedirectResponse('/login')
  262. current_user = Authorize.get_jwt_subject()
  263. result = get_user_under_organization(current_user)
  264. return json.dumps(result,ensure_ascii=False)
  265. @app.get('/user_role', response_class=HTMLResponse)
  266. async def user_role(request: Request, Authorize: AuthJWT = Depends()):
  267. try:
  268. Authorize.jwt_required()
  269. except Exception as e:
  270. print(e)
  271. return RedirectResponse('/login')
  272. current_user = Authorize.get_jwt_subject()
  273. result = {'role':check_role_type(current_user)}
  274. print(result)
  275. return json.dumps(result,ensure_ascii=False)
  276. @app.get('/tower', response_class=HTMLResponse)
  277. async def tower(request: Request, Authorize: AuthJWT = Depends()):
  278. try:
  279. Authorize.jwt_required()
  280. except Exception as e:
  281. print(e)
  282. return RedirectResponse('/login')
  283. current_user = Authorize.get_jwt_subject()
  284. result = get_user_under_organization(current_user)
  285. result.append({'Data' : get_tower_info('dev001')})
  286. return templates.TemplateResponse(name='tower.html', context={"request":request})
  287. @app.get('/tower/org', response_class=HTMLResponse)
  288. async def tower(request: Request, Authorize: AuthJWT = Depends()):
  289. try:
  290. Authorize.jwt_required()
  291. except Exception as e:
  292. print(e)
  293. return RedirectResponse('/login')
  294. current_user = Authorize.get_jwt_subject()
  295. result = get_user_under_organization(current_user)
  296. return json.dumps(result,ensure_ascii=False)
  297. @app.get('/tower/', response_class=HTMLResponse)
  298. async def tower(request: Request,company:str,factory:str,department:str,towerGroup:str, Authorize: AuthJWT = Depends()):
  299. try:
  300. Authorize.jwt_required()
  301. except Exception as e:
  302. print(e)
  303. return RedirectResponse('/login')
  304. #current_user = Authorize.get_jwt_subject()
  305. tower_arr = get_tower(company,factory,department,towerGroup)
  306. result = []
  307. for tower in tower_arr:
  308. result.append({'tower_name': tower,'tower_data': get_tower_info(tower)})
  309. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  310. @app.get('/tower/performance/{tower_id}', response_class=HTMLResponse)
  311. async def member_authority(request:Request,tower_id: str,Authorize: AuthJWT = Depends()):
  312. """設定成員權限"""
  313. try:
  314. Authorize.jwt_required()
  315. except Exception as e:
  316. print(e)
  317. return RedirectResponse('/login')
  318. result = get_tower_perform(tower_id)
  319. #print(result)
  320. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  321. @app.get('/optim', response_class=HTMLResponse)
  322. async def optim(request: Request, Authorize: AuthJWT = Depends()):
  323. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  324. statement = 'SELECT value FROM record_tower WHERE record_tower.key = "hotTemp"'
  325. x = 0
  326. y = 0
  327. z = 0
  328. count = 0
  329. waterflow = 0
  330. fannum = 0
  331. savewater = 0
  332. fanchange = 0
  333. saveelec = 0
  334. total = 0
  335. flowchange = 0
  336. try:
  337. Authorize.jwt_required()
  338. except Exception as e:
  339. print(e)
  340. return RedirectResponse('/login')
  341. current_user = Authorize.get_jwt_subject()
  342. print(check_role_type(current_user))
  343. role = int(check_role_type(current_user))
  344. print(check_role_type(current_user))
  345. if role == 1:
  346. statement = 'SELECT value FROM record_tower WHERE record_tower.key = "hotTemp"'
  347. for temp in db.query(statement):
  348. print(temp['value'])
  349. x=temp['value']
  350. statement2 = 'SELECT value FROM record_tower WHERE record_tower.key = "coldTempData1"'
  351. for temp2 in db.query(statement2):
  352. print(temp2['value'])
  353. y=temp2['value']
  354. statement3 = 'SELECT value FROM record_tower WHERE record_tower.key = "wetTemp"'
  355. for temp3 in db.query(statement3):
  356. print(temp3['value'])
  357. z=temp3['value']
  358. statement4 = 'SELECT value FROM record_tower WHERE record_tower.key = "count"'
  359. for tower in db.query(statement4):
  360. print(tower['value'])
  361. count=tower['value']
  362. statement5 = 'SELECT value FROM record_tower WHERE record_tower.key = "waterflow"'
  363. for tower in db.query(statement5):
  364. waterflow=tower['value']
  365. statement6 = 'SELECT value FROM record_tower WHERE record_tower.key = "fannum"'
  366. for tower in db.query(statement6):
  367. fannum=tower['value']
  368. statement7 = 'SELECT value FROM record_tower WHERE record_tower.key = "flowchange"'
  369. for tower in db.query(statement7):
  370. flowchange=tower['value']
  371. statement8 = 'SELECT value FROM record_tower WHERE record_tower.key = "savewater"'
  372. for tower in db.query(statement8):
  373. savewater=tower['value']
  374. statement9 = 'SELECT value FROM record_tower WHERE record_tower.key = "fanchange"'
  375. for tower in db.query(statement9):
  376. fanchange=tower['value']
  377. statement10 = 'SELECT value FROM record_tower WHERE record_tower.key = "saveelec"'
  378. for tower in db.query(statement10):
  379. saveelec=tower['value']
  380. statement11 = 'SELECT value FROM record_tower WHERE record_tower.key = "total"'
  381. for tower in db.query(statement11):
  382. total=tower['value']
  383. elif role == 3 :
  384. statement = 'SELECT value FROM record_tower WHERE record_tower.key = "hotTemp1"'
  385. for temp in db.query(statement):
  386. print(temp['value'])
  387. x=temp['value']
  388. statement2 = 'SELECT value FROM record_tower WHERE record_tower.key = "coldTempData2"'
  389. for temp2 in db.query(statement2):
  390. print(temp2['value'])
  391. y=temp2['value']
  392. statement3 = 'SELECT value FROM record_tower WHERE record_tower.key = "wetTemp1"'
  393. for temp3 in db.query(statement3):
  394. print(temp3['value'])
  395. z=temp3['value']
  396. statement4 = 'SELECT value FROM record_tower WHERE record_tower.key = "count1"'
  397. for tower in db.query(statement4):
  398. print(tower['value'])
  399. count=tower['value']
  400. statement5 = 'SELECT value FROM record_tower WHERE record_tower.key = "waterflow1"'
  401. for tower in db.query(statement5):
  402. waterflow=tower['value']
  403. statement6 = 'SELECT value FROM record_tower WHERE record_tower.key = "fannum1"'
  404. for tower in db.query(statement6):
  405. fannum=tower['value']
  406. statement7 = 'SELECT value FROM record_tower WHERE record_tower.key = "flowchange1"'
  407. for tower in db.query(statement7):
  408. flowchange=tower['value']
  409. statement8 = 'SELECT value FROM record_tower WHERE record_tower.key = "savewater1"'
  410. for tower in db.query(statement8):
  411. savewater=tower['value']
  412. statement9 = 'SELECT value FROM record_tower WHERE record_tower.key = "fanchange1"'
  413. for tower in db.query(statement9):
  414. fanchange=tower['value']
  415. statement10 = 'SELECT value FROM record_tower WHERE record_tower.key = "saveelec1"'
  416. for tower in db.query(statement10):
  417. saveelec=tower['value']
  418. statement11 = 'SELECT value FROM record_tower WHERE record_tower.key = "total1"'
  419. for tower in db.query(statement11):
  420. total=tower['value']
  421. elif role == 4 :
  422. statement = 'SELECT value FROM record_tower WHERE record_tower.key = "hotTemp2"'
  423. for temp in db.query(statement):
  424. print(temp['value'])
  425. x=temp['value']
  426. statement2 = 'SELECT value FROM record_tower WHERE record_tower.key = "coldTempData3"'
  427. for temp2 in db.query(statement2):
  428. print(temp2['value'])
  429. y=temp2['value']
  430. statement3 = 'SELECT value FROM record_tower WHERE record_tower.key = "wetTemp2"'
  431. for temp3 in db.query(statement3):
  432. print(temp3['value'])
  433. z=temp3['value']
  434. statement4 = 'SELECT value FROM record_tower WHERE record_tower.key = "count2"'
  435. for tower in db.query(statement4):
  436. print(tower['value'])
  437. count=tower['value']
  438. statement5 = 'SELECT value FROM record_tower WHERE record_tower.key = "waterflow2"'
  439. for tower in db.query(statement5):
  440. waterflow=tower['value']
  441. statement6 = 'SELECT value FROM record_tower WHERE record_tower.key = "fannum2"'
  442. for tower in db.query(statement6):
  443. fannum=tower['value']
  444. statement7 = 'SELECT value FROM record_tower WHERE record_tower.key = "flowchange2"'
  445. for tower in db.query(statement7):
  446. flowchange=tower['value']
  447. statement8 = 'SELECT value FROM record_tower WHERE record_tower.key = "savewater2"'
  448. for tower in db.query(statement8):
  449. savewater=tower['value']
  450. statement9 = 'SELECT value FROM record_tower WHERE record_tower.key = "fanchange2"'
  451. for tower in db.query(statement9):
  452. fanchange=tower['value']
  453. statement10 = 'SELECT value FROM record_tower WHERE record_tower.key = "saveelec2"'
  454. for tower in db.query(statement10):
  455. saveelec=tower['value']
  456. statement11 = 'SELECT value FROM record_tower WHERE record_tower.key = "total2"'
  457. for tower in db.query(statement11):
  458. total=tower['value']
  459. else :
  460. print("noright")
  461. return templates.TemplateResponse(name='optim.html',context=
  462. {
  463. 'request': request,"x":x,"y":y,"z":z,"count":count,"waterflow":waterflow
  464. ,"fannum":fannum , "flowchange":flowchange , "savewater":savewater
  465. , "fanchange":fanchange , "saveelec":saveelec , "total":total
  466. })
  467. @app.get('/vibration', response_class=HTMLResponse)
  468. async def vibration(request: Request, Authorize: AuthJWT = Depends()):
  469. try:
  470. Authorize.jwt_required()
  471. except Exception as e:
  472. print(e)
  473. return RedirectResponse('/login')
  474. return templates.TemplateResponse(name='vibration_test.html', context={'request': request})
  475. @app.get('/channel', response_class=HTMLResponse)
  476. async def vibration(request: Request, Authorize: AuthJWT = Depends()):
  477. try:
  478. Authorize.jwt_required()
  479. except Exception as e:
  480. print(e)
  481. return RedirectResponse('/login')
  482. return templates.TemplateResponse(name='channel.html', context={'request': request})
  483. @app.get('/channel/{tower_id}/{channel_id}', response_class=HTMLResponse)
  484. async def vibration(request: Request,tower_id:str,channel_id:str,Authorize: AuthJWT = Depends()):
  485. try:
  486. Authorize.jwt_required()
  487. except Exception as e:
  488. print(e)
  489. return RedirectResponse('/login')
  490. print(find_vibration_id(tower_id,channel_id))
  491. result = get_channel_info(find_vibration_id(tower_id,channel_id))
  492. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  493. @app.get('/channel_chart/{tower_id}/{channel_id}', response_class=HTMLResponse)
  494. async def vibration(request: Request,tower_id:str,channel_id:str,Authorize: AuthJWT = Depends()):
  495. try:
  496. Authorize.jwt_required()
  497. except Exception as e:
  498. print(e)
  499. return RedirectResponse('/login')
  500. print(find_vibration_id(tower_id,channel_id))
  501. result = get_channel_health(find_vibration_id(tower_id,channel_id))
  502. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  503. @app.get('/channel_predict/{tower_id}/{channel_id}', response_class=HTMLResponse)
  504. async def vibration(request: Request,tower_id:str,channel_id:str,Authorize: AuthJWT = Depends()):
  505. try:
  506. Authorize.jwt_required()
  507. except Exception as e:
  508. print(e)
  509. return RedirectResponse('/login')
  510. #print(find_vibration_id(tower_id,channel_id))
  511. result = get_predect_data(find_vibration_id(tower_id,channel_id))
  512. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  513. @app.get('/channel_frequency/{tower_id}/{channel_id}', response_class=HTMLResponse)
  514. async def vibration(request: Request,tower_id:str,channel_id:str,Authorize: AuthJWT = Depends()):
  515. try:
  516. Authorize.jwt_required()
  517. except Exception as e:
  518. print(e)
  519. return RedirectResponse('/login')
  520. #print(find_vibration_id(tower_id,channel_id))
  521. result = get_frequency(find_vibration_id(tower_id,channel_id))
  522. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  523. @app.get('/history', response_class=HTMLResponse)
  524. async def history(request: Request, Authorize: AuthJWT = Depends()):
  525. try:
  526. Authorize.jwt_required()
  527. except Exception as e:
  528. print(e)
  529. return RedirectResponse('/login')
  530. # current_user = Authorize.get_jwt_subject()
  531. return templates.TemplateResponse(name='history.html', context={'request': request})
  532. @app.get('/history/', response_class=HTMLResponse)
  533. async def history(request: Request,company:str,factory:str,department:str,towerGroup:str, Authorize: AuthJWT = Depends()):
  534. try:
  535. Authorize.jwt_required()
  536. except Exception as e:
  537. print(e)
  538. return RedirectResponse('/login')
  539. #current_user = Authorize.get_jwt_subject()
  540. tower_arr = get_tower(company,factory,department,towerGroup)
  541. result = []
  542. for tower in tower_arr:
  543. tmp_arr = get_vibration_info(tower)
  544. for arr in tmp_arr:
  545. result.append(arr)
  546. return json.dumps(result,ensure_ascii=False, cls = dateEncode)
  547. @app.get('/device', response_class=HTMLResponse)
  548. async def device(request: Request, Authorize: AuthJWT = Depends()):
  549. try:
  550. Authorize.jwt_required()
  551. except Exception as e:
  552. print(e)
  553. return RedirectResponse('/login')
  554. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  555. statement = 'SELECT * FROM device '
  556. a = []
  557. print("start")
  558. for row in db.query(statement):
  559. print(row['id'],row['deviceName'],row['hostIP'],row['CompanyCode'],row['FactoryCode'],row['DepartmentCode'])
  560. a.append((row['id'],row['deviceName'],row['hostIP'],row['CompanyCode'],row['FactoryCode'],row['DepartmentCode']))
  561. print(a)
  562. print("over3")
  563. #result = json.dumps(b,ensure_ascii=False)
  564. # current_user = Authorize.get_jwt_subject()
  565. return templates.TemplateResponse(name='device.html', context={'request': request,'a':a})
  566. @app.get('/system', response_class=HTMLResponse)
  567. async def system(request: Request, Authorize: AuthJWT = Depends()):
  568. try:
  569. Authorize.jwt_required()
  570. except Exception as e:
  571. print(e)
  572. return RedirectResponse('/login')
  573. # current_user = Authorize.get_jwt_subject()
  574. return templates.TemplateResponse(name='system.html', context={'request': request})
  575. @app.get('/member', response_class=HTMLResponse)
  576. async def get_member(request: Request, Authorize: AuthJWT = Depends()):
  577. """獲取所有帳號資訊"""
  578. try:
  579. Authorize.jwt_required()
  580. except Exception as e:
  581. print(e)
  582. return RedirectResponse('/login')
  583. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  584. statement = 'SELECT id,username,isAdmin FROM users'
  585. json_dic = []
  586. for row in db.query(statement):
  587. #print(row['id'],row['username'])
  588. json_dic.append({'username':row['username'],'isAdmin':row['isAdmin'],'roleType':check_role_type(row['username']),'role_name' :get_role_name(check_role_type(row['username']))})
  589. result = json.dumps(json_dic,ensure_ascii=False)
  590. return result
  591. @app.get('/member/edit/', response_class=HTMLResponse)
  592. async def login(request: Request, name:str,isAdmin:int,isEnable:int ,Authorize: AuthJWT = Depends()):
  593. try:
  594. Authorize.jwt_required()
  595. except Exception as e:
  596. print(e)
  597. return RedirectResponse('/login')
  598. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  599. current_user = Authorize.get_jwt_subject()
  600. current_user_roleType = check_role_type(current_user)
  601. del_user_roleType = check_role_type(name)
  602. statement = 'SELECT isAdmin FROM users WHERE userName = "'+current_user+'"'
  603. for row in db.query(statement):
  604. if row['isAdmin']!=1:
  605. return json.dumps([{'msg':'你沒有權限'}],ensure_ascii=False)
  606. if del_user_roleType == None:
  607. return json.dumps([{'msg':'不存在使用者'}],ensure_ascii=False)
  608. elif current_user_roleType>del_user_roleType or current_user_roleType==del_user_roleType:
  609. return json.dumps([{'msg':'你沒有權限'}],ensure_ascii=False)
  610. user_dic = get_user(name)
  611. print(user_dic)
  612. user_dic.isAdmin = isAdmin
  613. user_dic.isEnable = isEnable
  614. table = db['users']
  615. table.update(dict(user_dic), ['username'])
  616. return json.dumps([{'msg':"成功更改"}],ensure_ascii=False)
  617. @app.get('/member_delete', response_class=HTMLResponse)
  618. async def login(request: Request, Authorize: AuthJWT = Depends()):
  619. try:
  620. Authorize.jwt_required()
  621. except Exception as e:
  622. print(e)
  623. return RedirectResponse('/login')
  624. return templates.TemplateResponse(name='delete_member_test2.html', context={'request': request})
  625. @app.post('/member_delete')
  626. async def delete_member(request: Request):
  627. """刪除成員"""
  628. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  629. del_user = models.del_user(**await request.form())
  630. delete_name = del_user.del_name
  631. statement = 'SELECT * FROM users'
  632. current_user = ''
  633. for row in db.query(statement):
  634. if row['token'] != None :
  635. if compare_jwt_token(row['token'],del_user.access_token):
  636. current_user = row['username']
  637. if current_user == '':
  638. return {'msg':'尚未登入'}
  639. statement = 'SELECT isAdmin FROM users WHERE userName = "'+current_user+'"'
  640. for row in db.query(statement):
  641. if row['isAdmin']!=1:
  642. return {'msg': ' 你沒有權限'}
  643. current_user_roleType = check_role_type(current_user)
  644. del_user_roleType = check_role_type(delete_name)
  645. if del_user_roleType == None:
  646. return {'msg':'不存在使用者'}
  647. elif current_user_roleType>del_user_roleType or current_user_roleType==del_user_roleType:
  648. return {'msg': ' 你沒有權限'}
  649. else :
  650. table = db['users']
  651. table.delete(username=delete_name)
  652. return {'msg': ' 成功刪除'}
  653. @app.get('/member_authority/{edit_one}', response_class=HTMLResponse)
  654. async def member_authority(request:Request,edit_one: int,Authorize: AuthJWT = Depends()):
  655. """設定成員權限"""
  656. try:
  657. Authorize.jwt_required()
  658. except Exception as e:
  659. print(e)
  660. return RedirectResponse('/login')
  661. context = {'request': request}
  662. current_user = Authorize.get_jwt_subject()
  663. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  664. statement = check_isAdmin(current_user)
  665. if statement == "no user":
  666. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':'no user' })
  667. elif statement == 0:
  668. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':"沒有權限" })
  669. current_user_roleType = check_role_type(current_user)
  670. if edit_one == None:
  671. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':'no role' })
  672. elif int(current_user_roleType)>int(edit_one) or int(current_user_roleType)==int(edit_one):
  673. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':"沒有權限" })
  674. result = check_role_acl(edit_one)
  675. if result == []:
  676. cmd = 'SELECT id FROM module'
  677. for row in db.query(cmd):
  678. dic_tmp = {'id':0,'isView':0,'isAdd':0 ,'isEdit':0,'isDel':0,'role_id' : edit_one}
  679. context[get_modul_name(row['id']) ] = dic_tmp
  680. else:
  681. for dic in result:
  682. modul_name = get_modul_name(dic['module_id'])
  683. del dic['module_id']
  684. context[modul_name ] = dic
  685. return templates.TemplateResponse(name='member_authority_test.html', context=context)
  686. @app.post('/member_authority')
  687. async def member_authority(request: Request):
  688. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  689. edit_one = models.user_authority(**await request.form())
  690. statement = 'SELECT * FROM users'
  691. current_user = ''
  692. for row in db.query(statement):
  693. if row['token'] != None :
  694. if compare_jwt_token(row['token'],edit_one.access_token):
  695. current_user = row['username']
  696. if current_user == '':
  697. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':'尚未登入'})
  698. statement = check_isAdmin(current_user)
  699. if statement == "no user":
  700. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':statement })
  701. elif statement == 0:
  702. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg':'你沒有權限' })
  703. current_user_roleType = check_role_type(current_user)
  704. edit_one_roleType = edit_one.role_id
  705. if current_user_roleType>edit_one_roleType or current_user_roleType==edit_one_roleType:
  706. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg': ' 你沒有權限'})
  707. else :
  708. row = ['ai_prediction' ,'channel' ,'device', 'event', 'index' ,'performance', 'record', 'setting_device' ,'setting_system','tower']
  709. if check_role_acl(edit_one.role_id) == []:
  710. for module in row :
  711. new_dict = edit_one.get_acl_from_module_name(module)
  712. new_dict["id"]= None
  713. table = db['role_acl']
  714. table.insert(new_dict)
  715. else:
  716. for module in row :
  717. new_dict = edit_one.get_acl_from_module_name(module)
  718. table = db['role_acl']
  719. table.update(new_dict, ['id'])
  720. return templates.TemplateResponse(name='notice.html', context={"request":request,'msg': '成功更改權限'})
  721. # 溫度API
  722. @app.get('/temperature')
  723. async def get_temperatures():
  724. """ 撈DB溫度 """
  725. return {'hot_water': 30.48, 'cold_water': 28.10, 'wet_ball': 25.14}
  726. @app.post("/example")
  727. async def example(request: Request,Authorize: AuthJWT = Depends()):
  728. try:
  729. Authorize.jwt_required()
  730. except Exception as e:
  731. print(e)
  732. current_user = Authorize.get_jwt_subject()
  733. #form_data = await request.form()
  734. print( current_user)
  735. return current_user
  736. @app.post('/user')
  737. def user(Authorize: AuthJWT = Depends()):
  738. Authorize.jwt_required()
  739. current_user = Authorize.get_jwt_subject()
  740. return {"user": current_user}
  741. @app.get("/add_data", response_class=HTMLResponse)
  742. async def example(request: Request,Authorize: AuthJWT = Depends()):
  743. try:
  744. Authorize.jwt_required()
  745. except Exception as e:
  746. print(e)
  747. return RedirectResponse('/login')
  748. add_data()
  749. return templates.TemplateResponse(name='test.html', context={'request': request})
  750. @app.get('/health')
  751. async def get_health(date: str):
  752. """ 撈健康指標、預設健康指標 """
  753. date = str(datetime.strptime(date, "%Y-%m-%d"))[:10]
  754. print(date)
  755. print(str(datetime.today()))
  756. print(str(datetime.today()-timedelta(days=1)))
  757. fake_data = {
  758. str(datetime.today())[:10]: {'curr_health': 0.7, 'pred_health': 0.8},
  759. str(datetime.today()-timedelta(days=1))[:10]: {'curr_health': 0.6, 'pred_health': 0.7},
  760. }
  761. return fake_data[date]
  762. @app.get('/history_data')
  763. async def get_history(time_end: str):
  764. """ 透過終點時間,抓取歷史資料。 """
  765. date = str(datetime.strptime(time_end, "%Y-%m-%d"))[:10]
  766. print(date)
  767. print(str(datetime.today()))
  768. print(str(datetime.today()-timedelta(days=1)))
  769. fake_data = {
  770. str(datetime.today())[:10]: {
  771. 'curr_history': {
  772. 'RPM_1X': list(np.random.rand(13)),
  773. 'RPM_2X': list(np.random.rand(13)),
  774. 'RPM_3X': list(np.random.rand(13)),
  775. 'RPM_4X': list(np.random.rand(13)),
  776. 'RPM_5X': list(np.random.rand(13)),
  777. 'RPM_6X': list(np.random.rand(13)),
  778. 'RPM_7X': list(np.random.rand(13)),
  779. 'RPM_8X': list(np.random.rand(13)),
  780. 'Gear_1X': list(np.random.rand(13)),
  781. 'Gear_2X': list(np.random.rand(13)),
  782. 'Gear_3X': list(np.random.rand(13)),
  783. 'Gear_4X': list(np.random.rand(13)),
  784. },
  785. 'past_history': {
  786. 'RPM_1X': list(np.random.rand(13)),
  787. 'RPM_2X': list(np.random.rand(13)),
  788. 'RPM_3X': list(np.random.rand(13)),
  789. 'RPM_4X': list(np.random.rand(13)),
  790. 'RPM_5X': list(np.random.rand(13)),
  791. 'RPM_6X': list(np.random.rand(13)),
  792. 'RPM_7X': list(np.random.rand(13)),
  793. 'RPM_8X': list(np.random.rand(13)),
  794. 'Gear_1X': list(np.random.rand(13)),
  795. 'Gear_2X': list(np.random.rand(13)),
  796. 'Gear_3X': list(np.random.rand(13)),
  797. 'Gear_4X': list(np.random.rand(13)),
  798. }
  799. },
  800. str(datetime.today()-timedelta(days=1))[:10]: {
  801. 'curr_history': {
  802. 'RPM_1X': list(np.random.rand(13)),
  803. 'RPM_2X': list(np.random.rand(13)),
  804. 'RPM_3X': list(np.random.rand(13)),
  805. 'RPM_4X': list(np.random.rand(13)),
  806. 'RPM_5X': list(np.random.rand(13)),
  807. 'RPM_6X': list(np.random.rand(13)),
  808. 'RPM_7X': list(np.random.rand(13)),
  809. 'RPM_8X': list(np.random.rand(13)),
  810. 'Gear_1X': list(np.random.rand(13)),
  811. 'Gear_2X': list(np.random.rand(13)),
  812. 'Gear_3X': list(np.random.rand(13)),
  813. 'Gear_4X': list(np.random.rand(13)),
  814. },
  815. 'past_history': {
  816. 'RPM_1X': list(np.random.rand(13)),
  817. 'RPM_2X': list(np.random.rand(13)),
  818. 'RPM_3X': list(np.random.rand(13)),
  819. 'RPM_4X': list(np.random.rand(13)),
  820. 'RPM_5X': list(np.random.rand(13)),
  821. 'RPM_6X': list(np.random.rand(13)),
  822. 'RPM_7X': list(np.random.rand(13)),
  823. 'RPM_8X': list(np.random.rand(13)),
  824. 'Gear_1X': list(np.random.rand(13)),
  825. 'Gear_2X': list(np.random.rand(13)),
  826. 'Gear_3X': list(np.random.rand(13)),
  827. 'Gear_4X': list(np.random.rand(13)),
  828. }
  829. },
  830. }
  831. return fake_data[date]
  832. # Login funtion part
  833. def check_user_exists(username):
  834. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  835. if int(next(iter(db.query('SELECT COUNT(*) FROM Water_tower.users WHERE userName = "'+username+'"')))['COUNT(*)']) > 0:
  836. return True
  837. else:
  838. return False
  839. def get_user(username: str):
  840. """ 取得使用者資訊(Model) """
  841. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  842. if not check_user_exists(username): # if user don't exist
  843. return False
  844. user_dict = next(
  845. iter(db.query('SELECT * FROM Water_tower.users where userName ="'+username+'"')))
  846. user = models.User(**user_dict)
  847. return user
  848. def user_register(user):
  849. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  850. table = db['users']
  851. #user.password = get_password_hash(user.password)
  852. table.insert(dict(user))
  853. def get_password_hash(password):
  854. """ 加密密碼 """
  855. return pwd_context.hash(password)
  856. def verify_password(plain_password, hashed_password):
  857. """ 驗證密碼(hashed) """
  858. return pwd_context.verify(plain_password, hashed_password)
  859. def authenticate_user(username: str, password: str):
  860. """ 連線DB,讀取使用者是否存在。 """
  861. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  862. if not check_user_exists(username): # if user don't exist
  863. return False
  864. if not check_user_isEnable(username):
  865. return False
  866. user_dict = next(iter(db.query('SELECT * FROM Water_tower.users where userName ="'+username+'"')))
  867. user = models.User(**user_dict)
  868. #if not verify_password(password, user.password):
  869. #return False
  870. return user
  871. def create_access_token(data: dict, expires_delta: Optional[timedelta] = None):
  872. """ 創建token,並設定過期時間。 """
  873. to_encode = data.copy()
  874. if expires_delta:
  875. expire = datetime.utcnow() + expires_delta
  876. else:
  877. expire = datetime.utcnow() + timedelta(minutes=15)
  878. to_encode.update({"exp": expire})
  879. encoded_jwt = jwt.encode(to_encode, SECRET_KEY, algorithm=ALGORITHM)
  880. return encoded_jwt
  881. def compare_jwt_token(access_token: str, token: str):
  882. """比對jwt token"""
  883. if len(access_token) < len(token):
  884. if access_token in token:
  885. return True
  886. else :
  887. return False
  888. elif len(access_token) > len(token):
  889. if token in access_token:
  890. return True
  891. else :
  892. return False
  893. else :
  894. if token == access_token:
  895. return True
  896. else :
  897. return False
  898. def check_isAdmin(user_name:str):
  899. """查看是否為管理員"""
  900. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  901. isAdmin = None
  902. cmd = 'SELECT isAdmin FROM users WHERE userName = "'+user_name+'"'
  903. for row in db.query(cmd) :
  904. isAdmin = row['isAdmin']
  905. if isAdmin== None:
  906. return "no user"
  907. return isAdmin
  908. def check_role_type(user_name:str)->int:
  909. """查看使用者權限"""
  910. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  911. cmd = 'SELECT user_role.role_id FROM `users` JOIN `user_role` ON `users`.id = `user_role`.user_id where `users`.username = "'+user_name+'"'
  912. role_type = None
  913. for row in db.query(cmd) :
  914. role_type = row['role_id']
  915. return role_type
  916. def check_role_acl(role:int):
  917. """查看權限"""
  918. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  919. cmd = 'SELECT * FROM role_acl where role_id = '+str(role)
  920. result = []
  921. for row in db.query(cmd) :
  922. dic ={}
  923. for col_name in db['role_acl'].columns:
  924. dic[col_name] = row[col_name]
  925. if dic != {}:
  926. result.append(dic)
  927. return result
  928. def get_role_name(role_id:int):
  929. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  930. cmd = 'SELECT * FROM role where id = '+str(role_id)
  931. role:str
  932. for row in db.query(cmd) :
  933. role = row['name']
  934. return role
  935. def check_user_isEnable(user_name:str)->bool:
  936. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  937. cmd = 'SELECT isEnable FROM users where username = "'+str(user_name)+'"'
  938. able:bool
  939. for row in db.query(cmd) :
  940. able = row['isEnable']
  941. return able
  942. def get_user_under_organization(user_name:str):
  943. """查看所屬公司"""
  944. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  945. user_role = check_role_type(user_name)
  946. print(user_name,user_role)
  947. cmd = 'SELECT * FROM organization'
  948. result = []
  949. if int(user_role) == 1 :
  950. for row in db.query(cmd) :
  951. company = row['Company']
  952. factory = row['Factory']
  953. department = row['Department']
  954. cmd2 = 'SELECT TowerGroupCode FROM device WHERE CompanyCode = "' + company + '" AND FactoryCode = "' + factory + '" AND DepartmentCode = "' + department + '"'
  955. group = []
  956. for row2 in db.query(cmd2):
  957. if row2['TowerGroupCode'] not in group :
  958. group.append(row2['TowerGroupCode'])
  959. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':1})
  960. elif int(user_role) == 2:
  961. cmd2 = 'SELECT company FROM user WHERE user.username ="'+user_name +'"'
  962. company_able:str
  963. for row in db.query(cmd2) :
  964. company_able = row['company']
  965. for row in db.query(cmd) :
  966. company = row['Company']
  967. factory = row['Factory']
  968. department = row['Department']
  969. cmd3 = 'SELECT TowerGroupCode FROM device WHERE CompanyCode = "' + company + '" AND FactoryCode = "' + factory + '" AND DepartmentCode = "' + department + '"'
  970. group = []
  971. for row2 in db.query(cmd3):
  972. if row2['TowerGroupCode'] not in group :
  973. group.append(row2['TowerGroupCode'])
  974. if company == company_able:
  975. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':1})
  976. else:
  977. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':0})
  978. elif int(user_role) == 3:
  979. cmd2 = 'SELECT company,factory FROM users WHERE users.username = "'+user_name +'"'
  980. company_able:str
  981. factory_able:str
  982. num = 0
  983. for row in db.query(cmd2) :
  984. company_able = row['company']
  985. factory_able = row['factory']
  986. for row in db.query(cmd) :
  987. company = row['Company']
  988. factory = row['Factory']
  989. department = row['Department']
  990. cmd3 = 'SELECT TowerGroupCode FROM device WHERE CompanyCode = "' + company + '" AND FactoryCode = "' + factory + '" AND DepartmentCode = "' + department + '"'
  991. group = []
  992. for row2 in db.query(cmd3):
  993. if row2['TowerGroupCode'] not in group :
  994. group.append(row2['TowerGroupCode'])
  995. if company == company_able and factory==factory_able:
  996. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':1})
  997. else:
  998. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':0})
  999. elif int(user_role) == 4:
  1000. cmd2 = 'SELECT company,factory,department FROM users WHERE username = "'+user_name +'"'
  1001. company_able:str
  1002. factory_able:str
  1003. department_able:str
  1004. for row in db.query(cmd2) :
  1005. company_able = row['company']
  1006. factory_able = row['factory']
  1007. department_able = row['department']
  1008. for row in db.query(cmd) :
  1009. company = row['Company']
  1010. factory = row['Factory']
  1011. department = row['Department']
  1012. cmd3 = 'SELECT TowerGroupCode FROM device WHERE CompanyCode = "' + company + '" AND FactoryCode = "' + factory + '" AND DepartmentCode = "' + department + '"'
  1013. group = []
  1014. for row2 in db.query(cmd3):
  1015. if row2['TowerGroupCode'] not in group :
  1016. group.append(row2['TowerGroupCode'])
  1017. if company == company_able and factory==factory_able and department==department_able:
  1018. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':1})
  1019. else:
  1020. result.append({'company':company,'factory':factory,'department':department,'group':group,'able':0})
  1021. else :
  1022. result =[ {'msg':"error"}]
  1023. return result
  1024. def get_user_id(user_name:str):
  1025. """獲取user id"""
  1026. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1027. cmd = 'SELECT id FROM `users` where username = "'+user_name+'"'
  1028. id = None
  1029. for row in db.query(cmd) :
  1030. id = row['id']
  1031. return id
  1032. def get_user_name(user_id:int):
  1033. """獲取user name"""
  1034. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1035. cmd = 'SELECT username FROM `users` where id = "'+user_id+'"'
  1036. id = None
  1037. for row in db.query(cmd) :
  1038. id = row['username']
  1039. return id
  1040. def get_modul_name(modul_id:str):
  1041. """獲取modul名稱"""
  1042. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1043. cmd = 'SELECT moduleName FROM `module` where id = "'+modul_id+'"'
  1044. modul_name = None
  1045. for row in db.query(cmd) :
  1046. modul_name = row['moduleName']
  1047. return modul_name
  1048. def get_tower_info(tower_id:str):
  1049. """獲取水塔資料"""
  1050. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1051. cmd = 'SELECT * FROM `record_dcs` where device_id = "'+tower_id+'"'
  1052. result ={'DCS':{},'Fan':{},'Moter':{},'Device_info':{}}
  1053. for row in db.query(cmd) :
  1054. result['DCS'][row['key']]=row['value']
  1055. cmd = 'SELECT * FROM `record_tower` where device_id = "'+tower_id+'"'
  1056. for row in db.query(cmd) :
  1057. result['Fan'][row['key']]=row['value']
  1058. result['Moter'] = []
  1059. cmd = 'SELECT * FROM `vibration` where device_id = "'+tower_id+'"'
  1060. tmp = {}
  1061. for row in db.query(cmd) :
  1062. for col in db['vibration'].columns :
  1063. tmp[col] = row[col]
  1064. result['Moter'].append(tmp)
  1065. tmp = {}
  1066. cmd = 'SELECT * FROM `device` where id = "'+tower_id+'"'
  1067. for row in db.query(cmd):
  1068. for col in db['device'].columns :
  1069. if col != 'createTime':
  1070. result['Device_info'][col] = row[col]
  1071. return result
  1072. def get_tower_perform(tower_id:str):
  1073. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1074. cmd = 'SELECT * FROM `record_performance` where deviceCode = "'+tower_id+'" AND designWFR = 27000'
  1075. result = [{}]
  1076. for row in db.query(cmd):
  1077. for col in db['record_performance'].columns :
  1078. if col != 'createTime':
  1079. result[0][col] = row[col]
  1080. #print(result)
  1081. return result
  1082. def get_tower(company:str,factory:str,department:str,towerGroup:str):
  1083. towergroup_arr =[]
  1084. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1085. cmd = 'SELECT id FROM `device` where CompanyCode = "'+company+'" AND FactoryCode = "' +factory+'" AND DepartmentCode = "'+department+'" AND TowerGroupCode = "' + towerGroup + '"'
  1086. for row in db.query(cmd) :
  1087. towergroup_arr.append(row['id'])
  1088. return towergroup_arr
  1089. def check_tower_health(user_name:str):
  1090. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1091. org = get_user_under_organization(user_name)
  1092. #print(org)
  1093. towers : list
  1094. result = []
  1095. for dic in org:
  1096. #print(dic)
  1097. if dic['able'] == 1:
  1098. for group in dic['group']:
  1099. towers = get_tower(dic['company'],dic['factory'],dic['department'],group)
  1100. for tower in towers:
  1101. cmd = 'SELECT CVIndex,threshold FROM `vibration` where device_id = "'+tower+'"'
  1102. health =1
  1103. for row in db.query(cmd) :
  1104. print(row['CVIndex'],row['threshold'])
  1105. if row['CVIndex'] < int(row['threshold']):
  1106. health = 0
  1107. print("heheh")
  1108. print(health)
  1109. result.append({'company':dic['company'], 'factory':dic['factory'], 'department':dic['department'], 'group': group, 'tower': tower, 'health': health})
  1110. return result
  1111. def find_vibration_id(tower_id:str,channel_id:str):
  1112. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1113. cmd = 'SELECT id FROM `vibration` where device_id = "'+tower_id+'" AND channelName = "' +channel_id+'"'
  1114. for row in db.query(cmd) :
  1115. return row['id']
  1116. def get_channel_info(vibration_id):
  1117. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1118. cmd = 'SELECT * FROM `record_diagnosis` where vibration_id = "'+vibration_id+'"'
  1119. result = {}
  1120. for row in db.query(cmd) :
  1121. for col in db['record_diagnosis'].columns :
  1122. result[col] = row[col]
  1123. cmd2='SELECT CVIndex,threshold FROM `vibration` where id = "'+vibration_id+'"'
  1124. for row2 in db.query(cmd2) :
  1125. result['CVIndex'] = row2['CVIndex']
  1126. result['threshold'] = row2['threshold']
  1127. print(result)
  1128. return result
  1129. def get_channel_health(vibration_id:str):
  1130. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1131. result = []
  1132. data_name = ['CV_index', 'Vrms' ,'RPM']
  1133. for row in data_name:
  1134. result.append({'name':row,'data':[]})
  1135. cmd = 'SELECT * FROM record_health where vibration_id = "'+vibration_id+'"'
  1136. for row in db.query(cmd) :
  1137. for dic in result:
  1138. dic['data'].append(row[dic['name']])
  1139. return result
  1140. def get_predect_data(vibration_id:str):
  1141. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1142. result = {}
  1143. cmd = 'SELECT * FROM record_prediction_upd where vibration_id = "'+vibration_id+'"'
  1144. for row in db.query(cmd) :
  1145. arr = row['predictData'].split(',')
  1146. result['data']=arr
  1147. return result
  1148. def get_frequency(vibration_id:str):
  1149. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1150. result = {'Hz':[],'value':[]}
  1151. print(vibration_id)
  1152. cmd = 'SELECT * FROM record_frequency where vibration_id = "'+vibration_id+'"'
  1153. for row in db.query(cmd) :
  1154. result['Hz'].append(row['MFHz'])
  1155. result['value'].append(row['MFValue'])
  1156. return result
  1157. def get_vibration_info(deviceCode:str):
  1158. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1159. cmd = 'SELECT * FROM vibration where device_id = "'+deviceCode+'"'
  1160. tmp = []
  1161. for row in db.query(cmd) :
  1162. result = {}
  1163. for col in db['vibration'].columns :
  1164. result[col] = row[col]
  1165. #print(result)
  1166. tmp.append(result)
  1167. #print(tmp)
  1168. return tmp
  1169. def add_data():
  1170. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1171. loc_dt = datetime.today()
  1172. loc_dt_format = loc_dt.strftime("%Y-%m-%d %H:%M:%S")
  1173. cmd = "TRUNCATE TABLE record_health"
  1174. db.query(cmd)
  1175. for j in range(1,5):
  1176. for i in range(0,7):
  1177. time_del = timedelta(days=i)
  1178. date=loc_dt-time_del
  1179. db['record_health'].insert(dict(time_stamp=date, CV_index=uniform(0.6, 0.8), Vrms=uniform(1,3),Grms = uniform(1,3),RPM=uniform(1,3),vibration_id = j))
  1180. cmd = "TRUNCATE TABLE record_frequency"
  1181. db.query(cmd)
  1182. for i in range(0,1000):
  1183. print(i)
  1184. db['record_frequency'].insert(dict(time_stamp=loc_dt_format, MFHz=i, MFValue=uniform(0,0.12),vibration_id = 1))
  1185. cmd = "TRUNCATE TABLE record_frequency"
  1186. db.query(cmd)
  1187. for i in range(0,1000):
  1188. print(i)
  1189. db['record_frequency'].insert(dict(time_stamp=loc_dt_format, MFHz=i, MFValue=uniform(0,0.12),vibration_id = 1))
  1190. def add_tower():
  1191. db = dataset.connect('mysql://choozmo:pAssw0rd@db.ptt.cx:3306/Water_tower?charset=utf8mb4')
  1192. loc_dt = datetime.today()
  1193. loc_dt_format = loc_dt.strftime("%Y-%m-%d %H:%M:%S")
  1194. for device in ['dev005','dev006','dev007','dev008','dev009']:
  1195. for key in ['hotTemp','waterFlow','coldTemp','fanMotorCur','fanMotorSpeedFreq']:
  1196. db['record_dcs'].insert(dict(time_stamp=loc_dt_format, MFValue=uniform(0,0.12),vibration_id = 1))