files.py 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. from flask import request
  2. from flask_login import current_user
  3. from flask_restful import Resource, marshal_with
  4. import services
  5. from configs import dify_config
  6. from constants import DOCUMENT_EXTENSIONS
  7. from controllers.common.errors import FilenameNotExistsError
  8. from controllers.console.wraps import (
  9. account_initialization_required,
  10. cloud_edition_billing_resource_check,
  11. setup_required,
  12. )
  13. from fields.file_fields import file_fields, upload_config_fields
  14. from libs.login import login_required
  15. from services.file_service import FileService
  16. from .error import (
  17. FileTooLargeError,
  18. NoFileUploadedError,
  19. TooManyFilesError,
  20. UnsupportedFileTypeError,
  21. )
  22. PREVIEW_WORDS_LIMIT = 3000
  23. class FileApi(Resource):
  24. @setup_required
  25. @login_required
  26. @account_initialization_required
  27. @marshal_with(upload_config_fields)
  28. def get(self):
  29. return {
  30. "file_size_limit": dify_config.UPLOAD_FILE_SIZE_LIMIT,
  31. "batch_count_limit": dify_config.UPLOAD_FILE_BATCH_LIMIT,
  32. "image_file_size_limit": dify_config.UPLOAD_IMAGE_FILE_SIZE_LIMIT,
  33. "video_file_size_limit": dify_config.UPLOAD_VIDEO_FILE_SIZE_LIMIT,
  34. "audio_file_size_limit": dify_config.UPLOAD_AUDIO_FILE_SIZE_LIMIT,
  35. "workflow_file_upload_limit": dify_config.WORKFLOW_FILE_UPLOAD_LIMIT,
  36. }, 200
  37. @setup_required
  38. @login_required
  39. @account_initialization_required
  40. @marshal_with(file_fields)
  41. @cloud_edition_billing_resource_check("documents")
  42. def post(self):
  43. file = request.files["file"]
  44. source = request.form.get("source")
  45. if "file" not in request.files:
  46. raise NoFileUploadedError()
  47. if len(request.files) > 1:
  48. raise TooManyFilesError()
  49. if not file.filename:
  50. raise FilenameNotExistsError
  51. if source not in ("datasets", None):
  52. source = None
  53. try:
  54. upload_file = FileService.upload_file(
  55. filename=file.filename,
  56. content=file.read(),
  57. mimetype=file.mimetype,
  58. user=current_user,
  59. source=source,
  60. )
  61. except services.errors.file.FileTooLargeError as file_too_large_error:
  62. raise FileTooLargeError(file_too_large_error.description)
  63. except services.errors.file.UnsupportedFileTypeError:
  64. raise UnsupportedFileTypeError()
  65. return upload_file, 201
  66. class FilePreviewApi(Resource):
  67. @setup_required
  68. @login_required
  69. @account_initialization_required
  70. def get(self, file_id):
  71. file_id = str(file_id)
  72. text = FileService.get_file_preview(file_id)
  73. return {"content": text}
  74. class FileSupportTypeApi(Resource):
  75. @setup_required
  76. @login_required
  77. @account_initialization_required
  78. def get(self):
  79. return {"allowed_extensions": DOCUMENT_EXTENSIONS}