data-source-cli.ts 2.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. import "reflect-metadata"
  2. import { DataSource } from "typeorm"
  3. import process from 'node:process'
  4. /**
  5. * TypeORM 迁移数据源配置
  6. *
  7. * 此文件专用于 TypeORM 迁移 CLI 命令:
  8. * - pnpm migration:show
  9. * - pnpm migration:run
  10. * - pnpm migration:revert
  11. *
  12. * 注意:
  13. * - 使用 glob 模式加载实体,避免循环依赖
  14. * - 关闭自动同步(synchronize: false)
  15. * - 迁移通过 glob 模式加载
  16. */
  17. export const AppDataSource = new DataSource({
  18. type: "postgres",
  19. host: process.env.DB_HOST || "localhost",
  20. port: parseInt(process.env.DB_PORT || "5432"),
  21. username: process.env.DB_USERNAME || "postgres",
  22. password: process.env.DB_PASSWORD || "",
  23. database: process.env.DB_DATABASE || "postgres",
  24. // 使用明确的包路径加载实体,避免循环依赖
  25. entities: [
  26. // allin-packages 中的模块
  27. "../allin-packages/channel-module/src/entities/*.ts",
  28. "../allin-packages/company-module/src/entities/*.ts",
  29. // 显式路径:测试 Glob 模式是否是 migration:generate 失败的原因
  30. "../allin-packages/disability-module/src/entities/disabled-person.entity.ts",
  31. "../allin-packages/disability-module/src/entities/disabled-person-phone.entity.ts",
  32. "../allin-packages/disability-module/src/entities/disabled-person-guardian-phone.entity.ts",
  33. "../allin-packages/disability-module/src/entities/disabled-bank-card.entity.ts",
  34. "../allin-packages/disability-module/src/entities/disabled-photo.entity.ts",
  35. "../allin-packages/disability-module/src/entities/disabled-remark.entity.ts",
  36. "../allin-packages/disability-module/src/entities/disabled-visit.entity.ts",
  37. "../allin-packages/order-module/src/entities/*.ts",
  38. "../allin-packages/statistics-module/src/entities/*.ts",
  39. "../allin-packages/platform-module/src/entities/*.ts",
  40. "../allin-packages/salary-module/src/entities/*.ts",
  41. // packages 中的模块
  42. "../packages/core-module/src/entities/*.ts",
  43. "../packages/geo-areas/src/entities/*.ts",
  44. "../packages/bank-names-module/src/entities/*.ts",
  45. ],
  46. migrations: [
  47. "./migrations/*[0-9].ts", // 只匹配数字时间戳开头的迁移文件,排除 index.ts
  48. ],
  49. synchronize: false, // 迁移时必须关闭自动同步
  50. logging: process.env.DB_LOGGING === "true",
  51. })