您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符

ops_trace.py 5.8KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. from flask_restx import Resource, fields, reqparse
  2. from werkzeug.exceptions import BadRequest
  3. from controllers.console import api, console_ns
  4. from controllers.console.app.error import TracingConfigCheckError, TracingConfigIsExist, TracingConfigNotExist
  5. from controllers.console.wraps import account_initialization_required, setup_required
  6. from libs.login import login_required
  7. from services.ops_service import OpsService
  8. @console_ns.route("/apps/<uuid:app_id>/trace-config")
  9. class TraceAppConfigApi(Resource):
  10. """
  11. Manage trace app configurations
  12. """
  13. @api.doc("get_trace_app_config")
  14. @api.doc(description="Get tracing configuration for an application")
  15. @api.doc(params={"app_id": "Application ID"})
  16. @api.expect(
  17. api.parser().add_argument(
  18. "tracing_provider", type=str, required=True, location="args", help="Tracing provider name"
  19. )
  20. )
  21. @api.response(
  22. 200, "Tracing configuration retrieved successfully", fields.Raw(description="Tracing configuration data")
  23. )
  24. @api.response(400, "Invalid request parameters")
  25. @setup_required
  26. @login_required
  27. @account_initialization_required
  28. def get(self, app_id):
  29. parser = reqparse.RequestParser()
  30. parser.add_argument("tracing_provider", type=str, required=True, location="args")
  31. args = parser.parse_args()
  32. try:
  33. trace_config = OpsService.get_tracing_app_config(app_id=app_id, tracing_provider=args["tracing_provider"])
  34. if not trace_config:
  35. return {"has_not_configured": True}
  36. return trace_config
  37. except Exception as e:
  38. raise BadRequest(str(e))
  39. @api.doc("create_trace_app_config")
  40. @api.doc(description="Create a new tracing configuration for an application")
  41. @api.doc(params={"app_id": "Application ID"})
  42. @api.expect(
  43. api.model(
  44. "TraceConfigCreateRequest",
  45. {
  46. "tracing_provider": fields.String(required=True, description="Tracing provider name"),
  47. "tracing_config": fields.Raw(required=True, description="Tracing configuration data"),
  48. },
  49. )
  50. )
  51. @api.response(
  52. 201, "Tracing configuration created successfully", fields.Raw(description="Created configuration data")
  53. )
  54. @api.response(400, "Invalid request parameters or configuration already exists")
  55. @setup_required
  56. @login_required
  57. @account_initialization_required
  58. def post(self, app_id):
  59. """Create a new trace app configuration"""
  60. parser = reqparse.RequestParser()
  61. parser.add_argument("tracing_provider", type=str, required=True, location="json")
  62. parser.add_argument("tracing_config", type=dict, required=True, location="json")
  63. args = parser.parse_args()
  64. try:
  65. result = OpsService.create_tracing_app_config(
  66. app_id=app_id, tracing_provider=args["tracing_provider"], tracing_config=args["tracing_config"]
  67. )
  68. if not result:
  69. raise TracingConfigIsExist()
  70. if result.get("error"):
  71. raise TracingConfigCheckError()
  72. return result
  73. except Exception as e:
  74. raise BadRequest(str(e))
  75. @api.doc("update_trace_app_config")
  76. @api.doc(description="Update an existing tracing configuration for an application")
  77. @api.doc(params={"app_id": "Application ID"})
  78. @api.expect(
  79. api.model(
  80. "TraceConfigUpdateRequest",
  81. {
  82. "tracing_provider": fields.String(required=True, description="Tracing provider name"),
  83. "tracing_config": fields.Raw(required=True, description="Updated tracing configuration data"),
  84. },
  85. )
  86. )
  87. @api.response(200, "Tracing configuration updated successfully", fields.Raw(description="Success response"))
  88. @api.response(400, "Invalid request parameters or configuration not found")
  89. @setup_required
  90. @login_required
  91. @account_initialization_required
  92. def patch(self, app_id):
  93. """Update an existing trace app configuration"""
  94. parser = reqparse.RequestParser()
  95. parser.add_argument("tracing_provider", type=str, required=True, location="json")
  96. parser.add_argument("tracing_config", type=dict, required=True, location="json")
  97. args = parser.parse_args()
  98. try:
  99. result = OpsService.update_tracing_app_config(
  100. app_id=app_id, tracing_provider=args["tracing_provider"], tracing_config=args["tracing_config"]
  101. )
  102. if not result:
  103. raise TracingConfigNotExist()
  104. return {"result": "success"}
  105. except Exception as e:
  106. raise BadRequest(str(e))
  107. @api.doc("delete_trace_app_config")
  108. @api.doc(description="Delete an existing tracing configuration for an application")
  109. @api.doc(params={"app_id": "Application ID"})
  110. @api.expect(
  111. api.parser().add_argument(
  112. "tracing_provider", type=str, required=True, location="args", help="Tracing provider name"
  113. )
  114. )
  115. @api.response(204, "Tracing configuration deleted successfully")
  116. @api.response(400, "Invalid request parameters or configuration not found")
  117. @setup_required
  118. @login_required
  119. @account_initialization_required
  120. def delete(self, app_id):
  121. """Delete an existing trace app configuration"""
  122. parser = reqparse.RequestParser()
  123. parser.add_argument("tracing_provider", type=str, required=True, location="args")
  124. args = parser.parse_args()
  125. try:
  126. result = OpsService.delete_tracing_app_config(app_id=app_id, tracing_provider=args["tracing_provider"])
  127. if not result:
  128. raise TracingConfigNotExist()
  129. return {"result": "success"}, 204
  130. except Exception as e:
  131. raise BadRequest(str(e))