index.ts 7.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  1. import { OpenAPIHono } from '@hono/zod-openapi'
  2. import { swaggerUI } from '@hono/swagger-ui'
  3. import { errorHandler } from '@d8d/shared-utils'
  4. import { userRoutes as userModuleRoutes, roleRoutes as roleModuleRoutes } from '@d8d/core-module/user-module'
  5. import { authRoutes as authModuleRoutes, enterpriseAuthRoutes as enterpriseAuthModuleRoutes, talentAuthRoutes as talentAuthModuleRoutes } from '@d8d/core-module/auth-module'
  6. import { fileRoutes as fileModuleRoutes } from '@d8d/core-module/file-module'
  7. import { AuthContext } from '@d8d/shared-types'
  8. import { AppDataSource } from './data-source'
  9. import { Hono } from 'hono'
  10. import { databaseBackup } from './utils/backup'
  11. // 导入区域相关路由
  12. import { areasRoutes, adminAreasRoutes } from '@d8d/geo-areas'
  13. // 导入 allin 模块路由
  14. import { channelRoutes } from '@d8d/allin-channel-module'
  15. import { companyRoutes, companyEnterpriseRoutes } from '@d8d/allin-company-module'
  16. import { disabledPersonRoutes, personExtensionRoutes, talentPersonalInfoRoutes } from '@d8d/allin-disability-module'
  17. import { orderRoutes, enterpriseOrderRoutes, talentEmploymentRoutes } from '@d8d/allin-order-module'
  18. import { platformRoutes } from '@d8d/allin-platform-module'
  19. import { salaryRoutes } from '@d8d/allin-salary-module'
  20. import { statisticsRoutes } from '@d8d/allin-statistics-module'
  21. // 导入其他模块路由
  22. import { bankNameRoutes } from '@d8d/bank-names-module'
  23. // 使用 data-source.ts 中定义的 AppDataSource(包含所有实体和迁移配置)
  24. if(!AppDataSource || !AppDataSource.isInitialized) {
  25. await AppDataSource.initialize();
  26. console.log('数据库初始化完成')
  27. // 生产环境自动运行迁移
  28. const isProduction = process.env.NODE_ENV === 'production';
  29. if (isProduction) {
  30. await AppDataSource.runMigrations();
  31. console.log('数据库迁移已完成');
  32. }
  33. // 启动数据库备份调度
  34. databaseBackup.startScheduledBackups();
  35. console.log('数据库备份调度已启动');
  36. }
  37. const app = new Hono();
  38. const api = new OpenAPIHono<AuthContext>()
  39. api.onError(errorHandler)
  40. // Rate limiting
  41. api.use('/api/v1/*', async (_, next) => {
  42. // 实现速率限制逻辑
  43. await next()
  44. })
  45. // // 数据库初始化中间件
  46. // api.use('/api/v1/*', async (c, next) => {
  47. // await next();
  48. // })
  49. // 注册Bearer认证方案
  50. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  51. type:'http',
  52. scheme:'bearer',
  53. bearerFormat:'JWT',
  54. description:'使用JWT进行认证'
  55. })
  56. // OpenAPI documentation endpoint
  57. // eslint-disable-next-line no-constant-condition
  58. if (true) {
  59. // api.doc31('/doc', {
  60. // openapi: '3.1.0',
  61. // info: {
  62. // title: 'API Documentation',
  63. // version: '1.0.0'
  64. // },
  65. // security: [{
  66. // bearerAuth: []
  67. // }]
  68. // // servers: [{ url: '/api/v1' }]
  69. // })
  70. api.get('/doc', (c) => {
  71. const config = {
  72. openapi: '3.1.0',
  73. info: {
  74. title: 'API Documentation',
  75. version: '1.0.0'
  76. },
  77. security: [{
  78. bearerAuth: []
  79. }]
  80. // servers: [{ url: '/api/v1' }]
  81. };
  82. try {
  83. const document = api.getOpenAPI31Document(config);
  84. return c.json(document);
  85. } catch (e: any) {
  86. return c.json({
  87. error: 'OpenAPI document generation failed',
  88. message: e.message || 'Unknown error',
  89. stack: e.stack
  90. }, 500)
  91. }
  92. })
  93. app.get('/ui', swaggerUI({
  94. url: '/doc',
  95. persistAuthorization: true,
  96. manuallySwaggerUIHtml: () => `
  97. <div>
  98. <div id="swagger-ui"></div>
  99. <link rel="stylesheet" href="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui.css" />
  100. <script src="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui-bundle.js" crossorigin="anonymous"></script>
  101. <script>
  102. window.onload = () => {
  103. window.ui = SwaggerUIBundle({
  104. dom_id: '#swagger-ui',
  105. url: '/doc',
  106. persistAuthorization: true
  107. })
  108. }
  109. </script>
  110. </div>
  111. `
  112. }))
  113. }
  114. export const userRoutes = api.route('/api/v1/users', userModuleRoutes)
  115. export const authRoutes = api.route('/api/v1/auth', authModuleRoutes)
  116. export const fileApiRoutes = api.route('/api/v1/files', fileModuleRoutes)
  117. export const roleRoutes = api.route('/api/v1/roles', roleModuleRoutes)
  118. export const areaApiRoutes = api.route('/api/v1/areas', areasRoutes)
  119. export const adminAreaApiRoutes = api.route('/api/v1/admin/areas', adminAreasRoutes)
  120. export const channelApiRoutes = api.route('/api/v1/channel', channelRoutes)
  121. export const companyApiRoutes = api.route('/api/v1/company', companyRoutes)
  122. export const disabilityApiRoutes = api.route('/api/v1/disability', disabledPersonRoutes)
  123. export const orderApiRoutes = api.route('/api/v1/order', orderRoutes)
  124. export const platformApiRoutes = api.route('/api/v1/platform', platformRoutes)
  125. export const salaryApiRoutes = api.route('/api/v1/salary', salaryRoutes)
  126. export const bankNameApiRoutes = api.route('/api/v1/bank-names', bankNameRoutes)
  127. // 企业用户专用路由(用人方小程序)
  128. export const enterpriseAuthApiRoutes = api.route('/api/v1/yongren/auth', enterpriseAuthModuleRoutes)
  129. export const enterpriseCompanyApiRoutes = api.route('/api/v1/yongren/company', companyEnterpriseRoutes)
  130. export const enterpriseDisabilityApiRoutes = api.route('/api/v1/yongren/disability-person', personExtensionRoutes)
  131. export const enterpriseOrderApiRoutes = api.route('/api/v1/yongren/order', enterpriseOrderRoutes)
  132. export const enterpriseStatisticsApiRoutes = api.route('/api/v1/yongren/statistics', statisticsRoutes)
  133. // 人才用户专用路由(人才小程序)
  134. export const talentAuthApiRoutes = api.route('/api/v1/rencai/auth', talentAuthModuleRoutes)
  135. export const talentPersonalInfoApiRoutes = api.route('/api/v1/rencai', talentPersonalInfoRoutes)
  136. export const talentEmploymentApiRoutes = api.route('/api/v1/rencai', talentEmploymentRoutes)
  137. export type AuthRoutes = typeof authRoutes
  138. export type UserRoutes = typeof userRoutes
  139. export type FileRoutes = typeof fileApiRoutes
  140. export type RoleRoutes = typeof roleRoutes
  141. export type AreaRoutes = typeof areaApiRoutes
  142. export type AdminAreaRoutes = typeof adminAreaApiRoutes
  143. export type ChannelRoutes = typeof channelApiRoutes
  144. export type CompanyRoutes = typeof companyApiRoutes
  145. export type DisabilityRoutes = typeof disabilityApiRoutes
  146. export type OrderRoutes = typeof orderApiRoutes
  147. export type PlatformRoutes = typeof platformApiRoutes
  148. export type SalaryRoutes = typeof salaryApiRoutes
  149. export type BankNameRoutes = typeof bankNameApiRoutes
  150. export type EnterpriseAuthRoutes = typeof enterpriseAuthApiRoutes
  151. export type EnterpriseCompanyRoutes = typeof enterpriseCompanyApiRoutes
  152. export type EnterpriseDisabilityRoutes = typeof enterpriseDisabilityApiRoutes
  153. export type EnterpriseOrderRoutes = typeof enterpriseOrderApiRoutes
  154. export type EnterpriseStatisticsRoutes = typeof enterpriseStatisticsApiRoutes
  155. export type TalentAuthRoutes = typeof talentAuthApiRoutes
  156. export type TalentPersonalInfoRoutes = typeof talentPersonalInfoApiRoutes
  157. export type TalentEmploymentRoutes = typeof talentEmploymentApiRoutes
  158. app.route('/', api)
  159. export default app