mirror of
https://github.com/langgenius/dify.git
synced 2025-11-13 17:59:59 +00:00
Signed-off-by: -LAN- <laipz8200@outlook.com> Co-authored-by: twwu <twwu@dify.ai> Co-authored-by: crazywoola <100913391+crazywoola@users.noreply.github.com> Co-authored-by: jyong <718720800@qq.com> Co-authored-by: Wu Tianwei <30284043+WTW0313@users.noreply.github.com> Co-authored-by: QuantumGhost <obelisk.reg+git@gmail.com> Co-authored-by: lyzno1 <yuanyouhuilyz@gmail.com> Co-authored-by: quicksand <quicksandzn@gmail.com> Co-authored-by: Jyong <76649700+JohnJyong@users.noreply.github.com> Co-authored-by: lyzno1 <92089059+lyzno1@users.noreply.github.com> Co-authored-by: zxhlyh <jasonapring2015@outlook.com> Co-authored-by: Yongtao Huang <yongtaoh2022@gmail.com> Co-authored-by: autofix-ci[bot] <114827586+autofix-ci[bot]@users.noreply.github.com> Co-authored-by: Joel <iamjoel007@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: nite-knite <nkCoding@gmail.com> Co-authored-by: Hanqing Zhao <sherry9277@gmail.com> Co-authored-by: gemini-code-assist[bot] <176961590+gemini-code-assist[bot]@users.noreply.github.com> Co-authored-by: Harry <xh001x@hotmail.com>
119 lines
3.9 KiB
Python
119 lines
3.9 KiB
Python
from urllib.parse import quote
|
|
|
|
from flask import Response, request
|
|
from flask_restx import Resource, reqparse
|
|
from werkzeug.exceptions import NotFound
|
|
|
|
import services
|
|
from controllers.common.errors import UnsupportedFileTypeError
|
|
from controllers.files import files_ns
|
|
from extensions.ext_database import db
|
|
from services.account_service import TenantService
|
|
from services.file_service import FileService
|
|
|
|
|
|
@files_ns.route("/<uuid:file_id>/image-preview")
|
|
class ImagePreviewApi(Resource):
|
|
"""
|
|
Deprecated
|
|
"""
|
|
|
|
def get(self, file_id):
|
|
file_id = str(file_id)
|
|
|
|
timestamp = request.args.get("timestamp")
|
|
nonce = request.args.get("nonce")
|
|
sign = request.args.get("sign")
|
|
|
|
if not timestamp or not nonce or not sign:
|
|
return {"content": "Invalid request."}, 400
|
|
|
|
try:
|
|
generator, mimetype = FileService(db.engine).get_image_preview(
|
|
file_id=file_id,
|
|
timestamp=timestamp,
|
|
nonce=nonce,
|
|
sign=sign,
|
|
)
|
|
except services.errors.file.UnsupportedFileTypeError:
|
|
raise UnsupportedFileTypeError()
|
|
|
|
return Response(generator, mimetype=mimetype)
|
|
|
|
|
|
@files_ns.route("/<uuid:file_id>/file-preview")
|
|
class FilePreviewApi(Resource):
|
|
def get(self, file_id):
|
|
file_id = str(file_id)
|
|
|
|
parser = reqparse.RequestParser()
|
|
parser.add_argument("timestamp", type=str, required=True, location="args")
|
|
parser.add_argument("nonce", type=str, required=True, location="args")
|
|
parser.add_argument("sign", type=str, required=True, location="args")
|
|
parser.add_argument("as_attachment", type=bool, required=False, default=False, location="args")
|
|
|
|
args = parser.parse_args()
|
|
|
|
if not args["timestamp"] or not args["nonce"] or not args["sign"]:
|
|
return {"content": "Invalid request."}, 400
|
|
|
|
try:
|
|
generator, upload_file = FileService(db.engine).get_file_generator_by_file_id(
|
|
file_id=file_id,
|
|
timestamp=args["timestamp"],
|
|
nonce=args["nonce"],
|
|
sign=args["sign"],
|
|
)
|
|
except services.errors.file.UnsupportedFileTypeError:
|
|
raise UnsupportedFileTypeError()
|
|
|
|
response = Response(
|
|
generator,
|
|
mimetype=upload_file.mime_type,
|
|
direct_passthrough=True,
|
|
headers={},
|
|
)
|
|
# add Accept-Ranges header for audio/video files
|
|
if upload_file.mime_type in [
|
|
"audio/mpeg",
|
|
"audio/wav",
|
|
"audio/mp4",
|
|
"audio/ogg",
|
|
"audio/flac",
|
|
"audio/aac",
|
|
"video/mp4",
|
|
"video/webm",
|
|
"video/quicktime",
|
|
"audio/x-m4a",
|
|
]:
|
|
response.headers["Accept-Ranges"] = "bytes"
|
|
if upload_file.size > 0:
|
|
response.headers["Content-Length"] = str(upload_file.size)
|
|
if args["as_attachment"]:
|
|
encoded_filename = quote(upload_file.name)
|
|
response.headers["Content-Disposition"] = f"attachment; filename*=UTF-8''{encoded_filename}"
|
|
response.headers["Content-Type"] = "application/octet-stream"
|
|
|
|
return response
|
|
|
|
|
|
@files_ns.route("/workspaces/<uuid:workspace_id>/webapp-logo")
|
|
class WorkspaceWebappLogoApi(Resource):
|
|
def get(self, workspace_id):
|
|
workspace_id = str(workspace_id)
|
|
|
|
custom_config = TenantService.get_custom_config(workspace_id)
|
|
webapp_logo_file_id = custom_config.get("replace_webapp_logo") if custom_config is not None else None
|
|
|
|
if not webapp_logo_file_id:
|
|
raise NotFound("webapp logo is not found")
|
|
|
|
try:
|
|
generator, mimetype = FileService(db.engine).get_public_image_preview(
|
|
webapp_logo_file_id,
|
|
)
|
|
except services.errors.file.UnsupportedFileTypeError:
|
|
raise UnsupportedFileTypeError()
|
|
|
|
return Response(generator, mimetype=mimetype)
|