api.ts 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { OpenAPIHono } from '@hono/zod-openapi'
  2. import { errorHandler } from './utils/errorHandler'
  3. import usersRouter from './api/users/index'
  4. import authRoute from './api/auth/index'
  5. import rolesRoute from './api/roles/index'
  6. import { AuthContext } from './types/context'
  7. import { AppDataSource } from './data-source'
  8. const api = new OpenAPIHono<AuthContext>()
  9. api.onError(errorHandler)
  10. // Rate limiting
  11. api.use('/api/v1/*', async (c, next) => {
  12. const ip = c.req.header('x-forwarded-for') || c.req.header('cf-connecting-ip')
  13. // 实现速率限制逻辑
  14. await next()
  15. })
  16. // 数据库初始化中间件
  17. api.use('/api/v1/*', async (c, next) => {
  18. if(!AppDataSource.isInitialized) {
  19. await AppDataSource.initialize();
  20. }
  21. await next();
  22. })
  23. // 注册Bearer认证方案
  24. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  25. type:'http',
  26. scheme:'bearer',
  27. bearerFormat:'JWT',
  28. description:'使用JWT进行认证'
  29. })
  30. // OpenAPI documentation endpoint
  31. if(!import.meta.env.PROD){
  32. api.doc31('/doc', {
  33. openapi: '3.1.0',
  34. info: {
  35. title: 'API Documentation',
  36. version: '1.0.0'
  37. },
  38. security: [{
  39. bearerAuth: []
  40. }]
  41. // servers: [{ url: '/api/v1' }]
  42. })
  43. }
  44. const userRoutes = api.route('/api/v1/users', usersRouter)
  45. const authRoutes = api.route('/api/v1/auth', authRoute)
  46. const roleRoutes = api.route('/api/v1/roles', rolesRoute)
  47. export type AuthRoutes = typeof authRoutes
  48. export type UserRoutes = typeof userRoutes
  49. export type RoleRoutes = typeof roleRoutes
  50. export default api