Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

tool_files.py 2.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. from flask import Response
  2. from flask_restful import Resource, reqparse # type: ignore
  3. from werkzeug.exceptions import Forbidden, NotFound
  4. from controllers.files import api
  5. from controllers.files.error import UnsupportedFileTypeError
  6. from core.tools.signature import verify_tool_file_signature
  7. from core.tools.tool_file_manager import ToolFileManager
  8. from models import db as global_db
  9. class ToolFilePreviewApi(Resource):
  10. def get(self, file_id, extension):
  11. file_id = str(file_id)
  12. parser = reqparse.RequestParser()
  13. parser.add_argument("timestamp", type=str, required=True, location="args")
  14. parser.add_argument("nonce", type=str, required=True, location="args")
  15. parser.add_argument("sign", type=str, required=True, location="args")
  16. parser.add_argument("as_attachment", type=bool, required=False, default=False, location="args")
  17. args = parser.parse_args()
  18. if not verify_tool_file_signature(
  19. file_id=file_id, timestamp=args["timestamp"], nonce=args["nonce"], sign=args["sign"]
  20. ):
  21. raise Forbidden("Invalid request.")
  22. try:
  23. tool_file_manager = ToolFileManager(engine=global_db.engine)
  24. stream, tool_file = tool_file_manager.get_file_generator_by_tool_file_id(
  25. file_id,
  26. )
  27. if not stream or not tool_file:
  28. raise NotFound("file is not found")
  29. except Exception:
  30. raise UnsupportedFileTypeError()
  31. response = Response(
  32. stream,
  33. mimetype=tool_file.mimetype,
  34. direct_passthrough=True,
  35. headers={},
  36. )
  37. if tool_file.size > 0:
  38. response.headers["Content-Length"] = str(tool_file.size)
  39. if args["as_attachment"]:
  40. response.headers["Content-Disposition"] = f"attachment; filename={tool_file.name}"
  41. return response
  42. api.add_resource(ToolFilePreviewApi, "/files/tools/<uuid:file_id>.<string:extension>")