checkin.py 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262
  1. from fastapi import APIRouter, Request, Depends, HTTPException, Query, Header,status
  2. from sqlalchemy.exc import IntegrityError
  3. from fastapi.responses import HTMLResponse, FileResponse, StreamingResponse, RedirectResponse
  4. from fastapi.responses import JSONResponse
  5. from starlette.requests import HTTPConnection
  6. from database import get_db
  7. from sqlalchemy import text, exists, and_, or_, not_
  8. from sqlalchemy.orm import Session
  9. from sqlalchemy.sql import func
  10. from models import *
  11. import json
  12. import random
  13. from sqlalchemy import create_engine, select
  14. from typing import Optional
  15. from utils.StripTagsHTMLParser import *
  16. from common.db import db_event_management, db_user, db_area, db_emergency_plan
  17. from common.security import valid_access_token
  18. import traceback
  19. from utils import *
  20. from datetime import datetime, timedelta
  21. import qrcode
  22. from PIL import Image
  23. from io import BytesIO
  24. from config import settings
  25. from common import YzyApi
  26. from extensions import logger
  27. router = APIRouter()
  28. '''
  29. @router.get('/qrcode', response_class=StreamingResponse)
  30. async def get_qrcode(
  31. request: Request,
  32. event_id: str,
  33. db: Session = Depends(get_db)
  34. ):
  35. url = str(request.url)
  36. print('url:', url)
  37. url = url.replace("qrcode", "qrcode2") + "&r="+rnd()
  38. url = url.replace("http://" + request.url.hostname, settings.YZY_WEB_ROOT)
  39. logger.info('替换到互联网ip: {}', url)
  40. qr = qrcode.QRCode(
  41. version=1,
  42. error_correction=qrcode.constants.ERROR_CORRECT_M,
  43. box_size=10,
  44. border=0,
  45. )
  46. qr.add_data(url)
  47. qr.make(fit=True)
  48. image = qr.make_image()
  49. buf = BytesIO()
  50. image.save(buf, 'png')
  51. img_data = buf.getvalue()
  52. return StreamingResponse(BytesIO(img_data), media_type="image/png")
  53. @router.get('/qrcode2')
  54. async def get_qrcode2(
  55. event_id: str,
  56. user_agent: str = Header(default=''),
  57. db: Session = Depends(get_db)
  58. ):
  59. print('user_agent:', user_agent)
  60. redirect_url = "/yjxp/#/signPage?event_id={}".format(event_id) # 业务页面
  61. # if "wxworklocal" in user_agent:
  62. # logger.info("redirect_url: {}", redirect_url)
  63. # qrcode_str = f"http://19.155.220.209/api/event_management/event?event_id={event_id}"
  64. detail_url = YzyApi.format_redirect_url(redirect_url)
  65. else:
  66. # 120.241.74.139
  67. # detail_url = "http://yjxp.tjp.com.cn:8086/yjxp/#" + redirect_url
  68. #detail_url = "{}{}".format(settings.YZY_WEB_ROOT, redirect_url)
  69. return RedirectResponse(detail_url)
  70. '''
  71. @router.post("/getInfo")
  72. async def getInfo(
  73. request: Request,
  74. db: Session = Depends(get_db),
  75. body = Depends(remove_xss_json),
  76. user_id = Depends(valid_access_token)
  77. ):
  78. event_id = body['event_id']
  79. row = db.query(SysUser).filter(SysUser.user_id == user_id).first()
  80. user_info = get_model_dict(row)
  81. yzy_account = user_info['yzy_account']
  82. contact_info = db.query(EmergencyContactInfo).filter(and_(EmergencyContactInfo.del_flag == "0", EmergencyContactInfo.yue_gov_ease_phone == yzy_account)).first()
  83. contact_info = get_model_dict(contact_info)
  84. nick_name = contact_info['contact_name']
  85. dept_id = contact_info['unit_id']
  86. dept_name = contact_info['unit_name']
  87. duties = contact_info['position']
  88. # row = db.query(SysDept).filter(SysDept.dept_id == user_info['dept_id']).first()
  89. # dept_info = get_model_dict(row)
  90. user_name = user_info['user_name']
  91. # nick_name = user_info['nick_name']
  92. # dept_id = user_info['dept_id']
  93. # dept_name = dept_info['dept_name']
  94. # duties = ''
  95. sign_time = ''
  96. phone = user_info['phonenumber']
  97. row = db.query(EventCheckin).filter(and_(EventCheckin.event_id == event_id, EventCheckin.phone == phone, EventCheckin.del_flag == '0')).first()
  98. if row is not None:
  99. check_info = get_model_dict(row)
  100. user_name = check_info['user_name']
  101. nick_name = check_info['nick_name']
  102. dept_id = check_info['dept_id']
  103. dept_name = check_info['dept_name']
  104. duties = check_info['duties']
  105. sign_time = get_datetime_str(check_info['sign_time'])
  106. phone = check_info['phone']
  107. print('---------------', sign_time)
  108. return {
  109. 'code': 200,
  110. 'msg': '查询成功',
  111. 'data': {
  112. 'user_id': user_info['user_id'],
  113. 'user_name': user_name,
  114. 'nick_name': nick_name,
  115. 'dept_id': dept_id,
  116. 'dept_name': dept_name,
  117. 'duties': duties,
  118. 'sign_time': sign_time,
  119. 'phone': phone
  120. }
  121. }
  122. @router.post("/check")
  123. async def check(
  124. request: Request,
  125. db: Session = Depends(get_db),
  126. body = Depends(remove_xss_json),
  127. # user_id = Depends(valid_access_token)
  128. ):
  129. time.sleep(2.0)
  130. event_id = body['event_id']
  131. nick_name = body['nick_name']
  132. dept_name = body['dept_name']
  133. phone = body['phone']
  134. duties = body['duties']
  135. type_ = body['type']
  136. dept_id = 0
  137. yzy_account = ''
  138. contact_info = db.query(EmergencyContactInfo).filter(and_(EmergencyContactInfo.del_flag == "0", EmergencyContactInfo.yue_gov_ease_phone == phone)).first()
  139. if contact_info is not None:
  140. yzy_account = phone
  141. contact_info = get_model_dict(contact_info)
  142. dept_id = contact_info['unit_id']
  143. if type_ == '1':
  144. # 签名
  145. row = db.query(EventCheckin).filter(and_(EventCheckin.event_id == event_id, EventCheckin.phone == phone)).first()
  146. if row is None:
  147. event_checkin = EventCheckin(
  148. event_id = event_id,
  149. user_id = 0,
  150. user_name = '',
  151. nick_name = nick_name,
  152. dept_id = dept_id,
  153. dept_name = dept_name,
  154. sign_time = datetime.now(),
  155. yzy_account = yzy_account,
  156. duties = duties,
  157. phone = phone,
  158. del_flag = '0'
  159. )
  160. db.add(event_checkin)
  161. db.commit()
  162. else:
  163. row.sign_time = datetime.now()
  164. row.nick_name = nick_name
  165. row.dept_name = dept_name
  166. row.duties = duties
  167. row.phone = phone
  168. row.del_flag = '0'
  169. db.commit()
  170. return {
  171. 'code': 200,
  172. 'msg': '签到成功'
  173. }
  174. elif type_ == '2':
  175. # 取消签名
  176. row = db.query(EventCheckin).filter(and_(EventCheckin.event_id == event_id, EventCheckin.phone == phone)).first()
  177. if row is None:
  178. return {
  179. 'code': 500,
  180. 'msg': '用户并未签名,无法签退'
  181. }
  182. row.sign_time = datetime.now()
  183. row.del_flag = '1'
  184. db.commit()
  185. return {
  186. 'code': 200,
  187. 'msg': '签退成功'
  188. }
  189. @router.get('/list')
  190. async def get_event_list(
  191. event_id: str,
  192. page: int = Query(1, gt=0, description='页码'),
  193. page_size: int = Query(10, gt=0, description='pageSize'),
  194. db: Session = Depends(get_db)
  195. ):
  196. try:
  197. # 应用查询条件
  198. where = and_(EventCheckin.del_flag == '0', EventCheckin.event_id == event_id)
  199. # 计算总条目数
  200. q = db.query(func.count(EventCheckin.id))
  201. q = q.filter(where)
  202. total = q.scalar()
  203. # 执行分页查询
  204. q = db.query(EventCheckin)
  205. q = q.filter(where)
  206. rows = q.order_by(EventCheckin.id.desc()).offset((page - 1) * page_size).limit(page_size).all()
  207. data = [
  208. {
  209. "event_id": row.event_id,
  210. "user_id": row.user_id,
  211. "user_name": row.user_name,
  212. "nick_name": row.nick_name,
  213. "dept_id": row.dept_id,
  214. "dept_name": row.dept_name,
  215. "sign_time": get_datetime_str(row.sign_time),
  216. "yzy_account": row.yzy_account,
  217. "duties": row.duties,
  218. "phone": row.phone
  219. }
  220. for row in rows
  221. ]
  222. # 返回结果
  223. return {
  224. "code": 200,
  225. "msg": "查询成功",
  226. "data": data,
  227. "total": total
  228. }
  229. except Exception as e:
  230. # 处理异常
  231. traceback.print_exc()
  232. raise HTTPException(status_code=500, detail=str(e))