api.py 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. from natsort.natsort import order_by_index
  2. from models import *
  3. import requests
  4. import json
  5. from logger import logger
  6. from serial.tools import list_ports
  7. from utils.hlm_http_request import forward_request
  8. from sockets.socket_client import socket_manager
  9. from mcu.DeviceControl import DeviceControl
  10. import time
  11. # from service.base_deal import BaseDealImage
  12. from databases import DeviceConfig,SqlQuery,CRUD
  13. @app.get("/")
  14. async def index():
  15. # await socket_manager.send_message(msg="测试")
  16. return {"message": "Hello World"}
  17. @app.get("/send_test")
  18. async def index():
  19. data = {"data1":1,"data2":2,"data3":3,"data4":4}
  20. await socket_manager.send_message(msg="测试",data=data)
  21. return {"message": "Hello World"}
  22. @app.get("/scan_serials", description="扫描可用的设备端口")
  23. async def scanSerials():
  24. """扫描串口"""
  25. ports = list_ports.comports()
  26. print("Scanning", ports)
  27. return {"message": "Hello World"}
  28. @app.get("/test_conndevice")
  29. def test_conndevice():
  30. device_control = DeviceControl()
  31. p_list = []
  32. temp_ports_dict = {}
  33. # while 1:
  34. time.sleep(1)
  35. ports_dict = device_control.scan_serial_port()
  36. temp_ports_dict = ports_dict
  37. if not ports_dict:
  38. # 全部清空 移除所有串口
  39. if p_list:
  40. _p = p_list.pop()
  41. device_control.remove_port(_p)
  42. # continue
  43. if ports_dict:
  44. # print(plist)
  45. for index, _i in enumerate(p_list):
  46. if _i not in ports_dict:
  47. _p = p_list.pop(index)
  48. device_control.remove_port(_p)
  49. for _port_name, _port_value in ports_dict.items():
  50. if _port_name not in p_list:
  51. try:
  52. p_list.append(_port_name)
  53. device_control.add_port_by_linkage(_port_name)
  54. except BaseException as e:
  55. print(e.__traceback__.tb_frame.f_globals["__file__"]) # 发生异常所在的文件
  56. print(e.__traceback__.tb_lineno) # 发生异常所在的行数
  57. print("串口不存在{} {}".format(_port_name, e))
  58. # threading.Thread(target=self.add_port, args=(_port_name, _port_value)).start()
  59. # self.add_port(_p)
  60. @app.api_route(
  61. "/forward_request", methods=["GET", "POST"], description="代理转发hlm项目得请求"
  62. )
  63. async def forwardRequest(request: HlmForwardRequest):
  64. """
  65. 转发HTTP请求到目标URL
  66. :param request: FastAPI Request对象
  67. :return: 目标接口的响应
  68. """
  69. try:
  70. if request.method == "GET":
  71. params = request.query_params
  72. elif request.method == "POST":
  73. params = json.dump(request.query_params)
  74. else:
  75. raise UnicornException("仅支持GET和POST方法")
  76. target_url = request.target_url
  77. method = request.method.upper()
  78. headers = request.headers
  79. if not target_url:
  80. raise UnicornException("目标url地址不能为空")
  81. # 调用 hlm_http_request 中的 forward_request 函数
  82. response = forward_request(
  83. target_url, params=params, method=method, headers=headers
  84. )
  85. return response
  86. except requests.RequestException as e:
  87. raise UnicornException(e)
  88. except Exception as e:
  89. raise UnicornException(e)
  90. # @app.post('/handle_detail')
  91. # async def handle_detail(request: Request):
  92. #
  93. # image_dir = "{}/data".format(os.getcwd())
  94. # baseDealImage = BaseDealImage(image_dir=image_dir)
  95. # result = baseDealImage.dealMoveImage(image_dir=image_dir, callback_func=None)
  96. #
  97. #
  98. # params = json.dump(request.query_params)
  99. # #{'image_dir': 'D:/phpstudy_pro/WWW/auto_photo/output/2024-11-18', 'image_order': '俯视,侧视,后跟,鞋底,内里', 'is_check_number': True, 'resize_image_view': '后跟', 'cutout_mode': '1', 'logo_path': '', 'special_goods_art_no_folder_line': '', 'is_use_excel': True, 'excel_path': '', 'is_check_color_is_all': True, 'assigned_page_dict': {}, 'temp_class': {'huilima-2': <class 'detail_template.huilima.detail_huilima2.DetailPicGet'>, 'huilima-3': <class 'detail_template.huilima.detail_huilima3.DetailPicGet'>, 'huilima-4': <class 'detail_template.huilima.detail_huilima4.DetailPicGet'>, 'huilima-1': <class 'detail_template.huilima.detail_huilima1.DetailPicGet'>}, 'temp_name': 'huilima-2', 'temp_name_list': ['huilima-2', 'huilima-3', 'huilima-4', 'huilima-1'], 'target_error_folder': 'D:/phpstudy_pro/WWW/auto_photo/output/2024-11-18/软件-生成详情错误'}
  100. #
  101. # config_data = {
  102. # 'image_dir': params['image_dir'],
  103. # 'image_order': params['image_order'],
  104. # 'is_check_number': params['is_check_number'],
  105. # 'resize_image_view': params['resize_image_view'],
  106. # 'cutout_mode': '1',
  107. # 'logo_path': params['logo_path'],
  108. # 'special_goods_art_no_folder_line': '',
  109. # 'is_use_excel': params['is_use_excel'],
  110. # 'excel_path': params['excel_path'],
  111. # 'is_check_color_is_all': params['is_check_color_is_all'],
  112. # 'assigned_page_dict': {},
  113. # 'temp_class': {
  114. # 'huilima-2': 'detail_template.huilima.detail_huilima2.DetailPicGet',
  115. # 'huilima-3': 'detail_template.huilima.detail_huilima3.DetailPicGet',
  116. # 'huilima-4': 'detail_template.huilima.detail_huilima4.DetailPicGet',
  117. # 'huilima-1': 'detail_template.huilima.detail_huilima1.DetailPicGet'
  118. # },
  119. # 'temp_name': 'huilima-2',
  120. # 'temp_name_list': ['huilima-2', 'huilima-3', 'huilima-4', 'huilima-1'],
  121. # 'target_error_folder': 'D:/phpstudy_pro/WWW/auto_photo/output/2024-11-18/软件-生成详情错误'
  122. # }
  123. @app.post("/get_device_configs", description="获取可执行程序命令列表")
  124. def get_device_configs(params: ModelGetDeviceConfig):
  125. mode_type = params.mode_type
  126. session = SqlQuery()
  127. configModel = CRUD(DeviceConfig)
  128. configList = configModel.read_all(
  129. session, conditions={"mode_type": mode_type}, order_by="action_index", ascending=True
  130. )
  131. return {"code": 0, "msg": "", "data": {"list": configList}}
  132. @app.post("/device_config_detail", description="获取可执行程序详情")
  133. def get_device_configs(params: ModelGetDeviceConfigDetail):
  134. action_id = params.id
  135. session = SqlQuery()
  136. configModel = CRUD(DeviceConfig)
  137. model = configModel.read(session, conditions={"id": action_id})
  138. if model == None:
  139. return {"code": 1, "msg": "数据不存在", "data": None}
  140. return {"code": 0, "msg": "", "data": model}
  141. @app.post("/remove_config", description="删除一条可执行命令")
  142. def get_device_configs(params: ModelGetDeviceConfigDetail):
  143. action_id = params.id
  144. session = SqlQuery()
  145. configModel = CRUD(DeviceConfig)
  146. model = configModel.read(session, conditions={"id": action_id})
  147. if model == None:
  148. return {"code": 1, "msg": "数据不存在", "data": None}
  149. configModel.delete(session, obj_id=action_id)
  150. return {"code": 0, "msg": "删除成功", "data": None}
  151. @app.post("/save_device_config", description="创建或修改一条可执行命令")
  152. def save_device_config(params: SaveDeviceConfig):
  153. action_id = params.id
  154. session = SqlQuery()
  155. deviceConfig = CRUD(DeviceConfig)
  156. if action_id == None or action_id == 0:
  157. # 走新增逻辑
  158. params.id = None
  159. save_device_config = deviceConfig.create(session, obj_in=params)
  160. else:
  161. model = deviceConfig.read(session, conditions={"id": action_id})
  162. if model == None:
  163. return {"code": 1, "msg": "数据不存在", "data": None}
  164. # 走编辑逻辑
  165. kwargs = params.__dict__
  166. save_device_config = deviceConfig.update(session, obj_id=action_id, **kwargs)
  167. return {"code": 0, "msg": "操作成功", "data": save_device_config}
  168. @app.post("/reset_config", description="创建或修改一条可执行命令")
  169. def reset_config(params: ModelGetDeviceConfig):
  170. mode_type = params.mode_type
  171. if mode_type == None or mode_type == "":
  172. return {"code": 1, "msg": "参数错误", "data": None}
  173. session = SqlQuery()
  174. deviceConfig = CRUD(DeviceConfig)
  175. res = deviceConfig.deleteConditions(session, conditions={"mode_type": mode_type})
  176. if res is False:
  177. return {"code": 1, "msg": "操作失败", "data": None}
  178. actions = json.load(open("action.json", encoding="utf-8"))
  179. act = []
  180. for item in actions:
  181. if item.get("mode_type") == mode_type:
  182. act.append(item)
  183. batch_insert_device_configs(session, act)
  184. return {"code": 0, "msg": "操作成功", "data": None}