12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004 |
- #!/usr/bin/env python3
- # -*- coding: utf-8 -*-
- from fastapi import APIRouter, Request, Depends,Query, HTTPException, status,BackgroundTasks
- from common.security import valid_access_token
- from fastapi.responses import JSONResponse
- from sqlalchemy.orm import Session
- from sqlalchemy import and_, or_
- from pydantic import BaseModel
- from datetime import datetime
- from database import get_db
- from typing import List
- from models import *
- from utils import *
- from utils.ry_system_util import *
- from utils.riskManagement_uitl import *
- import json
- import traceback
- router = APIRouter()
- @router.get('/list')
- async def get_inspection_task_list(
- type: str = Query(None, description='类型'),
- cycle :str = Query(None, description='周期'),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- query = db.query(RiskManagementRiskTask)
- query = query.filter(RiskManagementRiskTask.del_flag != '2')
- # 应用查询条件
- if type:
- query = query.filter(RiskManagementRiskTask.risk_type == type)
- if cycle:
- query = query.filter(RiskManagementRiskTask.task_cycle == cycle)
- # 计算总条目数
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTask.create_time.desc())
- # 执行分页查询
- RiskTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- RiskTasks_list = []
- for task in RiskTasks:
- if task.task_status=='3':
- task_status = '3' #'已完结'
- else:
- if datetime.now()<task.start_time:
- task_status = '0' #'未开始'
- elif task.start_time<=datetime.now()<=task.end_time:
- task_status = '1' #'进行中'
- else:
- task_status = '2' #'未完成'
- create_by = task.create_by
- create_by = db.query(SysUser).filter(SysUser.user_id==create_by).first()
- nick_name = None
- if create_by:
- nick_name=create_by.nick_name
- task_info = {
- "id": task.id,
- "task_number": task.task_number,
- "type": task.risk_type,
- "task_time": '%s-%s'%(task.start_time.strftime('%Y/%m/%d'),task.end_time.strftime('%Y/%m/%d')),
- "cycle": task.task_cycle,
- "task_range": task.task_range,
- "task_status": task_status,
- "create_by":nick_name,
- "create_time": task.create_time#.strftime('%Y-%m-%d')
- }
- RiskTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": RiskTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.get('/{id}')
- async def get_inspection_task(
- id: str ,
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- query = db.query(RiskManagementRiskTask)
- query = query.filter(RiskManagementRiskTask.del_flag != '2')
- # 应用查询条件
- if id:
- query = query.filter(RiskManagementRiskTask.id == id)
- # 执行查询
- task = query.first()
- if not task:
- detail = "任务不存在"
- raise HTTPException(status_code=404, detail="任务不存在")
- # 将查询结果转换为列表形式的字典
- if task.task_status == '3':
- task_status = '3' # '已完结'
- else:
- if datetime.now() < task.start_time:
- task_status = '0' # '未开始'
- elif task.start_time <= datetime.now() <= task.end_time:
- task_status = '1' # '进行中'
- else:
- task_status = '2' # '未完成'
- create_by = task.create_by
- create_by = db.query(SysUser).filter(SysUser.user_id == create_by).first()
- nick_name = None
- if create_by:
- nick_name = create_by.nick_name
- risk_task_result = {
- "id": task.id,
- "task_number": task.task_number,
- "type": task.risk_type,
- "task_time": '%s-%s'%(task.start_time.strftime('%Y/%m/%d'),task.end_time.strftime('%Y/%m/%d')),
- "cycle": task.task_cycle,
- "task_range": task.task_range,
- "task_status": task_status,
- "create_by":nick_name,
- "create_time": task.create_time.strftime('%Y-%m-%d')
- }
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": risk_task_result
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- if str(e)=='':
- e = detail
- raise HTTPException(status_code=500, detail=str(e))
- @router.post('/create')
- async def create_inspection_task(
- background_tasks: BackgroundTasks,
- db: Session = Depends(get_db),
- body = Depends(remove_xss_json),
- user_id = Depends(valid_access_token)
- ):
- try:
- cycle = body['cycle']
- # 0每年、1每月、2每周、3每日、4一次
- corn_query = body['corn_query']
- if cycle=='0':
- corn=f'0 0 {corn_query} *'
- elif cycle=='1':
- corn=f'0 0 {corn_query} * *'
- elif cycle == '2':
- corn = f'0 0 * * {corn_query}'
- elif cycle == '3':
- corn = f'0 0 * * *'
- else:
- corn=''
- # 创建新的预案记录
- new_task = RiskManagementRiskTask(
- risk_type=body['type'],
- start_time = body['start_time'],
- end_time = body['end_time'],
- task_cycle = cycle,
- corn_expression = corn,
- task_range = body['task_range'],
- task_status = '-1',
- create_by = user_id
- )
- # 添加到数据库会话并提交
- db.add(new_task)
- db.commit()
- db.refresh(new_task) # 可选,如果需要刷新实例状态
- new_task.task_number = f'YJFX{str(new_task.id).zfill(10)}'
- db.commit()
- background_tasks.add_task(create_risk_children_task,db,new_task,corn_query)
- # 返回创建成功的响应
- return {
- "code": 200,
- "msg": "成功",
- "data": None
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.put('/update')
- async def update_inspection_task(
- db: Session = Depends(get_db),
- body = Depends(remove_xss_json),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 提取请求数据
- query = db.query(RiskManagementRiskTask)
- query = query.filter(RiskManagementRiskTask.id == body['id'])
- query = query.filter(RiskManagementRiskTask.del_flag != '2')
- task = query.first()
- if not task:
- detail = "任务不存在"
- raise HTTPException(status_code=404, detail="任务不存在")
- # if 'cycle' in body:
- # cycle = body['cycle']
- # # 0每年、1每月、2每周、3每日、4一次
- # corn_query = body['corn_query']
- # if cycle == '0':
- # corn = f'0 0 {corn_query} *'
- # elif cycle == '1':
- # corn = f'0 0 {corn_query} * *'
- # elif cycle == '2':
- # corn = f'0 0 * * {corn_query}'
- # elif cycle == '3':
- # corn = f'0 0 * * *'
- # else:
- # corn = ''
- # task.inspection_cycle = cycle
- # task.corn_expression = corn
- if 'type' in body:
- task.risk_type = body['type']
- # if 'start_time' in body:
- # task.start_time = body['start_time']
- # if 'end_time' in body:
- # task.end_time = body['end_time']
- if 'task_range' in body:
- task.task_range = body['task_range']
- if 'task_status' in body:
- task.task_status = body['task_status']
- if user_id:
- task.update_by = user_id
- # 更新到数据库会话并提交
- db.commit()
- db.refresh(task) # 可选,如果需要刷新实例状态
- # 返回创建成功的响应
- return {
- "code": 200,
- "msg": "成功",
- "data": None
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- if str(e)=='':
- e = detail
- raise HTTPException(status_code=500, detail=str(e))
- @router.delete('/delete')
- async def delete_inspection_tasks(
- taskIds: list,
- db: Session = Depends(get_db),
- body = Depends(remove_xss_json),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 提取请求数据
- query = db.query(RiskManagementRiskTask)
- query = query.filter(RiskManagementRiskTask.del_flag != '2')
- query = query.filter(RiskManagementRiskTask.id.in_(taskIds))
- tasks = query.all()
- if not tasks:
- detail = "任务不存在"
- raise HTTPException(status_code=404, detail="任务不存在")
- for task in tasks:
- task.del_flag = '2'
- task.update_by=user_id
- # 更新到数据库会话并提交
- db.commit()
- # 返回创建成功的响应
- return {
- "code": 200,
- "msg": "删除成功",
- "data": None
- }
- except Exception as e:
- # 处理异常
- if str(e) == '':
- e = detail
- raise HTTPException(status_code=500, detail=str(e))
- @router.delete('/delete/{userId}')
- async def delete_inspection_task(
- userId: str,
- db: Session = Depends(get_db),
- body = Depends(remove_xss_json),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 提取请求数据
- query = db.query(RiskManagementRiskTask)
- query = query.filter(RiskManagementRiskTask.del_flag != '2')
- query = query.filter(RiskManagementRiskTask.id==userId)
- task = query.first()
- if not task:
- detail = "任务不存在"
- raise HTTPException(status_code=404, detail="任务不存在")
- task.del_flag = '2'
- task.update_by = user_id
- # 更新到数据库会话并提交
- db.commit()
- db.refresh(task) # 可选,如果需要刷新实例状态
- # 返回创建成功的响应
- return {
- "code": 200,
- "msg": "删除成功",
- "data": None
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- if str(e) == '':
- e = detail
- raise HTTPException(status_code=500, detail=str(e))
- ####小屏子任务查询
- @router.get('/children/task/list')
- async def get_risk_task_list(
- type: str =Query(None, description='类型'),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- # 查询用户负责层级
- task_range = user_id_get_task_range(db,user_id)
- #查询未办结巡查任务列表
- Task_list = db.query(RiskManagementRiskTask)\
- .filter(RiskManagementRiskTask.del_flag!='2')\
- .filter(RiskManagementRiskTask.task_range.in_(task_range))\
- .filter(RiskManagementRiskTask.task_status!='3').all()
- #获取所有巡查任务id
- task_ids = [i.id for i in Task_list]
- #用户所有负责的区域
- user_area_code_list = db.query(RiskManagementInspectionUser)\
- .filter(RiskManagementInspectionUser.del_flag!='2')\
- .filter(RiskManagementInspectionUser.user_id==user_id).all()
- user_area_codes = [i.area_code for i in user_area_code_list]
- #查询子任务
- query = db.query(RiskManagementRiskTaskChildrenTask)
- query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
- # 应用查询条件
- # 查询小于今天
- query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time <=datetime.now())
- # 查询层级、未办结子任务
- query = query.filter(RiskManagementRiskTaskChildrenTask.task_range.in_(task_range))
- query = query.filter(RiskManagementRiskTaskChildrenTask.task_id.in_(task_ids))
- # 计算总条目数
- if type:
- query = query.filter(RiskManagementRiskTaskChildrenTask.type==type)
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTask.tsak_time.asc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- InspectionTasks_list = []
- for task in InspectionTasks:
- # 判断这个任务该user_id完成了没
- tasklog = db.query(RiskManagementRiskTaskChildrenTaskLog).\
- filter(RiskManagementRiskTaskChildrenTaskLog.del_flag!='2').\
- filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id==task.id).\
- filter(RiskManagementRiskTaskChildrenTaskLog.area_code.in_(user_area_codes)).all()
- task_area_code_list = [i.area_code for i in tasklog]
- query = db.query(RiskManagementInspectionUser)\
- .filter(RiskManagementInspectionUser.del_flag!='2')\
- .filter(RiskManagementInspectionUser.user_id==user_id)
- if task.task_range == '0' and '440900000000' not in task_area_code_list:
- user_range_area_codes= ['440900000000']
- elif task.task_range == '1':
- query = query.filter(
- and_(RiskManagementInspectionUser.area_code.like('%000000'),
- RiskManagementInspectionUser.area_code.notlike('%00000000'),
- ~RiskManagementInspectionUser.area_code.in_(task_area_code_list)))
- user_range_area_codes= list({i.area_code for i in query.all()})
- elif task.task_range == '2':
- query = query.filter(and_(RiskManagementInspectionUser.area_code.like('%000'),
- RiskManagementInspectionUser.area_code.notlike('%000000'),
- ~RiskManagementInspectionUser.area_code.in_(task_area_code_list)))
- user_range_area_codes= list({i.area_code for i in query.all()})
- elif task.task_range == '3':
- query = query.filter(RiskManagementInspectionUser.area_code.notlike('%000'),
- ~RiskManagementInspectionUser.area_code.in_(task_area_code_list))
- user_range_area_codes= list({i.area_code for i in query.all()})
- else:
- user_range_area_codes= []
- for area_code in user_range_area_codes:
- task_info = {
- "id": task.id,
- "type": task.type,
- "task_range": task.task_range,
- "cycle": task.cycle,
- "area_code":area_code,
- "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
- "task_time": task.tsak_time.strftime('%Y-%m-%d'),
- "create_time": task.create_time.strftime('%Y-%m-%d')
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- ##日历
- @router.get('/children/task/calendar/list')
- async def get_inspection_task_list(
- year_1: int =Query(None, description='年份'),
- month_1: int =Query(None, description='月份'),
- # page: int = Query(1, gt=0, description='页码'),
- # pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- import datetime as datetime_1
- task_range = user_id_get_task_range(db,user_id)
- Task_list = db.query(RiskManagementRiskTask).\
- filter(RiskManagementRiskTask.del_flag!='2').\
- filter(RiskManagementRiskTask.task_range.in_(task_range)).all() #.filter(RiskManagementInspectionTask.task_status!='3')
- task_ids = [i.id for i in Task_list]
- user_area_code_list = db.query(RiskManagementInspectionUser).\
- filter(RiskManagementInspectionUser.del_flag!='2').\
- filter(RiskManagementInspectionUser.user_id==user_id).all()
- user_area_codes = [i.area_code for i in user_area_code_list]
- query = db.query(RiskManagementRiskTaskChildrenTask)
- query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
- # 应用查询条件
- current_date = datetime.today()
- if year_1 is None:
- year_1 =current_date.year
- if month_1 is None:
- month_1 = current_date.month
- if month_1 == 12:
- query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time < datetime_1.date(year_1+1, 1, 1))
- else:
- query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time < datetime_1.date(year_1, month_1 + 1, 1))
- query = query.filter(RiskManagementRiskTaskChildrenTask.tsak_time >= datetime_1.date(year_1, month_1, 1))
- # query = query.filter(RiskManagementInspectionTaskChildrenTask.tsak_time <=datetime.now())
- query = query.filter(RiskManagementRiskTaskChildrenTask.task_range.in_(task_range))
- query = query.filter(RiskManagementRiskTaskChildrenTask.task_id.in_(task_ids))
- # 计算总条目数
- total_items = query.count()
- print(total_items)
- result = []
- # 获取指定月份的第一天是周几
- # first_day = datetime.date(yaer_1, month_1, 1)
- # 计算该月的天数
- if month_1 == 12:
- number_of_days = (datetime_1.date(year_1+1, 1, 1) - datetime_1.timedelta(days=1)).day
- else:
- number_of_days = (datetime_1.date(year_1, month_1 + 1, 1) - datetime_1.timedelta(days=1)).day
- # 遍历该月的每一天
- for day in range(1, number_of_days + 1):
- # 创建日期对象
- date_obj = datetime_1.date(year_1, month_1, day)
- # 获取星期(0是周一,6是周日)
- week_day = date_obj.weekday()
- # 将星期转换为中文
- week_day_cn = "一二三四五六日"[week_day]
- data = {"day":day,"date":f"{year_1}-{month_1}-{day}","week":f'周{week_day_cn}',"status":0}
- if date_obj==datetime_1.date.today():
- data['status']=4
- # 排序
- # total_items = query.count()
- # print( '前',total_items)
- # print(datetime_1.date(year_1, month_1, day))
- query_1 = query.filter(
- RiskManagementRiskTaskChildrenTask.tsak_time == datetime_1.date(year_1, month_1, day))
- # query = query.order_by(RiskManagementInspectionTaskChildrenTask.tsak_time.asc())
- # total_items = query_1.count()
- # print( '后',total_items)
- InspectionTasks = query_1.all()
- # 将查询结果转换为列表形式的字典
- InspectionTasks_list = []
- for task in InspectionTasks:
- # 判断这个任务该user_id完成了没
- # tasklog = db.query(RiskManagementInspectionTaskChildrenTaskLog).\
- # filter(RiskManagementInspectionTaskChildrenTaskLog.del_flag!='2').\
- # filter(RiskManagementInspectionTaskChildrenTaskLog.children_task_id==task.id).\
- # filter(RiskManagementInspectionTaskChildrenTaskLog.area_code.in_(user_area_codes)).all()
- # task_area_code_list = [i.area_code for i in tasklog]
- query_2 = db.query(RiskManagementInspectionUser).\
- filter(RiskManagementInspectionUser.del_flag!='2').\
- filter(RiskManagementInspectionUser.user_id==user_id)
- if task.task_range == '0':
- user_range_area_codes= ['440900000000']
- elif task.task_range == '1':
- query_2 = query_2.filter(
- and_(RiskManagementInspectionUser.area_code.like('%000000'),
- RiskManagementInspectionUser.area_code.notlike('%00000000')))
- user_range_area_codes= list({i.area_code for i in query_2.all()})
- elif task.task_range == '2':
- query_2 = query_2.filter(and_(RiskManagementInspectionUser.area_code.like('%000'),
- RiskManagementInspectionUser.area_code.notlike('%000000')))
- user_range_area_codes= list({i.area_code for i in query_2.all()})
- elif task.task_range == '3':
- query_2 = query_2.filter(RiskManagementInspectionUser.area_code.notlike('%000'))
- user_range_area_codes= list({i.area_code for i in query_2.all()})
- else:
- user_range_area_codes= []
- print(task.task_range)
- print(user_range_area_codes)
- for area_code in user_range_area_codes:
- tasklog = db.query(RiskManagementRiskTaskChildrenTaskLog). \
- filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2'). \
- filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id == task.id). \
- filter(RiskManagementRiskTaskChildrenTaskLog.area_code==area_code).first()
- task_info = {
- "id": task.id,
- "type": task.type,
- "cycle": task.cycle,
- "area_code":area_code,
- "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
- "task_status": tasklog is not None,
- "task_time": task.tsak_time.strftime('%Y-%m-%d'),
- "create_time": task.create_time.strftime('%Y-%m-%d %H:%M')
- }
- if tasklog :
- task_info['create_time'] = tasklog.create_time.strftime('%Y-%m-%d %H:%M')
- if task.tsak_time<datetime.today() and data['status']<1:
- data['status'] = 1 #有事已完成
- # elif tasklog.tsak_time > datetime.today():
- # data['status'] = 3 # 未来有事
- else:
- if task.tsak_time < datetime.today() and data['status'] < 2:
- data['status'] = 2 # 有事未完成
- elif task.tsak_time > datetime.today():
- data['status'] = 3 # 未来有事
- InspectionTasks_list.append(task_info)
- data['task_list']=InspectionTasks_list
- result.append(data)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": result
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.get('/children/task/records')
- async def get_children_task_records_list(
- type: str =Query(None, description='类型'),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 获取子任务id
- query = db.query(RiskManagementRiskTaskChildrenTask)
- query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
- if type:
- query = query.filter(RiskManagementRiskTaskChildrenTask.type==type)
- children_ids = [i.id for i in query.all()]
- print(children_ids)
- # 构建查询
- query = db.query(RiskManagementRiskTaskChildrenTaskLog)
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2')
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.user_id == user_id)
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id.in_(children_ids))
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTaskLog.create_time.desc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- InspectionTasks_list = []
- for task in InspectionTasks:
- children_task = risk_task_children_task_id_get_risk_task_children_task_info(db,task.children_task_id)
- task_info = {
- "id": task.children_task_id,
- "type": children_task.type,
- "task_range": children_task.task_range,
- "cycle": children_task.cycle,
- "area_code": task.area_code,
- "area": area_code_get_ancestors_names(db, area_code_get_area_info(db, task.area_code)),
- "task_time": children_task.tsak_time.strftime('%Y-%m-%d'),
- "create_time": task.create_time.strftime('%Y-%m-%d %H:%M')
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.get('/children/task/result/{children_task_id}')
- async def get_children_task_result(
- children_task_id: str ,
- db: Session = Depends(get_db),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- query = db.query(RiskManagementRiskTaskChildrenTaskResult)
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.del_flag != '2')
- # 应用查询条件
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.children_task_id == children_task_id)
- # 计算总条目数
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTaskResult.create_time.desc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- InspectionTasks_list = []
- for task in InspectionTasks:
- area_code = task.area_code
- area = area_code_get_area_info(db, area_code)
- area = area_code_get_ancestors_names(db, area)
- task_info = {
- "id": task.id,
- # "children_task_id": task.children_task_id,
- "type":risk_task_children_task_id_get_risk_task_children_task_info(db,task.children_task_id).type,
- "point_name": task.inspection_point_name,
- # "area": area,
- # "create_time": task.create_time.strftime('%Y-%m-%d'),
- # "nick_name": task.nick_name,
- "task_result": task.inspection_result,
- "remark": task.remark,
- "fileList": get_file_query_fun(db=db, from_scenario='RiskManagementRiskTaskChildrenTaskResult',
- foreign_key=task.id)
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.post('/children/task/result/create')
- async def create_inspection_task(
- db: Session = Depends(get_db),
- body = Depends(remove_xss_json),
- user_id = Depends(valid_access_token)
- ):
- try:
- children_task_id = body['children_task_id']
- result = body['result']
- area_code = body['area_code']
- area =area_code_get_ancestors_names(db, area_code_get_area_info(db, area_code))
- # task_time = body['task_time']
- # 创建新的
- new_task_log = RiskManagementRiskTaskChildrenTaskLog(
- id=new_guid(),
- children_task_id=children_task_id,
- area_code = area_code,
- area = area,
- task_status = '1',
- user_id = user_id,
- nick_name = user_id_get_user_info(db,user_id).nick_name,
- create_by = user_id
- )
- for info in result:
- new_file_list = info['fileList']
- inspection_point_name= info['point_name']
- inspection_result = info['task_result']
- remark = info['remark']
- new_task_result = RiskManagementRiskTaskChildrenTaskResult(
- id=new_guid(),
- children_task_id=children_task_id,
- inspection_point_name=inspection_point_name,
- area_code=area_code,
- inspection_result=inspection_result,
- remark = remark,
- user_id = user_id,
- nick_name = user_id_get_user_info(db,user_id).nick_name,
- create_by = user_id
- )
- db.add(new_task_result)
- for file in new_file_list:
- file_name = file['file_name']
- file_name_desc = file['file_name_desc']
- status = file['status']
- new_file = RiskManagementFile(
- file_id=new_guid(),
- foreign_key=new_task_result.id,
- from_scenario='RiskManagementRiskTaskChildrenTaskResult',
- file_name=file_name,
- file_name_desc=file_name_desc,
- status=status
- )
- db.add(new_file)
- # 添加到数据库会话并提交
- db.add(new_task_log)
- db.commit()
-
- # 标记消息已读
- child_task_info = db.query(RiskManagementRiskTaskChildrenTask).filter(RiskManagementRiskTaskChildrenTask.id == children_task_id).first()
- if child_task_info is not None:
- logger.info("标记[风险排查任务]已读 {}", str(child_task_info.task_id))
- db_msg_center.update_msg_read(db, user_id, "风险排查", str(child_task_info.task_id))
- # 返回创建成功的响应
- return {
- "code": 200,
- "msg": "成功",
- "data": None
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- ####中屏子任务
- @router.get('/children/task/{task_id}/list')
- async def get_inspection_task_list(
- task_id: str ,
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- query = db.query(RiskManagementRiskTaskChildrenTask)
- query = query.filter(RiskManagementRiskTaskChildrenTask.del_flag != '2')
- # 应用查询条件
- query = query.filter(RiskManagementRiskTaskChildrenTask.task_id == task_id)
- # 计算总条目数
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTask.tsak_time.asc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- InspectionTasks_list = []
- for task in InspectionTasks:
- task_num=task.task_num
- completed_num = db.query(RiskManagementRiskTaskChildrenTaskLog)\
- .filter(RiskManagementRiskTaskChildrenTaskLog.del_flag!='2')\
- .filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id==task.id).count()
- incomplete_num = task_num-completed_num
- task_info = {
- "id": task.id,
- "task_id":task.task_id,
- "task_number": task.task_number,
- "type": task.type,
- "task_time": task.tsak_time.strftime('%Y-%m-%d'),
- "cycle": task.cycle,
- "task_range": task.task_range,
- "completed_num": completed_num,
- "incomplete_num": incomplete_num,
- "create_time": task.create_time.strftime('%Y-%m-%d')
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.get('/children/task/log/{children_task_id}/{status}/list')
- async def get_inspection_task_list(
- children_task_id: str ,
- status:str,
- area_code: str = Query(None, description='区划编码'),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- total_items= 0
- InspectionTasks_list = []
- if status=='completed':
- query = db.query(RiskManagementRiskTaskChildrenTaskLog)
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.del_flag != '2')
- # 应用查询条件
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.children_task_id == children_task_id)
- if area_code:
- query = query.filter(RiskManagementRiskTaskChildrenTaskLog.area_code == area_code)
- # 计算总条目数
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTaskLog.create_time.desc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- for task in InspectionTasks:
- task_info = {
- "id": task.id,
- "children_task_id":children_task_id,
- "area_code": task.area_code,
- "area": task.area,
- "task_status": task.task_status,
- "user_id": task.user_id,
- "nick_name": task.nick_name,
- "create_time": task.create_time.strftime('%Y-%m-%d')
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- elif status == 'incomplete':
- children_task = risk_task_children_task_id_get_risk_task_children_task_info(db,children_task_id)
- if children_task:
- task = risk_task_id_get_risk_task_info(db,children_task.task_id)
- if task:
- complete_area_code_list =[i.area_code for i in risk_task_children_task_id_get_risk_task_children_task_log_info(db,children_task_id)]
- area_code_list = get_area_code_exclude_list(db,task.task_range,complete_area_code_list)
- if area_code:
- area_code_list = area_code_rang_get_area_children_list(db, children_task.task_range, area_code,
- complete_area_code_list)
- for area_code in area_code_list:
- task_info = {
- "id": new_guid(),
- "children_task_id": children_task_id,
- "area_code": area_code,
- "area": area_code_get_ancestors_names(db,area_code_get_area_info(db,area_code)),
- "task_status": '0',
- "user_id": '',
- "nick_name": '',
- "create_time": children_task.tsak_time.strftime('%Y-%m-%d')
- }
- InspectionTasks_list.append(task_info)
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
- @router.get('/children/task/result/{children_task_id}/list')
- async def get_inspection_task_list(
- children_task_id: str ,
- area_code: str = Query(None, description='区划编码'),
- result: str = Query(None, description='巡查结果'),
- nick_name: str = Query(None, description='姓名'),
- page: int = Query(1, gt=0, description='页码'),
- pageSize: int = Query(10, gt=0, description='每页条目数量'),
- db: Session = Depends(get_db),
- user_id = Depends(valid_access_token)
- ):
- try:
- # 构建查询
- query = db.query(RiskManagementRiskTaskChildrenTaskResult)
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.del_flag != '2')
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.children_task_id == children_task_id)
- # 应用查询条件
- if area_code:
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.area_code == area_code)
- if result:
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.inspection_result == result)
- if nick_name:
- query = query.filter(RiskManagementRiskTaskChildrenTaskResult.nick_name.like(f'%{nick_name}%') )
- # 计算总条目数
- total_items = query.count()
- # 排序
- query = query.order_by(RiskManagementRiskTaskChildrenTaskResult.create_time.desc())
- # 执行分页查询
- InspectionTasks = query.offset((page - 1) * pageSize).limit(pageSize).all()
- # 将查询结果转换为列表形式的字典
- InspectionTasks_list = []
- for task in InspectionTasks:
- area_code = task.area_code
- area = area_code_get_area_info(db, area_code)
- area = area_code_get_ancestors_names(db, area)
- task_info = {
- "id": task.id,
- "children_task_id": task.children_task_id,
- "point_name":task.inspection_point_name,
- "area": area,
- "create_time": task.create_time.strftime('%Y-%m-%d'),
- "nick_name": task.nick_name,
- "result": task.inspection_result,
- "fileList": get_file_query_fun(db=db,from_scenario='RiskManagementRiskTaskChildrenTaskResult', foreign_key=task.id),
- "remark":task.remark
- }
- InspectionTasks_list.append(task_info)
- # 返回结果
- return {
- "code": 200,
- "msg": "成功",
- "data": InspectionTasks_list,
- "total": total_items,
- "page": page,
- "pageSize": pageSize,
- "totalPages": (total_items + pageSize - 1) // pageSize
- }
- except Exception as e:
- # 处理异常
- traceback.print_exc()
- raise HTTPException(status_code=500, detail=str(e))
|