index.ts 6.8 KB

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