index.ts 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. import { OpenAPIHono } from '@hono/zod-openapi'
  2. import { swaggerUI } from '@hono/swagger-ui'
  3. import { errorHandler, initializeDataSource } from '@d8d/shared-utils'
  4. import { userRoutes as userModuleRoutes, roleRoutes as roleModuleRoutes } from '@d8d/core-module/user-module'
  5. import { authRoutes as authModuleRoutes } 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 '@d8d/shared-utils'
  9. import { Hono } from 'hono'
  10. import { databaseBackup } from './utils/backup'
  11. import { UserEntity, Role } from '@d8d/core-module/user-module'
  12. import { File } from '@d8d/core-module/file-module'
  13. import { SystemConfig } from '@d8d/core-module/system-config-module'
  14. import { areasRoutes, adminAreasRoutes, AreaEntity } from '@d8d/geo-areas'
  15. import { channelRoutes } from '@d8d/allin-channel-module'
  16. import { Channel } from '@d8d/allin-channel-module/entities'
  17. import { companyRoutes } from '@d8d/allin-company-module'
  18. import { Company } from '@d8d/allin-company-module/entities'
  19. import { disabledPersonRoutes } from '@d8d/allin-disability-module'
  20. import { DisabledPerson, DisabledBankCard, DisabledPhoto, DisabledRemark, DisabledVisit } from '@d8d/allin-disability-module/entities'
  21. import { orderRoutes } from '@d8d/allin-order-module'
  22. import { EmploymentOrder, OrderPerson, OrderPersonAsset } from '@d8d/allin-order-module/entities'
  23. import { platformRoutes } from '@d8d/allin-platform-module'
  24. import { Platform } from '@d8d/allin-platform-module/entities'
  25. import { salaryRoutes } from '@d8d/allin-salary-module'
  26. import { SalaryLevel } from '@d8d/allin-salary-module/entities'
  27. initializeDataSource([
  28. UserEntity, Role, File, SystemConfig, AreaEntity,
  29. Channel,
  30. Company,
  31. DisabledPerson, DisabledBankCard, DisabledPhoto, DisabledRemark, DisabledVisit,
  32. EmploymentOrder, OrderPerson, OrderPersonAsset,
  33. Platform,
  34. SalaryLevel
  35. ])
  36. if(!AppDataSource || !AppDataSource.isInitialized) {
  37. await AppDataSource.initialize();
  38. console.log('数据库初始化完成')
  39. // 启动数据库备份调度
  40. databaseBackup.startScheduledBackups();
  41. console.log('数据库备份调度已启动');
  42. }
  43. const app = new Hono();
  44. const api = new OpenAPIHono<AuthContext>()
  45. api.onError(errorHandler)
  46. // Rate limiting
  47. api.use('/api/v1/*', async (_, next) => {
  48. // 实现速率限制逻辑
  49. await next()
  50. })
  51. // // 数据库初始化中间件
  52. // api.use('/api/v1/*', async (c, next) => {
  53. // await next();
  54. // })
  55. // 注册Bearer认证方案
  56. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  57. type:'http',
  58. scheme:'bearer',
  59. bearerFormat:'JWT',
  60. description:'使用JWT进行认证'
  61. })
  62. // OpenAPI documentation endpoint
  63. // !import.meta.env.PROD
  64. if(1){
  65. // api.doc31('/doc', {
  66. // openapi: '3.1.0',
  67. // info: {
  68. // title: 'API Documentation',
  69. // version: '1.0.0'
  70. // },
  71. // security: [{
  72. // bearerAuth: []
  73. // }]
  74. // // servers: [{ url: '/api/v1' }]
  75. // })
  76. api.get('/doc', (c) => {
  77. const config = {
  78. openapi: '3.1.0',
  79. info: {
  80. title: 'API Documentation',
  81. version: '1.0.0'
  82. },
  83. security: [{
  84. bearerAuth: []
  85. }]
  86. // servers: [{ url: '/api/v1' }]
  87. };
  88. try {
  89. const document = api.getOpenAPI31Document(config);
  90. return c.json(document);
  91. } catch (e: any) {
  92. return c.json({
  93. error: 'OpenAPI document generation failed',
  94. message: e.message || 'Unknown error',
  95. stack: e.stack
  96. }, 500)
  97. }
  98. })
  99. app.get('/ui', swaggerUI({
  100. url: '/doc',
  101. persistAuthorization: true,
  102. manuallySwaggerUIHtml: () => `
  103. <div>
  104. <div id="swagger-ui"></div>
  105. <link rel="stylesheet" href="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui.css" />
  106. <script src="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui-bundle.js" crossorigin="anonymous"></script>
  107. <script>
  108. window.onload = () => {
  109. window.ui = SwaggerUIBundle({
  110. dom_id: '#swagger-ui',
  111. url: '/doc',
  112. persistAuthorization: true
  113. })
  114. }
  115. </script>
  116. </div>
  117. `
  118. }))
  119. }
  120. export const userRoutes = api.route('/api/v1/users', userModuleRoutes)
  121. export const authRoutes = api.route('/api/v1/auth', authModuleRoutes)
  122. export const fileApiRoutes = api.route('/api/v1/files', fileModuleRoutes)
  123. export const roleRoutes = api.route('/api/v1/roles', roleModuleRoutes)
  124. export const areaApiRoutes = api.route('/api/v1/areas', areasRoutes)
  125. export const adminAreaApiRoutes = api.route('/api/v1/admin/areas', adminAreasRoutes)
  126. export const channelApiRoutes = api.route('/api/v1/channel', channelRoutes)
  127. export const companyApiRoutes = api.route('/api/v1/company', companyRoutes)
  128. export const disabilityApiRoutes = api.route('/api/v1/disability', disabledPersonRoutes)
  129. export const orderApiRoutes = api.route('/api/v1/order', orderRoutes)
  130. export const platformApiRoutes = api.route('/api/v1/platform', platformRoutes)
  131. export const salaryApiRoutes = api.route('/api/v1/salary', salaryRoutes)
  132. export type AuthRoutes = typeof authRoutes
  133. export type UserRoutes = typeof userRoutes
  134. export type FileRoutes = typeof fileApiRoutes
  135. export type RoleRoutes = typeof roleRoutes
  136. export type AreaRoutes = typeof areaApiRoutes
  137. export type AdminAreaRoutes = typeof adminAreaApiRoutes
  138. export type ChannelRoutes = typeof channelApiRoutes
  139. export type CompanyRoutes = typeof companyApiRoutes
  140. export type DisabilityRoutes = typeof disabilityApiRoutes
  141. export type OrderRoutes = typeof orderApiRoutes
  142. export type PlatformRoutes = typeof platformApiRoutes
  143. export type SalaryRoutes = typeof salaryApiRoutes
  144. app.route('/', api)
  145. export default app