config.py 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import secrets
  2. from typing import Any, Dict, List, Optional, Union
  3. from pydantic import AnyHttpUrl, BaseSettings, EmailStr, HttpUrl, PostgresDsn, validator, DirectoryPath
  4. class Settings(BaseSettings):
  5. API_V1_STR: str = "/api/v1"
  6. SECRET_KEY: str = secrets.token_urlsafe(32)
  7. # 60 minutes * 24 hours * 8 days = 8 days
  8. ACCESS_TOKEN_EXPIRE_MINUTES: int = 60 * 24 * 8
  9. SERVER_NAME: str = "cloud.choozmo.com:8080"
  10. SERVER_HOST: AnyHttpUrl = "http://cloud.choozmo.com:8080"
  11. # BACKEND_CORS_ORIGINS is a JSON-formatted list of origins
  12. # e.g: '["http://localhost", "http://localhost:4200", "http://localhost:3000", \
  13. # "http://localhost:8080", "http://local.dockertoolbox.tiangolo.com"]'
  14. BACKEND_CORS_ORIGINS: List[AnyHttpUrl] = ["http://cmm.ai:3001/", "https://cloud.choozmo:8080", "http://cloud.choozmo.com:8080", "https://cloud.choozmo.com", "http://cloud.choozmo.com","http://172.105.219.42", "http://local.ai-anchor.com:5173", "http://local.ai-anchor.com:8080", "http://localhost", "http://localhost:4200", "http://localhost:3000", "http://localhost:5173", "http://localhost:8080", "https://localhost", "https://localhost:4200", "https://localhost:3000", "https://localhost:8080", "http://dev.ai-anchor.com:3000", "http://dev.ai-anchor.com:5173", "http://dev.ai-anchor.com:8080"]
  15. @validator("BACKEND_CORS_ORIGINS", pre=True)
  16. def assemble_cors_origins(cls, v: Union[str, List[str]]) -> Union[List[str], str]:
  17. if isinstance(v, str) and not v.startswith("["):
  18. return [i.strip() for i in v.split(",")]
  19. elif isinstance(v, (list, str)):
  20. return v
  21. raise ValueError(v)
  22. PROJECT_NAME: str = "ai-anchor"
  23. SENTRY_DSN: Optional[HttpUrl] = "http://SENTRY_DSN"
  24. @validator("SENTRY_DSN", pre=True)
  25. def sentry_dsn_can_be_blank(cls, v: str) -> Optional[str]:
  26. if len(v) == 0:
  27. return None
  28. return
  29. '''
  30. @validator("SQLALCHEMY_DATABASE_URI", pre=True)
  31. def assemble_db_connection(cls, v: Optional[str], values: Dict[str, Any]) -> Any:
  32. if isinstance(v, str):
  33. return v
  34. return PostgresDsn.build(
  35. scheme="postgresql",
  36. user=values.get("POSTGRES_USER"),
  37. password=values.get("POSTGRES_PASSWORD"),
  38. host=values.get("POSTGRES_SERVER"),
  39. path=f"/{values.get('POSTGRES_DB') or ''}",
  40. )
  41. '''
  42. SMTP_TLS: bool = True
  43. SMTP_PORT: Optional[int] = None
  44. SMTP_HOST: Optional[str] = None
  45. SMTP_USER: Optional[str] = None
  46. SMTP_PASSWORD: Optional[str] = None
  47. EMAILS_FROM_EMAIL: Optional[EmailStr] = None
  48. EMAILS_FROM_NAME: Optional[str] = None
  49. @validator("EMAILS_FROM_NAME")
  50. def get_project_name(cls, v: Optional[str], values: Dict[str, Any]) -> str:
  51. if not v:
  52. return values["PROJECT_NAME"]
  53. return v
  54. EMAIL_RESET_TOKEN_EXPIRE_HOURS: int = 48
  55. EMAIL_TEMPLATES_DIR: str = "/app/app/email-templates/build"
  56. EMAILS_ENABLED: bool = False
  57. @validator("EMAILS_ENABLED", pre=True)
  58. def get_emails_enabled(cls, v: bool, values: Dict[str, Any]) -> bool:
  59. return bool(
  60. values.get("SMTP_HOST")
  61. and values.get("SMTP_PORT")
  62. and values.get("EMAILS_FROM_EMAIL")
  63. )
  64. EMAIL_TEST_USER: EmailStr = "test@example.com" # type: ignore
  65. FIRST_SUPERUSER: EmailStr = "admin@ai-anchor.com"
  66. FIRST_SUPERUSER_PASSWORD: str = "password"
  67. USERS_OPEN_REGISTRATION: bool = False
  68. MEMBERSHIP_STATUS : List[str] = ['normal', 'infinite']
  69. PROGRESS_STATE: List[str] = ['waiting', 'processing', 'completed', 'failed']
  70. SERVER_ADDRESS: AnyHttpUrl = "http://172.105.219.42:8080"
  71. CELERY_ZIP_STORAGE: str = "celery_storage/zips"
  72. CELERY_VIDEO_STORAGE: str = "celery_storage/videos"
  73. BACKEND_ZIP_STORAGE: str = "backend_storage/zips"
  74. BACKEND_VIDEO_STORAGE: str = "backend_storage/videos"
  75. LOCAL_ZIP_STORAGE:str = 'local_storage/zips'
  76. LOCAL_VIDEO_STORAGE:str = 'local_storage/videos'
  77. class Config:
  78. case_sensitive = True
  79. settings = Settings()