%%{init: {"theme": "base", "themeVariables": {"primaryColor": "#fabd2f", "primaryTextColor": "#282828", "primaryBorderColor": "#b57614", "lineColor": "#7c6f64", "secondaryColor": "#83a598", "tertiaryColor": "#b8bb26", "background": "#fbf1c7", "mainBkg": "#ebdbb2", "fontFamily": "Tahoma, sans-serif"}}}%% flowchart LR subgraph Era1["ยุค Hardcode Config / In-code Secret"] A["DB_URL ใน source codeเสี่ยงรั่วไหล"] end subgraph Era2["ยุค Environment Config / Twelve-factor"] B["process.envแยก config จาก code"] C["dotenvโหลด .env ตอนพัฒนา"] end subgraph Era3["ยุค Multi Environment / Deployment"] D["development/staging/productionค่าต่างตาม environment"] E["Secret Managerจัดการ secret จริง"] end A --> B --> C --> D --> E
%%{init: {"theme": "base", "themeVariables": {"primaryColor": "#fabd2f", "primaryTextColor": "#282828", "primaryBorderColor": "#b57614", "lineColor": "#7c6f64", "secondaryColor": "#83a598", "tertiaryColor": "#b8bb26", "background": "#fbf1c7", "mainBkg": "#ebdbb2", "fontFamily": "Tahoma, sans-serif"}}}%% flowchart TD A[".envค่าจริงในเครื่อง"] --> B["dotenv.configโหลดค่า"] B --> C["process.envตัวแปร runtime"] C --> D["Node Appใช้งาน config"] E[".env.exampletemplate"] --> F["Developerสร้าง .env เอง"] G[".gitignoreกัน secret หลุด"] --> A