files.py 3.1 KB

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