index.ts 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  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 { databaseBackup } from './utils/backup'
  11. import { UserEntity, Role } from '@d8d/user-module'
  12. import { File } from '@d8d/file-module'
  13. // 导入其他实体(暂时保留在server包中)
  14. import { Advertisement } from './modules/advertisements/advertisement.entity'
  15. import { AdvertisementType } from './modules/advertisements/advertisement-type.entity'
  16. import { GoodsCategory } from './modules/goods/goods-category.entity'
  17. import { Goods } from './modules/goods/goods.entity'
  18. import { City } from './modules/system/city.entity'
  19. import { Config } from './modules/system/config.entity'
  20. import { ExpressCompany } from './modules/logistics/express-company.entity'
  21. import { Organization } from './modules/organization/organization.entity'
  22. import { Supplier } from './modules/supplier/supplier.entity'
  23. import { Card } from './modules/card/card.entity'
  24. import { Agent } from './modules/agent/agent.entity'
  25. import { Merchant } from './modules/merchant/merchant.entity'
  26. import { UserCard } from './modules/user-cards/user-card.entity'
  27. import { UserCardBalanceRecord } from './modules/user-card-balance-records/user-card-balance-record.entity'
  28. import { DeliveryAddress } from './modules/delivery-address/delivery-address.entity'
  29. import { Order } from './modules/orders/order.entity'
  30. import { OrderGoods } from './modules/orders/order-goods.entity'
  31. import { OrderRefund } from './modules/orders/order-refund.entity'
  32. if(!AppDataSource || !AppDataSource.isInitialized) {
  33. initializeDataSource([
  34. UserEntity, Role, File,
  35. Advertisement, AdvertisementType, GoodsCategory, Goods, City, Config,
  36. ExpressCompany, Organization, Supplier, Card, Agent, Merchant,
  37. UserCard, UserCardBalanceRecord, DeliveryAddress, Order, OrderGoods, OrderRefund
  38. ])
  39. await AppDataSource.initialize();
  40. console.log('数据库初始化完成')
  41. // 启动数据库备份调度
  42. databaseBackup.startScheduledBackups();
  43. console.log('数据库备份调度已启动');
  44. }
  45. const app = new Hono();
  46. const api = new OpenAPIHono<AuthContext>()
  47. api.onError(errorHandler)
  48. // Rate limiting
  49. api.use('/api/v1/*', async (_, next) => {
  50. // 实现速率限制逻辑
  51. await next()
  52. })
  53. // // 数据库初始化中间件
  54. // api.use('/api/v1/*', async (c, next) => {
  55. // await next();
  56. // })
  57. // 注册Bearer认证方案
  58. api.openAPIRegistry.registerComponent('securitySchemes','bearerAuth',{
  59. type:'http',
  60. scheme:'bearer',
  61. bearerFormat:'JWT',
  62. description:'使用JWT进行认证'
  63. })
  64. // OpenAPI documentation endpoint
  65. // !import.meta.env.PROD
  66. if(1){
  67. // api.doc31('/doc', {
  68. // openapi: '3.1.0',
  69. // info: {
  70. // title: 'API Documentation',
  71. // version: '1.0.0'
  72. // },
  73. // security: [{
  74. // bearerAuth: []
  75. // }]
  76. // // servers: [{ url: '/api/v1' }]
  77. // })
  78. api.get('/doc', (c) => {
  79. const config = {
  80. openapi: '3.1.0',
  81. info: {
  82. title: 'API Documentation',
  83. version: '1.0.0'
  84. },
  85. security: [{
  86. bearerAuth: []
  87. }]
  88. // servers: [{ url: '/api/v1' }]
  89. };
  90. try {
  91. const document = api.getOpenAPI31Document(config);
  92. return c.json(document);
  93. } catch (e: any) {
  94. return c.json({
  95. error: 'OpenAPI document generation failed',
  96. message: e.message || 'Unknown error',
  97. stack: e.stack
  98. }, 500)
  99. }
  100. })
  101. app.get('/ui', swaggerUI({
  102. url: '/doc',
  103. persistAuthorization: true,
  104. manuallySwaggerUIHtml: () => `
  105. <div>
  106. <div id="swagger-ui"></div>
  107. <link rel="stylesheet" href="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui.css" />
  108. <script src="https://ai-oss.d8d.fun/swagger-ui-dist/swagger-ui-bundle.js" crossorigin="anonymous"></script>
  109. <script>
  110. window.onload = () => {
  111. window.ui = SwaggerUIBundle({
  112. dom_id: '#swagger-ui',
  113. url: '/doc',
  114. persistAuthorization: true
  115. })
  116. }
  117. </script>
  118. </div>
  119. `
  120. }))
  121. }
  122. export const userRoutes = api.route('/api/v1/users', userModuleRoutes)
  123. export const authRoutes = api.route('/api/v1/auth', authModuleRoutes)
  124. export const fileApiRoutes = api.route('/api/v1/files', fileModuleRoutes)
  125. export const roleRoutes = api.route('/api/v1/roles', roleModuleRoutes)
  126. // 导入并注册其他路由(暂时保留在server包中)
  127. import advertisementRoutes from './api/advertisements/index'
  128. import advertisementTypeRoutes from './api/advertisement-types/index'
  129. import goodsCategoryRoutes from './api/goods-categories/index'
  130. import goodsRoutes from './api/goods/index'
  131. import cityRoutes from './api/cities/index'
  132. import configRoutes from './api/configs/index'
  133. import expressCompanyRoutes from './api/express-companies/index'
  134. import organizationRoutes from './api/organizations/index'
  135. import supplierRoutes from './api/suppliers/index'
  136. import cardRoutes from './api/cards/index'
  137. import agentRoutes from './api/agents/index'
  138. import merchantRoutes from './api/merchants/index'
  139. import userCardRoutes from './api/user-cards/index'
  140. import userCardBalanceRecordRoutes from './api/user-card-balance-records/index'
  141. import deliveryAddressRoutes from './api/delivery-address/index'
  142. import orderRoutes from './api/orders/index'
  143. import orderGoodsRoutes from './api/orders-goods/index'
  144. import orderRefundRoutes from './api/orders-refund/index'
  145. export const advertisementApiRoutes = api.route('/api/v1/advertisements', advertisementRoutes)
  146. export const advertisementTypeApiRoutes = api.route('/api/v1/advertisement-types', advertisementTypeRoutes)
  147. export const goodsCategoryApiRoutes = api.route('/api/v1/goods-categories', goodsCategoryRoutes)
  148. export const goodsApiRoutes = api.route('/api/v1/goods', goodsRoutes)
  149. export const cityApiRoutes = api.route('/api/v1/cities', cityRoutes)
  150. export const configApiRoutes = api.route('/api/v1/configs', configRoutes)
  151. export const expressCompanyApiRoutes = api.route('/api/v1/express-companies', expressCompanyRoutes)
  152. export const organizationApiRoutes = api.route('/api/v1/organizations', organizationRoutes)
  153. export const supplierApiRoutes = api.route('/api/v1/suppliers', supplierRoutes)
  154. export const cardApiRoutes = api.route('/api/v1/cards', cardRoutes)
  155. export const agentApiRoutes = api.route('/api/v1/agents', agentRoutes)
  156. export const merchantApiRoutes = api.route('/api/v1/merchants', merchantRoutes)
  157. export const userCardApiRoutes = api.route('/api/v1/user-cards', userCardRoutes)
  158. export const userCardBalanceRecordApiRoutes = api.route('/api/v1/user-card-balance-records', userCardBalanceRecordRoutes)
  159. export const deliveryAddressApiRoutes = api.route('/api/v1/delivery-addresses', deliveryAddressRoutes)
  160. export const orderApiRoutes = api.route('/api/v1/orders', orderRoutes)
  161. export const orderGoodsApiRoutes = api.route('/api/v1/orders-goods', orderGoodsRoutes)
  162. export const orderRefundApiRoutes = api.route('/api/v1/orders-refund', orderRefundRoutes)
  163. export type AuthRoutes = typeof authRoutes
  164. export type UserRoutes = typeof userRoutes
  165. export type FileRoutes = typeof fileApiRoutes
  166. export type RoleRoutes = typeof roleRoutes
  167. export type AdvertisementRoutes = typeof advertisementApiRoutes
  168. export type AdvertisementTypeRoutes = typeof advertisementTypeApiRoutes
  169. export type GoodsCategoryRoutes = typeof goodsCategoryApiRoutes
  170. export type GoodsRoutes = typeof goodsApiRoutes
  171. export type CityRoutes = typeof cityApiRoutes
  172. export type ConfigRoutes = typeof configApiRoutes
  173. export type ExpressCompanyRoutes = typeof expressCompanyApiRoutes
  174. export type OrganizationRoutes = typeof organizationApiRoutes
  175. export type SupplierRoutes = typeof supplierApiRoutes
  176. export type CardRoutes = typeof cardApiRoutes
  177. export type AgentRoutes = typeof agentApiRoutes
  178. export type MerchantRoutes = typeof merchantApiRoutes
  179. export type UserCardRoutes = typeof userCardApiRoutes
  180. export type UserCardBalanceRecordRoutes = typeof userCardBalanceRecordApiRoutes
  181. export type DeliveryAddressRoutes = typeof deliveryAddressApiRoutes
  182. export type OrderRoutes = typeof orderApiRoutes
  183. export type OrderGoodsRoutes = typeof orderGoodsApiRoutes
  184. export type OrderRefundRoutes = typeof orderRefundApiRoutes
  185. app.route('/', api)
  186. export default app