159 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			159 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | ||
|  * @swagger
 | ||
|  * tags:
 | ||
|  *   name: Matching
 | ||
|  *   description: 匹配订单相关接口
 | ||
|  */
 | ||
| /**
 | ||
|  * @swagger
 | ||
|  * /api/matching/my-orders:
 | ||
|  *   get:
 | ||
|  *     summary: 获取用户的匹配订单列表
 | ||
|  *     tags: [Matching]
 | ||
|  *     security:
 | ||
|  *       - bearerAuth: []
 | ||
|  *     parameters:
 | ||
|  *       - in: query
 | ||
|  *         name: page
 | ||
|  *         schema:
 | ||
|  *           type: integer
 | ||
|  *           default: 1
 | ||
|  *         description: 页码
 | ||
|  *       - in: query
 | ||
|  *         name: limit
 | ||
|  *         schema:
 | ||
|  *           type: integer
 | ||
|  *           default: 10
 | ||
|  *         description: 每页数量
 | ||
|  *     responses:
 | ||
|  *       200:
 | ||
|  *         description: 成功获取匹配订单列表
 | ||
|  *         content:
 | ||
|  *           application/json:
 | ||
|  *             schema:
 | ||
|  *               type: object
 | ||
|  *               properties:
 | ||
|  *                 success:
 | ||
|  *                   type: boolean
 | ||
|  *                 data:
 | ||
|  *                   type: array
 | ||
|  *                   items:
 | ||
|  *                     $ref: '#/components/schemas/MatchingOrder'
 | ||
|  *       401:
 | ||
|  *         description: 未授权
 | ||
|  *       500:
 | ||
|  *         description: 服务器错误
 | ||
|  */
 | ||
| /**
 | ||
|  * @swagger
 | ||
|  * components:
 | ||
|  *   schemas:
 | ||
|  *     MatchingOrder:
 | ||
|  *       type: object
 | ||
|  *       properties:
 | ||
|  *         id:
 | ||
|  *           type: integer
 | ||
|  *           description: 匹配订单ID
 | ||
|  *         initiator_id:
 | ||
|  *           type: integer
 | ||
|  *           description: 发起人ID
 | ||
|  *         matching_type:
 | ||
|  *           type: string
 | ||
|  *           enum: [small, large]
 | ||
|  *           description: 匹配类型(小额或大额)
 | ||
|  *         amount:
 | ||
|  *           type: number
 | ||
|  *           description: 匹配总金额
 | ||
|  *         status:
 | ||
|  *           type: string
 | ||
|  *           enum: [pending, matching, completed, failed]
 | ||
|  *           description: 订单状态
 | ||
|  *         created_at:
 | ||
|  *           type: string
 | ||
|  *           format: date-time
 | ||
|  *           description: 创建时间
 | ||
|  *     Allocation:
 | ||
|  *       type: object
 | ||
|  *       properties:
 | ||
|  *         id:
 | ||
|  *           type: integer
 | ||
|  *           description: 分配ID
 | ||
|  *         from_user_id:
 | ||
|  *           type: integer
 | ||
|  *           description: 发送方用户ID
 | ||
|  *         to_user_id:
 | ||
|  *           type: integer
 | ||
|  *           description: 接收方用户ID
 | ||
|  *         amount:
 | ||
|  *           type: number
 | ||
|  *           description: 分配金额
 | ||
|  *         cycle_number:
 | ||
|  *           type: integer
 | ||
|  *           description: 轮次编号
 | ||
|  *         status:
 | ||
|  *           type: string
 | ||
|  *           enum: [pending, confirmed, rejected, cancelled]
 | ||
|  *           description: 分配状态
 | ||
|  *         created_at:
 | ||
|  *           type: string
 | ||
|  *           format: date-time
 | ||
|  *           description: 创建时间
 | ||
|  */
 | ||
| 
 | ||
| /**
 | ||
|  * @swagger
 | ||
|  * /api/matching/create:
 | ||
|  *   post:
 | ||
|  *     summary: 创建匹配订单
 | ||
|  *     tags: [Matching]
 | ||
|  *     security:
 | ||
|  *       - bearerAuth: []
 | ||
|  *     requestBody:
 | ||
|  *       required: true
 | ||
|  *       content:
 | ||
|  *         application/json:
 | ||
|  *           schema:
 | ||
|  *             type: object
 | ||
|  *             properties:
 | ||
|  *               matchingType:
 | ||
|  *                 type: string
 | ||
|  *                 enum: [small, large]
 | ||
|  *                 default: small
 | ||
|  *                 description: 匹配类型(小额或大额)
 | ||
|  *               customAmount:
 | ||
|  *                 type: number
 | ||
|  *                 description: 大额匹配时的自定义金额(5000-50000之间)
 | ||
|  *     responses:
 | ||
|  *       200:
 | ||
|  *         description: 匹配订单创建成功
 | ||
|  *         content:
 | ||
|  *           application/json:
 | ||
|  *             schema:
 | ||
|  *               type: object
 | ||
|  *               properties:
 | ||
|  *                 success:
 | ||
|  *                   type: boolean
 | ||
|  *                 message:
 | ||
|  *                   type: string
 | ||
|  *                 data:
 | ||
|  *                   type: object
 | ||
|  *                   properties:
 | ||
|  *                     matchingOrderId:
 | ||
|  *                       type: integer
 | ||
|  *                     amounts:
 | ||
|  *                       type: array
 | ||
|  *                       items:
 | ||
|  *                         type: number
 | ||
|  *                     matchingType:
 | ||
|  *                       type: string
 | ||
|  *                     totalAmount:
 | ||
|  *                       type: number
 | ||
|  *       400:
 | ||
|  *         description: 参数错误或用户未满足匹配条件
 | ||
|  *       401:
 | ||
|  *         description: 未授权
 | ||
|  *       404:
 | ||
|  *         description: 用户不存在
 | ||
|  *       500:
 | ||
|  *         description: 服务器错误
 | ||
|  */ |