index.ts 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  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/user-module'
  5. import { authRoutes as authModuleRoutes } from '@d8d/auth-module'
  6. import { fileRoutes as fileModuleRoutes } from '@d8d/file-module'
  7. import { AuthContext } from '@d8d/shared-types'
  8. import { AppDataSource } from '@d8d/shared-utils'
  9. import { Hono } from 'hono'
  10. import { UserEntity, Role } from '@d8d/user-module'
  11. import { File } from '@d8d/file-module'
  12. // 导入已实现的包实体
  13. import { AreaEntity } from '@d8d/geo-areas'
  14. import { PaymentEntity } from '@d8d/mini-payment'
  15. import { Advertisement, AdvertisementType } from '@d8d/advertisements-module'
  16. import { DeliveryAddress } from '@d8d/delivery-address-module'
  17. import { Goods, GoodsCategory } from '@d8d/goods-module'
  18. import { Merchant } from '@d8d/merchant-module'
  19. import { Order, OrderGoods, OrderRefund } from '@d8d/orders-module'
  20. import { Supplier } from '@d8d/supplier-module'
  21. if(!AppDataSource || !AppDataSource.isInitialized) {
  22. initializeDataSource([
  23. // 已实现的包实体
  24. UserEntity, Role, File,
  25. AreaEntity, PaymentEntity,
  26. Advertisement, AdvertisementType,
  27. DeliveryAddress,
  28. Goods, GoodsCategory,
  29. Merchant,
  30. Order, OrderGoods, OrderRefund,
  31. Supplier
  32. ])
  33. await AppDataSource.initialize();
  34. console.log('数据库初始化完成')
  35. }
  36. const app = new Hono();
  37. const api = new OpenAPIHono<AuthContext>()
  38. api.onError(errorHandler)
  39. // Rate limiting
  40. api.use('/api/v1/*', async (_, next) => {
  41. // 实现速率限制逻辑
  42. await next()
  43. })
  44. // // 数据库初始化中间件
  45. // api.use('/api/v1/*', async (c, next) => {
  46. // await next();
  47. // })
  48. // 注册Bearer认证方案
  49. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  50. type:'http',
  51. scheme:'bearer',
  52. bearerFormat:'JWT',
  53. description:'使用JWT进行认证'
  54. })
  55. // OpenAPI documentation endpoint
  56. // !import.meta.env.PROD
  57. if(1){
  58. // api.doc31('/doc', {
  59. // openapi: '3.1.0',
  60. // info: {
  61. // title: 'API Documentation',
  62. // version: '1.0.0'
  63. // },
  64. // security: [{
  65. // bearerAuth: []
  66. // }]
  67. // // servers: [{ url: '/api/v1' }]
  68. // })
  69. api.get('/doc', (c) => {
  70. const config = {
  71. openapi: '3.1.0',
  72. info: {
  73. title: 'API Documentation',
  74. version: '1.0.0'
  75. },
  76. security: [{
  77. bearerAuth: []
  78. }]
  79. // servers: [{ url: '/api/v1' }]
  80. };
  81. try {
  82. const document = api.getOpenAPI31Document(config);
  83. return c.json(document);
  84. } catch (e: any) {
  85. return c.json({
  86. error: 'OpenAPI document generation failed',
  87. message: e.message || 'Unknown error',
  88. stack: e.stack
  89. }, 500)
  90. }
  91. })
  92. app.get('/ui', swaggerUI({
  93. url: '/doc',
  94. persistAuthorization: true,
  95. manuallySwaggerUIHtml: () => `
  96. <div>
  97. <div id="swagger-ui"></div>
  98. <link rel="stylesheet" href="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui.css" />
  99. <script src="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui-bundle.js" crossorigin="anonymous"></script>
  100. <script>
  101. window.onload = () => {
  102. window.ui = SwaggerUIBundle({
  103. dom_id: '#swagger-ui',
  104. url: '/doc',
  105. persistAuthorization: true
  106. })
  107. }
  108. </script>
  109. </div>
  110. `
  111. }))
  112. }
  113. export const userRoutes = api.route('/api/v1/users', userModuleRoutes)
  114. export const authRoutes = api.route('/api/v1/auth', authModuleRoutes)
  115. export const fileApiRoutes = api.route('/api/v1/files', fileModuleRoutes)
  116. export const roleRoutes = api.route('/api/v1/roles', roleModuleRoutes)
  117. // 导入已实现的包路由
  118. import { areasRoutes, adminAreasRoutes } from '@d8d/geo-areas'
  119. import { PaymentRoutes } from '@d8d/mini-payment'
  120. import { advertisementRoutes, advertisementTypeRoutes } from '@d8d/advertisements-module'
  121. import { userDeliveryAddressRoutes } from '@d8d/delivery-address-module'
  122. import { adminGoodsCategoriesRoutes, adminGoodsRoutes } from '@d8d/goods-module'
  123. import { merchantRoutes } from '@d8d/merchant-module'
  124. import { userOrderRoutes, userOrderItemsRoutes, userRefundsRoutes } from '@d8d/orders-module'
  125. import { userSupplierRoutes } from '@d8d/supplier-module'
  126. // 注册已实现的包路由
  127. export const areaApiRoutes = api.route('/api/v1/areas', areasRoutes)
  128. export const adminAreaApiRoutes = api.route('/api/v1/admin/areas', adminAreasRoutes)
  129. export const paymentApiRoutes = api.route('/api/v1/payments', PaymentRoutes)
  130. export const advertisementApiRoutes = api.route('/api/v1/advertisements', advertisementRoutes)
  131. export const advertisementTypeApiRoutes = api.route('/api/v1/advertisement-types', advertisementTypeRoutes)
  132. export const deliveryAddressApiRoutes = api.route('/api/v1/delivery-addresses', userDeliveryAddressRoutes)
  133. export const goodsCategoryApiRoutes = api.route('/api/v1/goods-categories', adminGoodsCategoriesRoutes)
  134. export const goodsApiRoutes = api.route('/api/v1/goods', adminGoodsRoutes)
  135. export const merchantApiRoutes = api.route('/api/v1/merchants', merchantRoutes)
  136. export const orderApiRoutes = api.route('/api/v1/orders', userOrderRoutes)
  137. export const orderGoodsApiRoutes = api.route('/api/v1/orders-goods', userOrderItemsRoutes)
  138. export const orderRefundApiRoutes = api.route('/api/v1/orders-refund', userRefundsRoutes)
  139. export const supplierApiRoutes = api.route('/api/v1/suppliers', userSupplierRoutes)
  140. export type AuthRoutes = typeof authRoutes
  141. export type UserRoutes = typeof userRoutes
  142. export type FileRoutes = typeof fileApiRoutes
  143. export type RoleRoutes = typeof roleRoutes
  144. export type AdvertisementRoutes = typeof advertisementApiRoutes
  145. export type AdvertisementTypeRoutes = typeof advertisementTypeApiRoutes
  146. export type GoodsCategoryRoutes = typeof goodsCategoryApiRoutes
  147. export type GoodsRoutes = typeof goodsApiRoutes
  148. export type SupplierRoutes = typeof supplierApiRoutes
  149. export type MerchantRoutes = typeof merchantApiRoutes
  150. export type DeliveryAddressRoutes = typeof deliveryAddressApiRoutes
  151. export type OrderRoutes = typeof orderApiRoutes
  152. export type OrderGoodsRoutes = typeof orderGoodsApiRoutes
  153. export type OrderRefundRoutes = typeof orderRefundApiRoutes
  154. export type AreaRoutes = typeof areaApiRoutes
  155. export type AdminAreaRoutes = typeof adminAreaApiRoutes
  156. app.route('/', api)
  157. export default app