__init__.py 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591
  1. #!/usr/bin/env python3
  2. # -*- coding: utf-8 -*-
  3. from fastapi import APIRouter, Request, Depends, Query, HTTPException, status
  4. from common.security import valid_access_token
  5. from fastapi.responses import JSONResponse
  6. from sqlalchemy.orm import Session
  7. from sqlalchemy import and_, or_
  8. from sqlalchemy.sql import func
  9. from common.auth_user import *
  10. from pydantic import BaseModel
  11. from database import get_db
  12. from typing import List
  13. from models import *
  14. from utils import *
  15. import traceback
  16. import json
  17. router = APIRouter()
  18. @router.get('/type/list')
  19. async def get_dict_types(
  20. db: Session = Depends(get_db), # 假设 get_db 是获取数据库会话的依赖项
  21. pageNum: int = Query(1, gt=0),
  22. pageSize: int = Query(10, gt=0),
  23. dictName: str = Query(None, max_length=100),
  24. dictType: str = Query(None, max_length=100),
  25. beginTime: datetime = Query(None),
  26. endTime: datetime = Query(None)
  27. ):
  28. try:
  29. # 构建查询
  30. query = db.query(SysDictType)
  31. query = query.filter(SysDictType.del_flag!='2')
  32. # 添加查询条件
  33. if dictName:
  34. query = query.filter(SysDictType.dict_name.like(f'%{dictName}%'))
  35. if dictType:
  36. query = query.filter(SysDictType.dict_type.like(f'%{dictType}%'))
  37. if beginTime and endTime:
  38. query = query.filter(
  39. and_(
  40. SysDictType.create_time >= beginTime,
  41. SysDictType.create_time <= endTime
  42. )
  43. )
  44. # 计算总记录数
  45. total_count = query.count()
  46. # 计算分页
  47. offset = (pageNum - 1) * pageSize
  48. dict_types = query.offset(offset).limit(pageSize).all()
  49. # 转换为字典
  50. dict_type_dicts = [
  51. {
  52. "dictId": d.dict_id,
  53. "dictName": d.dict_name,
  54. "dictType": d.dict_type,
  55. "remark": d.remark,
  56. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  57. }
  58. for d in dict_types
  59. ]
  60. # 构建返回结果
  61. result = {
  62. "total": total_count,
  63. "rows": dict_type_dicts,
  64. "code": 200,
  65. "msg": "查询成功"
  66. }
  67. return result
  68. except Exception as e:
  69. # 处理异常
  70. raise HTTPException(status_code=500, detail=str(e))
  71. @router.get('/type/optionselect')
  72. async def get_dict_types_optionselect(
  73. db: Session = Depends(get_db), # 假设 get_db 是获取数据库会话的依赖项
  74. ):
  75. try:
  76. # 构建查询
  77. query = db.query(SysDictType)
  78. query = query.filter(SysDictType.del_flag!='2')
  79. # 计算总记录数
  80. dict_types = query.all()
  81. # 转换为字典
  82. dict_type_dicts = [
  83. {
  84. "dictId": d.dict_id,
  85. "dictName": d.dict_name,
  86. "dictType": d.dict_type,
  87. "remark": d.remark,
  88. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  89. }
  90. for d in dict_types
  91. ]
  92. # 构建返回结果
  93. result = {
  94. "data": dict_type_dicts,
  95. "code": 200,
  96. "msg": "查询成功"
  97. }
  98. return result
  99. except Exception as e:
  100. # 处理异常
  101. raise HTTPException(status_code=500, detail=str(e))
  102. @router.get('/type/{dictId}')
  103. async def get_dict_types_optionselect(
  104. dictId: str,
  105. db: Session = Depends(get_db), # 假设 get_db 是获取数据库会话的依赖项
  106. body = Depends(remove_xss_json),
  107. user: AuthUser = Depends(get_auth_user)
  108. ):
  109. try:
  110. # 构建查询
  111. query = db.query(SysDictType)
  112. query = query.filter(SysDictType.dict_id==dictId)
  113. query = query.filter(SysDictType.del_flag!='2')
  114. dict_types = query.first()
  115. # 转换为字典
  116. dict_type_dicts ={
  117. "dictId": dict_types.dict_id,
  118. "dictName": dict_types.dict_name,
  119. "dictType": dict_types.dict_type,
  120. "remark": dict_types.remark,
  121. "createTime": dict_types.create_time.strftime('%Y-%m-%d %H:%M:%S') if dict_types.create_time else ''
  122. }
  123. # 构建返回结果
  124. result = {
  125. "data": dict_type_dicts,
  126. "code": 200,
  127. "msg": "查询成功"
  128. }
  129. return result
  130. except Exception as e:
  131. # 处理异常
  132. raise HTTPException(status_code=500, detail=str(e))
  133. class DictTypeCreateForm(BaseModel):
  134. dictName: str
  135. dictType: str
  136. remark: str = None
  137. @router.post("/type")
  138. async def create_dict_type(
  139. form_data: DictTypeCreateForm,
  140. db: Session = Depends(get_db),
  141. body = Depends(remove_xss_json),
  142. user_id = Depends(valid_access_token)
  143. ):
  144. try:
  145. # 从请求数据创建一个新的 SysDictType 实例
  146. new_dict_type = SysDictType(
  147. dict_name=form_data.dictName,
  148. dict_type=form_data.dictType,
  149. remark=form_data.remark,
  150. create_time=datetime.now(), # 假设自动设置创建时间
  151. update_time=datetime.now() # 假设自动设置更新时间
  152. )
  153. # 添加到数据库会话并提交
  154. db.add(new_dict_type)
  155. db.commit()
  156. db.refresh(new_dict_type) # 可选,如果需要刷新实例状态
  157. # 构建并返回响应
  158. return {
  159. "code": 200,
  160. "msg": "操作成功",
  161. "data": None # 根据你的响应示例,data 为 null
  162. }
  163. except Exception as e:
  164. # 处理异常
  165. raise HTTPException(status_code=500, detail=str(e))
  166. class DictTypeUpdataForm(BaseModel):
  167. createTime : str
  168. dictId : str
  169. dictName: str
  170. dictType: str
  171. remark: str = None
  172. @router.put("/type")
  173. async def updata_dict_type(
  174. form_data: DictTypeUpdataForm,
  175. db: Session = Depends(get_db),
  176. body = Depends(remove_xss_json),
  177. user_id = Depends(valid_access_token)
  178. ):
  179. try:
  180. # 从请求数据创建一个新的 SysDictType 实例
  181. dict_type = db.query(SysDictType).filter(SysDictType.dict_id == form_data.dictId and SysDictType.del_flag != '2').first()
  182. if not dict_type:
  183. detail = "dict_type不存在"
  184. raise HTTPException(status_code=404, detail="dict_type不存在")
  185. dict_type.dict_name = form_data.dictName
  186. dict_type.dict_type = form_data.dictType
  187. dict_type.remark = form_data.remark
  188. dict_type.update_time = datetime.now()
  189. # 添加到数据库会话并提交
  190. db.commit()
  191. # db.refresh(new_dict_type) # 可选,如果需要刷新实例状态
  192. # 构建并返回响应
  193. return {
  194. "code": 200,
  195. "msg": "操作成功",
  196. "data": None # 根据你的响应示例,data 为 null
  197. }
  198. except Exception as e:
  199. # 处理异常
  200. if str(e)=='':
  201. e=detail
  202. raise HTTPException(status_code=500, detail=str(e))
  203. @router.delete("/type/delete/{dictId}") # 使用 ID 来标识要删除的接口
  204. async def delete_dict_type(
  205. dictId: int,
  206. db: Session = Depends(get_db),
  207. body = Depends(remove_xss_json),
  208. user_id = Depends(valid_access_token)
  209. ):
  210. try:
  211. # 从数据库中获取要删除的 OneShareApiEntity 实例
  212. dict_type = db.query(SysDictType).filter(SysDictType.dict_id == dictId and SysDictType.del_flag != '2').first()
  213. if not dict_type:
  214. detail = "dict_type不存在"
  215. raise HTTPException(status_code=404, detail="dict_type不存在")
  216. dict_type.del_flag = '2'
  217. # 删除实例
  218. # db.delete(api)
  219. db.commit()
  220. # 构建并返回响应
  221. return {
  222. "code": 200,
  223. "msg": "操作成功",
  224. "data": None
  225. }
  226. except Exception as e:
  227. # 处理异常
  228. if str(e)=='':
  229. e=detail
  230. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  231. @router.get('/data/list')
  232. async def get_dict_data_by_type(
  233. dictType: str = Query(None, max_length=100),
  234. pageNum: int = Query(1, gt=0),
  235. pageSize: int = Query(10, gt=0),
  236. db: Session = Depends(get_db),
  237. body = Depends(remove_xss_json),
  238. user_id = Depends(valid_access_token)
  239. ):
  240. try:
  241. # 根据 dict_type 查询字典数据
  242. # dict_data = db.query(SysDictData).filter_by(dict_type=dictType).all()
  243. query = db.query(SysDictData)
  244. # 添加查询条件
  245. # if dictType:
  246. query = query.filter(SysDictData.dict_type.like(f'%{dictType}%'))
  247. query = query.filter(SysDictData.del_flag != '2')
  248. # 计算总记录数
  249. total_count = query.count()
  250. # 计算分页
  251. offset = (pageNum - 1) * pageSize
  252. dict_data = query.offset(offset).limit(pageSize).all()
  253. # 转换为字典
  254. dict_data_list = [
  255. {
  256. "dictCode": d.dict_code,
  257. "dictSort": d.dict_sort,
  258. "dictLabel": d.dict_label,
  259. "dictValue": d.dict_value,
  260. "dictType": d.dict_type,
  261. "cssClass": d.css_class,
  262. "listClass": d.list_class,
  263. "isDefault": d.is_default,
  264. "remark": d.remark,
  265. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  266. }
  267. for d in dict_data
  268. ]
  269. # 构建返回结果
  270. result = {
  271. "total": total_count,
  272. "rows": dict_data_list,
  273. "code": 200,
  274. "msg": "查询成功"
  275. }
  276. return result
  277. except Exception as e:
  278. # 处理异常
  279. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  280. @router.get('/data/{dictCode}')
  281. async def get_dict_data_by_type(
  282. dictCode: str ,
  283. db: Session = Depends(get_db),
  284. body = Depends(remove_xss_json),
  285. user_id = Depends(valid_access_token)
  286. ):
  287. try:
  288. # 根据 dict_type 查询字典数据
  289. # dict_data = db.query(SysDictData).filter_by(dict_type=dictType).all()
  290. query = db.query(SysDictData)
  291. # 添加查询条件
  292. # if dictType:
  293. query = query.filter(SysDictData.dict_code==dictCode)
  294. query = query.filter(SysDictData.del_flag != '2')
  295. d = query.first()
  296. # 转换为字典
  297. dict_data_list = {
  298. "dictCode": d.dict_code,
  299. "dictSort": d.dict_sort,
  300. "dictLabel": d.dict_label,
  301. "dictValue": d.dict_value,
  302. "dictType": d.dict_type,
  303. "cssClass": d.css_class,
  304. "listClass": d.list_class,
  305. "isDefault": d.is_default,
  306. "remark": d.remark,
  307. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  308. }
  309. # 构建返回结果
  310. result = {
  311. "data": dict_data_list,
  312. "code": 200,
  313. "msg": "查询成功"
  314. }
  315. return result
  316. except Exception as e:
  317. # 处理异常
  318. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  319. class DictDataCreateForm(BaseModel):
  320. dictLabel:str
  321. dictValue:str
  322. cssClass:str
  323. listClass:str
  324. dictSort:int
  325. remark:str
  326. dictType:str
  327. @router.post('/data')
  328. async def create_dict_data(
  329. form_data: DictDataCreateForm,
  330. db: Session = Depends(get_db),
  331. body = Depends(remove_xss_json),
  332. user_id = Depends(valid_access_token)
  333. ):
  334. try:
  335. # 创建一个新的 SysDictData 实例
  336. new_dict_data = SysDictData(
  337. dict_sort=form_data.dictSort,
  338. dict_label=form_data.dictLabel,
  339. dict_value=form_data.dictValue,
  340. dict_type=form_data.dictType,
  341. css_class=form_data.cssClass,
  342. list_class=form_data.listClass,
  343. remark=form_data.remark
  344. )
  345. # 添加到会话并提交
  346. db.add(new_dict_data)
  347. db.commit()
  348. db.refresh(new_dict_data) # 可选,如果需要刷新实例状态
  349. # 构建返回结果
  350. result = {
  351. "code": 200,
  352. "msg": "操作成功",
  353. "data": None
  354. }
  355. return result
  356. except Exception as e:
  357. # 处理异常
  358. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  359. @router.get('/data/type/{dict_type}')
  360. async def get_dict_data_by_type(
  361. dict_type: str,
  362. db: Session = Depends(get_db),
  363. body = Depends(remove_xss_json),
  364. user_id = Depends(valid_access_token)
  365. ):
  366. try:
  367. # 根据 dict_type 查询字典数据
  368. query = db.query(SysDictData)
  369. query = query.filter(SysDictData.dict_type==dict_type)
  370. query = query.filter(SysDictData.del_flag != '2')
  371. # dict_data = db.query(SysDictData).filter_by(dict_type==dict_type and del_flag != '2').all()
  372. dict_data = query.all()
  373. # 将模型转换为字典
  374. dict_data_list = [
  375. {
  376. "dictCode": d.dict_code,
  377. "dictSort": d.dict_sort,
  378. "dictLabel": d.dict_label,
  379. "dictValue": d.dict_value,
  380. "dictType": d.dict_type,
  381. "cssClass": d.css_class,
  382. "listClass": d.list_class,
  383. "isDefault": d.is_default,
  384. "remark": d.remark,
  385. "createTime": d.create_time.strftime('%Y-%m-%d %H:%M:%S') if d.create_time else ''
  386. }
  387. for d in dict_data
  388. ]
  389. # 构建返回结果
  390. result = {
  391. "code": 200,
  392. "msg": "操作成功",
  393. "data": dict_data_list
  394. }
  395. return result
  396. except Exception as e:
  397. # 处理异常
  398. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  399. class DictDataUpdataForm(BaseModel):
  400. dictCode:str
  401. dictLabel:str= None
  402. dictValue:str= None
  403. cssClass:str= None
  404. listClass:str= None
  405. dictSort:int= None
  406. remark:str= None
  407. dictType:str = None
  408. isDefault:str = None
  409. @router.put("/data")
  410. async def updata_dict_type(
  411. form_data: DictDataUpdataForm,
  412. db: Session = Depends(get_db),
  413. body = Depends(remove_xss_json),
  414. user_id = Depends(valid_access_token)
  415. ):
  416. try:
  417. # 从请求数据创建一个新的 SysDictType 实例
  418. query = db.query(SysDictData)
  419. query = query.filter(SysDictData.dict_code == form_data.dictCode)
  420. query = query.filter(SysDictData.del_flag != '2')
  421. # query = db.query(SysDictData).filter(SysDictData.dict_code == form_data.dictCode)
  422. # query = db.query(SysDictData).filter(SysDictData.del_flag != '2')
  423. dict_data = query.first()
  424. if not dict_data:
  425. detail = "dict_data不存在"
  426. raise HTTPException(status_code=404, detail="dict_data不存在")
  427. if form_data.dictSort:
  428. dict_data.dict_sort = form_data.dictSort
  429. if form_data.dictLabel:
  430. dict_data.dict_label = form_data.dictLabel
  431. if form_data.dictValue:
  432. dict_data.dict_value = form_data.dictValue
  433. if form_data.dictType:
  434. dict_data.dict_type = form_data.dictType
  435. if form_data.cssClass:
  436. dict_data.css_class = form_data.cssClass
  437. if form_data.listClass:
  438. dict_data.list_class = form_data.listClass
  439. if form_data.remark:
  440. dict_data.remark = form_data.remark
  441. if form_data.isDefault:
  442. dict_data.is_default = form_data.isDefault
  443. # 添加到数据库会话并提交
  444. db.commit()
  445. # db.refresh(new_dict_type) # 可选,如果需要刷新实例状态
  446. # 构建并返回响应
  447. return {
  448. "code": 200,
  449. "msg": "操作成功",
  450. "data": None # 根据你的响应示例,data 为 null
  451. }
  452. except Exception as e:
  453. # 处理异常
  454. if str(e)=='':
  455. e=detail
  456. raise HTTPException(status_code=500, detail=str(e))
  457. @router.delete("/data/delete/{dictCode}") # 使用 ID 来标识要删除的接口
  458. async def delete_dict_data(
  459. dictCode: str,
  460. db: Session = Depends(get_db),
  461. body = Depends(remove_xss_json),
  462. user_id = Depends(valid_access_token)
  463. ):
  464. try:
  465. # 从数据库中获取要删除的 OneShareApiEntity 实例
  466. query = db.query(SysDictData)
  467. query = query.filter(SysDictData.dict_code == dictCode)
  468. query = query.filter(SysDictData.del_flag != '2')
  469. dict_data = query.first()
  470. # dict_data = db.query(SysDictData).filter(SysDictData.dict_code == dictCode and SysDictData.del_flag != '2').first()
  471. if not dict_data:
  472. detail = "dict_data不存在"
  473. raise HTTPException(status_code=404, detail="dict_data不存在")
  474. dict_data.del_flag = '2'
  475. # 删除实例
  476. # db.delete(api)
  477. db.commit()
  478. # 构建并返回响应
  479. return {
  480. "code": 200,
  481. "msg": "操作成功",
  482. "data": None
  483. }
  484. except Exception as e:
  485. # 处理异常
  486. if str(e)=='':
  487. e=detail
  488. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))
  489. @router.delete("/data/{dictCode}") # 使用 ID 来标识要删除的接口
  490. async def delete_dict_data(
  491. dictCode: str,
  492. db: Session = Depends(get_db),
  493. body = Depends(remove_xss_json),
  494. user_id = Depends(valid_access_token)
  495. ):
  496. try:
  497. # 从数据库中获取要删除的 OneShareApiEntity 实例
  498. query = db.query(SysDictData)
  499. query = query.filter(SysDictData.del_flag != '2')
  500. dictCodeList = dictCode.split(',')
  501. query = query.filter(SysDictData.dict_code.in_(dictCodeList))
  502. dict_data = query.all()
  503. # dict_data = db.query(SysDictData).filter(SysDictData.dict_code == dictCode and SysDictData.del_flag != '2').first()
  504. if not dict_data:
  505. return JSONResponse(content={"msg":"dict不存在"},status_code=404)
  506. # detail = "dict不存在"
  507. # raise HTTPException(status_code=404, detail="dict不存在")
  508. for dict in dict_data:
  509. dict.del_flag = '2'
  510. # 删除实例
  511. # db.delete(api)
  512. db.commit()
  513. # 构建并返回响应
  514. return {
  515. "code": 200,
  516. "msg": "操作成功",
  517. "data": None
  518. }
  519. except Exception as e:
  520. # 处理异常
  521. traceback.print_exc()
  522. raise HTTPException(status_code=status.HTTP_500_INTERNAL_SERVER_ERROR, detail=str(e))