mirror of
https://github.com/langgenius/dify.git
synced 2026-02-12 22:01:20 -05:00
Implement phase 1 of the file module migration by moving workflow-facing file primitives to core.workflow.file while keeping core.file as a temporary compatibility layer. What this commit changes - Add core.workflow.file package (constants/enums/models/helpers/file_manager/tool_file_parser). - Add protocol-based runtime binding in core.workflow.file.runtime and core.workflow.file.protocols. - Add application adapter core.app.workflow.file_runtime and bind runtime in extensions.ext_storage.init_app. - Bind runtime in tests via tests/conftest.py. - Migrate workflow-only imports from core.file.* to core.workflow.file.* across workflow runtime/nodes/entry/encoder and workflow node factory. - Update workflow unit tests to patch/import the new workflow file namespace. - Remove workflow-external-imports ignore_imports entries related to core.file from .importlinter. Compatibility guarantee for phase split - Keep core.file import path available in this phase by replacing core/file/*.py with forwarding bridge modules that re-export core.workflow.file symbols. - Preserve runtime behavior and isinstance(File) identity consistency while non-workflow modules are still on legacy import paths. Notes - This commit intentionally does not remove core.file. Full repository replacement and bridge removal are handled in phase 2.
43 lines
1.2 KiB
Python
43 lines
1.2 KiB
Python
from __future__ import annotations
|
|
|
|
from collections.abc import Generator
|
|
from typing import Protocol
|
|
|
|
|
|
class HttpResponseProtocol(Protocol):
|
|
"""Subset of response behavior needed by workflow file helpers."""
|
|
|
|
content: bytes
|
|
|
|
def raise_for_status(self) -> None: ...
|
|
|
|
|
|
class WorkflowFileRuntimeProtocol(Protocol):
|
|
"""Runtime dependencies required by ``core.workflow.file``.
|
|
|
|
Implementations are expected to be provided by integration layers (for example,
|
|
``core.app.workflow.file_runtime``) so the workflow package avoids importing
|
|
application infrastructure modules directly.
|
|
"""
|
|
|
|
@property
|
|
def files_url(self) -> str: ...
|
|
|
|
@property
|
|
def internal_files_url(self) -> str | None: ...
|
|
|
|
@property
|
|
def secret_key(self) -> str: ...
|
|
|
|
@property
|
|
def files_access_timeout(self) -> int: ...
|
|
|
|
@property
|
|
def multimodal_send_format(self) -> str: ...
|
|
|
|
def http_get(self, url: str, *, follow_redirects: bool = True) -> HttpResponseProtocol: ...
|
|
|
|
def storage_load(self, path: str, *, stream: bool = False) -> bytes | Generator: ...
|
|
|
|
def sign_tool_file(self, *, tool_file_id: str, extension: str, for_external: bool = True) -> str: ...
|