routes.py 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283
  1. from flask import request
  2. from app import app
  3. from app.models.result import success, failed
  4. from app.routes.graph_routes import MyEncoder
  5. from app.core.data_model import model as model_functions
  6. import json
  7. # 2024.09.11 数据模型血缘关系(传入数据资源id)
  8. @app.route('/model/data/relation', methods=['POST'])
  9. def data_model_relation():
  10. try:
  11. # 传入请求参数
  12. receiver = request.get_json()
  13. resource_ids = receiver['id'] # 给定一个数据资源的id
  14. response_data = model_functions.handle_model_relation(resource_ids)
  15. res = success(response_data, "success")
  16. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  17. except Exception as e:
  18. res = failed({}, {"error": f"{e}"})
  19. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  20. # 传入一个数据资源的id,返回多个有血缘关系的数据资源
  21. @app.route('/model/relatives/relation', methods=['POST'])
  22. def data_relatives_relation():
  23. try:
  24. # 传入请求参数
  25. receiver = request.get_json()
  26. page = int(receiver.get('current', 1))
  27. page_size = int(receiver.get('size', 10))
  28. id = receiver['id']
  29. name_filter = receiver.get('name', None)
  30. category = receiver.get('category', None)
  31. time = receiver.get('time', None)
  32. # 计算跳过的记录的数量
  33. skip_count = (page - 1) * page_size
  34. data, total = model_functions.model_resource_list(skip_count, page_size, name_filter, id, category, time)
  35. response_data = {'records': data, 'total': total, 'size': page_size, 'current': page}
  36. res = success(response_data, "success")
  37. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  38. except Exception as e:
  39. res = failed({}, {"error": f"{e}"})
  40. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  41. # DDL数据模型保存
  42. @app.route('/data/model/save', methods=['POST'])
  43. def data_model_save():
  44. # 传入请求参数
  45. receiver = request.get_json()
  46. data_model = receiver['name']
  47. id_list = receiver['id_list']
  48. # resource_id和meta_id构成json格式
  49. result = json.dumps(id_list, ensure_ascii=False)
  50. try:
  51. # 从DDL中选取保存数据模型
  52. result_list = [receiver['en_name']]
  53. id, data_model_node = model_functions.handle_data_model(data_model, result_list, result, receiver)
  54. model_functions.handle_no_meta_data_model(id_list, receiver, data_model_node)
  55. model_functions.calculate_model_level(id)
  56. res = success({}, "success")
  57. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  58. except Exception as e:
  59. res = failed({}, {"error": f"{e}"})
  60. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  61. # 新建数据模型请求接口(从数据资源中选取)
  62. @app.route('/model/data/search', methods=['POST'])
  63. def data_model_search():
  64. # 传入请求参数
  65. receiver = request.get_json()
  66. data_model = receiver['name']
  67. id_list = receiver['id_list']
  68. # resource_id和meta_id构成json格式
  69. result = json.dumps(id_list, ensure_ascii=False)
  70. try:
  71. from app.core.meta_data import translate_and_parse
  72. result_list = translate_and_parse(data_model)
  73. id, data_model_node = model_functions.handle_data_model(data_model, result_list, result, receiver)
  74. if id_list:
  75. model_functions.resource_handle_meta_data_model(id_list, id)
  76. model_functions.calculate_model_level(id)
  77. res = success({}, "success")
  78. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  79. except Exception as e:
  80. res = failed({}, {"error": f"{e}"})
  81. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  82. # 新建数据模型请求接口(从数据模型中选取)
  83. @app.route('/model/data/model/add', methods=['POST'])
  84. def data_model_model_add():
  85. # 传入请求参数
  86. receiver = request.get_json()
  87. data_model = receiver['name']
  88. id_list = receiver['id_list']
  89. # model_id和meta_id构成json格式
  90. result = json.dumps(id_list, ensure_ascii=False)
  91. try:
  92. from app.core.meta_data import translate_and_parse
  93. result_list = translate_and_parse(data_model)
  94. id, data_model_node = model_functions.handle_data_model(data_model, result_list, result, receiver)
  95. model_functions.model_handle_meta_data_model(id_list, id)
  96. model_functions.calculate_model_level(id)
  97. res = success({}, "success")
  98. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  99. except Exception as e:
  100. res = failed({}, {"error": f"{e}"})
  101. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  102. # 数据模型-详情接口
  103. @app.route('/data/model/detail', methods=['POST'])
  104. def data_model_detail():
  105. try:
  106. # 传入请求参数
  107. receiver = request.get_json()
  108. id = int(receiver.get('id'))
  109. response_data = model_functions.handle_id_model(id)
  110. res = success(response_data, "success")
  111. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  112. except Exception as e:
  113. res = failed({}, {"error": f"{e}"})
  114. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  115. # 删除数据模型
  116. @app.route('/data/model/delete', methods=['POST'])
  117. def data_model_delete():
  118. try:
  119. # 传入请求参数
  120. receiver = request.get_json()
  121. id = receiver['id']
  122. # 首先删除数据模型节点
  123. from app.services.neo4j_driver import neo4j_driver
  124. query = """
  125. MATCH (n:data_model) where id(n) = $nodeId
  126. detach delete n
  127. """
  128. with neo4j_driver.get_session() as session:
  129. session.run(query, nodeId=id)
  130. res = success({}, "success")
  131. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  132. except Exception as e:
  133. res = failed({}, {"error": f"{e}"})
  134. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  135. # 列表 数据模型查询
  136. @app.route('/data/model/list', methods=['POST'])
  137. def data_model_list():
  138. try:
  139. # 传入请求参数
  140. receiver = request.get_json()
  141. page = int(receiver.get('current', 1))
  142. page_size = int(receiver.get('size', 10))
  143. name_filter = receiver.get('name', None)
  144. en_name_filter = receiver.get('en_name', None)
  145. category = receiver.get('category', None)
  146. tag = receiver.get('tag', None)
  147. level = receiver.get('level', None)
  148. # 计算跳过的记录的数量
  149. skip_count = (page - 1) * page_size
  150. data, total = model_functions.model_list(skip_count, page_size, en_name_filter,
  151. name_filter, category, tag, level)
  152. response_data = {'records': data, 'total': total, 'size': page_size, 'current': page}
  153. res = success(response_data, "success")
  154. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  155. except Exception as e:
  156. res = failed({}, {"error": f"{e}"})
  157. return json.dumps(res, ensure_ascii=False, cls=MyEncoder)
  158. # 数据模型的图谱(血缘关系Kinship+影响关系Impact+所有关系all)
  159. @app.route('/data/model/graph/all', methods=['POST'])
  160. def data_model_graph_all():
  161. try:
  162. # 传入请求参数
  163. receiver = request.get_json()
  164. nodeid = receiver['id']
  165. type = receiver['type'] # kinship/impact/all
  166. meta = receiver['meta'] # true/false 是否返回元数据
  167. if type == 'kinship':
  168. result = model_functions.model_kinship_graph(nodeid, meta)
  169. elif type == 'impact':
  170. result = model_functions.model_impact_graph(nodeid, meta)
  171. else:
  172. result = model_functions.model_all_graph(nodeid, meta)
  173. return json.dumps(success(result, "success"), ensure_ascii=False, cls=MyEncoder)
  174. except Exception as e:
  175. return json.dumps(failed({}, str(e)), ensure_ascii=False, cls=MyEncoder)
  176. # 数据模型的列表图谱
  177. @app.route('/data/model/list/graph', methods=['POST'])
  178. def data_model_list_graph():
  179. try:
  180. # 传入请求参数
  181. receiver = request.get_json()
  182. if not receiver or 'tag' not in receiver:
  183. raise ValueError("Missing 'tag' parameter in request body")
  184. nodeid = receiver['tag']
  185. # 构建查询条件
  186. params = {}
  187. where_clause = ""
  188. if nodeid is not None:
  189. where_clause = "MATCH (n)-[:label]->(la) WHERE id(la) = $nodeId"
  190. params['nodeId'] = nodeid
  191. from app.services.neo4j_driver import neo4j_driver
  192. query = f"""
  193. MATCH (n:data_model)
  194. OPTIONAL MATCH (n)-[:child]->(child)
  195. {where_clause}
  196. WITH
  197. collect(DISTINCT {{id: toString(id(n)), text: n.name, type: split(labels(n)[0], '_')[1]}}) AS nodes,
  198. collect(DISTINCT {{id: toString(id(child)), text: child.name, type: split(labels(child)[0], '_')[1]}}) AS nodes2,
  199. collect(DISTINCT {{from: toString(id(n)), to: toString(id(child)), text: '下级'}}) AS lines
  200. RETURN nodes + nodes2 AS nodes, lines AS lines
  201. """
  202. with neo4j_driver.get_session() as session:
  203. result = session.run(query, **params)
  204. data = result.data()
  205. if len(data) > 0:
  206. # 过滤掉空节点(即 id 为 null 的节点)
  207. nodes = []
  208. for node in data[0]['nodes']:
  209. if node['id'] != 'null':
  210. nodes.append(node)
  211. lines = data[0]['lines']
  212. response_data = {
  213. 'nodes': nodes,
  214. 'edges': lines
  215. }
  216. return json.dumps(success(response_data, "success"), ensure_ascii=False, cls=MyEncoder)
  217. else:
  218. return json.dumps(success({'nodes': [], 'edges': []}, "No data found"), ensure_ascii=False, cls=MyEncoder)
  219. except Exception as e:
  220. return json.dumps(failed({}, str(e)), ensure_ascii=False, cls=MyEncoder)
  221. # 更新数据模型
  222. @app.route('/data/model/update', methods=['POST'])
  223. def data_model_update():
  224. try:
  225. # 传入请求参数
  226. receiver = request.get_json()
  227. result = model_functions.data_model_edit(receiver)
  228. return json.dumps(success(result, "success"), ensure_ascii=False, cls=MyEncoder)
  229. except Exception as e:
  230. return json.dumps(failed({}, str(e)), ensure_ascii=False, cls=MyEncoder)