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

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