base.py 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. # base.py 修改后
  2. import os
  3. from dotenv import load_dotenv
  4. from core.utils.path_utils import project_root, log_dir
  5. from pydantic import Field, AnyUrl, field_validator, ConfigDict
  6. from pydantic_settings import BaseSettings # 注意:BaseSettings 现在在 pydantic_settings 中
  7. load_dotenv(os.path.join(project_root, ".env"))
  8. class Settings(BaseSettings):
  9. # Pydantic 2.x 使用 ConfigDict 替代内部 Config 类
  10. model_config = ConfigDict(
  11. env_file=".env",
  12. env_file_encoding='utf-8',
  13. case_sensitive=False,
  14. env_prefix="", # 明确指定环境变量前缀
  15. )
  16. # 环境标识
  17. ENV: str = "prod"
  18. ENABLE_ALIYUN_LOG: bool = True
  19. # 日志配置
  20. LOG_DIR: str = log_dir
  21. LOG_LEVEL: str = "INFO"
  22. # 阿里云数据库配置
  23. DB_HOST: str = Field(..., validation_alias="DB_HOST")
  24. DB_PORT: int = Field(3306, validation_alias="DB_PORT")
  25. DB_USER: str = Field(..., validation_alias="DB_USER")
  26. DB_PASSWORD: str = Field(..., validation_alias="DB_PASSWORD")
  27. DB_NAME: str = Field(..., validation_alias="DB_NAME")
  28. DB_CHARSET: str = Field(..., validation_alias="DB_CHARSET")
  29. DB_POOL_SIZE: int = 20
  30. DB_POOL_RECYCLE: int = 3600
  31. # 阿里云RocketMQ配置
  32. ROCKETMQ_ENDPOINT: str = Field(..., validation_alias="ROCKETMQ_ENDPOINT")
  33. ROCKETMQ_ACCESS_KEY_ID: str = Field(..., validation_alias="ROCKETMQ_ACCESS_KEY_ID")
  34. ROCKETMQ_ACCESS_KEY_SECRET: str = Field(..., validation_alias="ROCKETMQ_ACCESS_KEY_SECRET")
  35. ROCKETMQ_INSTANCE_ID: str = Field(..., validation_alias="ROCKETMQ_INSTANCE_ID")
  36. ROCKETMQ_WAIT_SECONDS: int = 30
  37. ROCKETMQ_BATCH: int = 1
  38. # 飞书配置
  39. FEISHU_APPID: str = Field(..., validation_alias="FEISHU_APPID")
  40. FEISHU_APPSECRET: str = Field(..., validation_alias="FEISHU_APPSECRET")
  41. # 连接池配置
  42. CONNECTION_TIMEOUT: int = 10
  43. REQUEST_TIMEOUT: int = 30
  44. # 阿里云日志
  45. ALIYUN_ACCESS_KEY_ID: str = Field(..., validation_alias="ALIYUN_ACCESS_KEY_ID")
  46. ALIYUN_ACCESS_KEY_SECRET: str = Field(..., validation_alias="ALIYUN_ACCESS_KEY_SECRET")
  47. # redis
  48. REDIS_HOST: str = Field(..., validation_alias="REDIS_HOST")
  49. REDIS_PORT: int = Field(..., validation_alias="REDIS_PORT")
  50. REDIS_PASSWORD: str = Field(..., validation_alias="REDIS_PASSWORD")
  51. REDIS_DB: int = Field(0, validation_alias="REDIS_DB")
  52. REDIS_MAX_CONNECTIONS: int = Field(20, validation_alias="REDIS_MAX_CONNECTIONS")
  53. @property
  54. def redis_url(self) -> str:
  55. return f"redis://:{self.REDIS_PASSWORD}@{self.REDIS_HOST}:{self.REDIS_PORT}/{self.REDIS_DB}"
  56. # Pydantic 2.x 验证器语法
  57. @field_validator('DB_PORT', 'REDIS_PORT')
  58. @classmethod
  59. def validate_port(cls, v: int) -> int:
  60. if not 1 <= v <= 65535:
  61. raise ValueError('Port must be between 1 and 65535')
  62. return v
  63. @field_validator('DB_POOL_SIZE', 'DB_POOL_RECYCLE', 'REDIS_MAX_CONNECTIONS')
  64. @classmethod
  65. def validate_positive_int(cls, v: int) -> int:
  66. if v <= 0:
  67. raise ValueError('Value must be positive')
  68. return v
  69. @field_validator('ROCKETMQ_WAIT_SECONDS')
  70. @classmethod
  71. def validate_rocketmq_wait_seconds(cls, v: int) -> int:
  72. if not 1 <= v <= 30:
  73. raise ValueError('ROCKETMQ_WAIT_SECONDS must be between 1 and 30')
  74. return v
  75. @field_validator('ROCKETMQ_BATCH')
  76. @classmethod
  77. def validate_rocketmq_batch(cls, v: int) -> int:
  78. if not 1 <= v <= 16:
  79. raise ValueError('ROCKETMQ_BATCH must be between 1 and 16')
  80. return v
  81. @field_validator('CONNECTION_TIMEOUT', 'REQUEST_TIMEOUT')
  82. @classmethod
  83. def validate_timeouts(cls, v: int) -> int:
  84. if v <= 0:
  85. raise ValueError('Timeout must be positive')
  86. return v
  87. settings = Settings()