remote_files.py 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. import urllib.parse
  2. from flask_restful import marshal_with, reqparse
  3. from controllers.common import helpers
  4. from controllers.web.wraps import WebApiResource
  5. from core.file import helpers as file_helpers
  6. from core.helper import ssrf_proxy
  7. from fields.file_fields import file_fields_with_signed_url, remote_file_info_fields
  8. from services.file_service import FileService
  9. class RemoteFileInfoApi(WebApiResource):
  10. @marshal_with(remote_file_info_fields)
  11. def get(self, url):
  12. decoded_url = urllib.parse.unquote(url)
  13. try:
  14. response = ssrf_proxy.head(decoded_url)
  15. return {
  16. "file_type": response.headers.get("Content-Type", "application/octet-stream"),
  17. "file_length": int(response.headers.get("Content-Length", -1)),
  18. }
  19. except Exception as e:
  20. return {"error": str(e)}, 400
  21. class RemoteFileUploadApi(WebApiResource):
  22. @marshal_with(file_fields_with_signed_url)
  23. def post(self, app_model, end_user): # Add app_model and end_user parameters
  24. parser = reqparse.RequestParser()
  25. parser.add_argument("url", type=str, required=True, help="URL is required")
  26. args = parser.parse_args()
  27. url = args["url"]
  28. response = ssrf_proxy.head(url)
  29. response.raise_for_status()
  30. file_info = helpers.guess_file_info_from_response(response)
  31. if not FileService.is_file_size_within_limit(extension=file_info.extension, file_size=file_info.size):
  32. return {"error": "File size exceeded"}, 400
  33. response = ssrf_proxy.get(url)
  34. response.raise_for_status()
  35. content = response.content
  36. try:
  37. upload_file = FileService.upload_file(
  38. filename=file_info.filename,
  39. content=content,
  40. mimetype=file_info.mimetype,
  41. user=end_user, # Use end_user instead of current_user
  42. source_url=url,
  43. )
  44. except Exception as e:
  45. return {"error": str(e)}, 400
  46. return {
  47. "id": upload_file.id,
  48. "name": upload_file.name,
  49. "size": upload_file.size,
  50. "extension": upload_file.extension,
  51. "url": file_helpers.get_signed_file_url(upload_file_id=upload_file.id),
  52. "mime_type": upload_file.mime_type,
  53. "created_by": upload_file.created_by,
  54. "created_at": upload_file.created_at,
  55. }, 201