mirror of
https://github.com/langgenius/dify.git
synced 2026-03-25 16:28:04 +08:00
Made-with: Cursor # Conflicts: # api/controllers/console/app/workflow_draft_variable.py # api/core/agent/cot_agent_runner.py # api/core/agent/cot_chat_agent_runner.py # api/core/agent/cot_completion_agent_runner.py # api/core/agent/fc_agent_runner.py # api/core/app/apps/advanced_chat/app_generator.py # api/core/app/apps/advanced_chat/app_runner.py # api/core/app/apps/agent_chat/app_runner.py # api/core/app/apps/workflow/app_generator.py # api/core/app/apps/workflow/app_runner.py # api/core/app/entities/app_invoke_entities.py # api/core/app/entities/queue_entities.py # api/core/llm_generator/output_parser/structured_output.py # api/core/workflow/workflow_entry.py # api/dify_graph/context/__init__.py # api/dify_graph/entities/tool_entities.py # api/dify_graph/file/file_manager.py # api/dify_graph/graph_engine/response_coordinator/coordinator.py # api/dify_graph/graph_events/node.py # api/dify_graph/node_events/node.py # api/dify_graph/nodes/agent/agent_node.py # api/dify_graph/nodes/llm/entities.py # api/dify_graph/nodes/llm/llm_utils.py # api/dify_graph/nodes/llm/node.py # api/dify_graph/nodes/question_classifier/question_classifier_node.py # api/dify_graph/runtime/graph_runtime_state.py # api/dify_graph/variables/segments.py # api/factories/variable_factory.py # api/services/variable_truncator.py # api/tests/unit_tests/utils/structured_output_parser/test_structured_output_parser.py # api/uv.lock # web/app/components/app-sidebar/app-info.tsx # web/app/components/app-sidebar/app-sidebar-dropdown.tsx # web/app/components/app/create-app-modal/index.spec.tsx # web/app/components/apps/__tests__/list.spec.tsx # web/app/components/apps/app-card.tsx # web/app/components/apps/list.tsx # web/app/components/header/account-dropdown/compliance.tsx # web/app/components/header/account-dropdown/index.tsx # web/app/components/header/account-dropdown/support.tsx # web/app/components/workflow-app/components/workflow-onboarding-modal/index.tsx # web/app/components/workflow/panel/debug-and-preview/hooks.ts # web/contract/console/apps.ts # web/contract/router.ts # web/eslint-suppressions.json # web/next.config.ts # web/pnpm-lock.yaml
87 lines
2.4 KiB
Python
87 lines
2.4 KiB
Python
from collections.abc import Mapping, Sequence
|
|
from typing import Any, Protocol
|
|
|
|
from dify_graph.model_runtime.entities.llm_entities import LLMUsage
|
|
from dify_graph.system_variable import SystemVariableReadOnlyView
|
|
from dify_graph.variables.segments import Segment
|
|
|
|
|
|
class ReadOnlyVariablePool(Protocol):
|
|
"""Read-only interface for VariablePool."""
|
|
|
|
def get(self, selector: Sequence[str], /) -> Segment | None:
|
|
"""Get a variable value (read-only)."""
|
|
...
|
|
|
|
def get_all_by_node(self, node_id: str) -> Mapping[str, object]:
|
|
"""Get all variables for a node (read-only)."""
|
|
...
|
|
|
|
def get_by_prefix(self, prefix: str) -> Mapping[str, object]:
|
|
"""Get all variables stored under a given node prefix (read-only)."""
|
|
...
|
|
|
|
|
|
class ReadOnlyGraphRuntimeState(Protocol):
|
|
"""
|
|
Read-only view of GraphRuntimeState for layers.
|
|
|
|
This protocol defines a read-only interface that prevents layers from
|
|
modifying the graph runtime state while still allowing observation.
|
|
All methods return defensive copies to ensure immutability.
|
|
"""
|
|
|
|
@property
|
|
def system_variable(self) -> SystemVariableReadOnlyView: ...
|
|
|
|
@property
|
|
def variable_pool(self) -> ReadOnlyVariablePool:
|
|
"""Get read-only access to the variable pool."""
|
|
...
|
|
|
|
@property
|
|
def start_at(self) -> float:
|
|
"""Get the start time (read-only)."""
|
|
...
|
|
|
|
@property
|
|
def total_tokens(self) -> int:
|
|
"""Get the total tokens count (read-only)."""
|
|
...
|
|
|
|
@property
|
|
def llm_usage(self) -> LLMUsage:
|
|
"""Get a copy of LLM usage info (read-only)."""
|
|
...
|
|
|
|
@property
|
|
def outputs(self) -> dict[str, Any]:
|
|
"""Get a defensive copy of outputs (read-only)."""
|
|
...
|
|
|
|
@property
|
|
def node_run_steps(self) -> int:
|
|
"""Get the node run steps count (read-only)."""
|
|
...
|
|
|
|
@property
|
|
def ready_queue_size(self) -> int:
|
|
"""Get the number of nodes currently in the ready queue."""
|
|
...
|
|
|
|
@property
|
|
def exceptions_count(self) -> int:
|
|
"""Get the number of node execution exceptions recorded."""
|
|
...
|
|
|
|
def get_output(self, key: str, default: Any = None) -> Any:
|
|
"""Get a single output value (returns a copy)."""
|
|
...
|
|
|
|
@property
|
|
def sandbox(self) -> Any: ...
|
|
|
|
def dumps(self) -> str:
|
|
"""Serialize the runtime state into a JSON snapshot (read-only)."""
|
|
...
|