2
0

api.ts 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import { OpenAPIHono } from '@hono/zod-openapi'
  2. import { swaggerUI } from '@hono/swagger-ui'
  3. import { errorHandler } from './utils/errorHandler'
  4. import usersRouter from './api/users/index'
  5. import authRoute from './api/auth/index'
  6. import rolesRoute from './api/roles/index'
  7. import { AuthContext } from './types/context'
  8. import { AppDataSource } from './data-source'
  9. import { Hono } from 'hono'
  10. const app = new Hono();
  11. const api = new OpenAPIHono<AuthContext>()
  12. api.onError(errorHandler)
  13. // Rate limiting
  14. api.use('/api/v1/*', async (c, next) => {
  15. const ip = c.req.header('x-forwarded-for') || c.req.header('cf-connecting-ip')
  16. // 实现速率限制逻辑
  17. await next()
  18. })
  19. // 数据库初始化中间件
  20. api.use('/api/v1/*', async (c, next) => {
  21. if(!AppDataSource.isInitialized) {
  22. await AppDataSource.initialize();
  23. }
  24. await next();
  25. })
  26. // 注册Bearer认证方案
  27. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  28. type:'http',
  29. scheme:'bearer',
  30. bearerFormat:'JWT',
  31. description:'使用JWT进行认证'
  32. })
  33. // OpenAPI documentation endpoint
  34. if(!import.meta.env.PROD){
  35. api.doc31('/doc', {
  36. openapi: '3.1.0',
  37. info: {
  38. title: 'API Documentation',
  39. version: '1.0.0'
  40. },
  41. security: [{
  42. bearerAuth: []
  43. }]
  44. // servers: [{ url: '/api/v1' }]
  45. })
  46. app.get('/ui', swaggerUI({
  47. url: '/doc',
  48. persistAuthorization: true,
  49. manuallySwaggerUIHtml: (asset) => `
  50. <div>
  51. <div id="swagger-ui"></div>
  52. <link rel="stylesheet" href="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui.css" />
  53. <script src="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui-bundle.js" crossorigin="anonymous"></script>
  54. <script>
  55. window.onload = () => {
  56. window.ui = SwaggerUIBundle({
  57. dom_id: '#swagger-ui',
  58. url: '/doc',
  59. persistAuthorization: true
  60. })
  61. }
  62. </script>
  63. </div>
  64. `
  65. }))
  66. }
  67. const userRoutes = api.route('/api/v1/users', usersRouter)
  68. const authRoutes = api.route('/api/v1/auth', authRoute)
  69. const roleRoutes = api.route('/api/v1/roles', rolesRoute)
  70. export type AuthRoutes = typeof authRoutes
  71. export type UserRoutes = typeof userRoutes
  72. export type RoleRoutes = typeof roleRoutes
  73. app.route('/', api)
  74. export default app