- config.py: KIS_APP_KEY/SECRET/ACCOUNT/IS_VIRTUAL + V1_TOKEN_PATH env - state.py: PollState extended with minute_bars (deque) and asking_price - requirements.txt: websockets>=12 19 existing tests still pass. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
40 lines
1.3 KiB
Python
40 lines
1.3 KiB
Python
"""Signal V2 환경변수 로딩."""
|
|
import os
|
|
from dataclasses import dataclass, field
|
|
from pathlib import Path
|
|
|
|
from dotenv import load_dotenv
|
|
|
|
load_dotenv(Path(__file__).parent.parent / ".env")
|
|
|
|
|
|
@dataclass(frozen=True)
|
|
class Settings:
|
|
stock_api_url: str = field(
|
|
default_factory=lambda: os.getenv("STOCK_API_URL", "").rstrip("/")
|
|
)
|
|
webai_api_key: str = field(
|
|
default_factory=lambda: os.getenv("WEBAI_API_KEY", "").strip()
|
|
)
|
|
port: int = field(default_factory=lambda: int(os.getenv("SIGNAL_V2_PORT", "8001")))
|
|
db_path: Path = field(
|
|
default_factory=lambda: Path(__file__).parent / "data" / "signal_v2.db"
|
|
)
|
|
# Phase 3a additions
|
|
kis_app_key: str = field(default_factory=lambda: os.getenv("KIS_APP_KEY", "").strip())
|
|
kis_app_secret: str = field(default_factory=lambda: os.getenv("KIS_APP_SECRET", "").strip())
|
|
kis_account: str = field(default_factory=lambda: os.getenv("KIS_ACCOUNT", "").strip())
|
|
kis_is_virtual: bool = field(
|
|
default_factory=lambda: os.getenv("KIS_IS_VIRTUAL", "true").lower() == "true"
|
|
)
|
|
v1_token_path: Path = field(
|
|
default_factory=lambda: Path(
|
|
os.getenv("V1_TOKEN_PATH",
|
|
str(Path(__file__).parent.parent / "signal_v1" / "data" / "kis_token.json"))
|
|
)
|
|
)
|
|
|
|
|
|
def get_settings() -> Settings:
|
|
return Settings()
|