from typing import Dict, List
from distflow.workers.dag.node import NodeRole


class DAGInitializationError(Exception):
    """Custom exception for failures during DAGWorker initialization."""

    pass


class DAGConstants:
    """Centralized constants to improve maintainability and avoid magic strings."""

    # Worker role mapping
    WORKER_ROLE_MAPPING: Dict[NodeRole, str] = {
        NodeRole.ACTOR: "actor",
        NodeRole.ROLLOUT: "rollout",
        NodeRole.REFERENCE: "ref",
    }
    # Configuration keys
    INTERN_CONFIG: str = "intern_config"
    # Framework strategy names
    FSDP_STRATEGIES: List[str] = ["fsdp", "fsdp2"]
    MEGATRON_STRATEGYS: List[str] = ["megatron"]
    # keep this for backward compatibility
    MEGATRON_STRATEGY: str = "megatron"
    # Metric group order
    METRIC_GROUP_ORDER = ["step", "training", "actor", "critic", "perf", "response_length", "response", "prompt_length", "prompt", "dapo_sampling", "global_seqlen", "timing_s", "timing_per_token_ms", "perf/total_num_tokens", "perf/time_per_step", "perf/throughput"]
