2
0

routes_migrations.ts 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. import { Hono } from 'hono'
  2. import { APIClient } from '@d8d-appcontainer/api'
  3. import type { Variables } from './app.tsx'
  4. import type { WithAuth } from './app.tsx'
  5. import { migrations } from './migrations.ts'
  6. import debug from "debug";
  7. const log = {
  8. api: debug("api:migrations"),
  9. };
  10. export function createMigrationsRoutes(withAuth: WithAuth) {
  11. const migrationsRoutes = new Hono<{ Variables: Variables }>()
  12. migrationsRoutes.get('/', async (c) => {
  13. const apiClient = c.get('apiClient')
  14. log.api('正在执行数据库迁移...')
  15. const migrationsResult = await apiClient.database.executeLiveMigrations(migrations)
  16. // log.app('数据库迁移完成 %O',migrationsResult)
  17. const failedResult = migrationsResult?.find((migration) => migration.status === 'failed')
  18. if (failedResult) {
  19. log.api('数据库迁移失败 %O', failedResult)
  20. return c.json({ error: '数据库迁移失败', failedResult }, 500)
  21. }
  22. return c.json({ success: true })
  23. })
  24. migrationsRoutes.get('/history', async (c) => {
  25. const apiClient = c.get('apiClient')
  26. log.api('正在执行数据库迁移...')
  27. const MIRGRATIONS_TABLE = 'knex_migrations'
  28. const hasTable = await apiClient.database.schema.hasTable(MIRGRATIONS_TABLE);
  29. let history = []
  30. if(hasTable)
  31. history = await apiClient.database.table(MIRGRATIONS_TABLE).orderBy('id', 'desc')
  32. return c.json({
  33. success: true,
  34. history
  35. })
  36. })
  37. return migrationsRoutes
  38. }