feat: added openapi spec
This commit is contained in:
		
							parent
							
								
									8dc085c6a0
								
							
						
					
					
						commit
						bd865c709e
					
				
					 1 changed files with 552 additions and 0 deletions
				
			
		
							
								
								
									
										552
									
								
								api/openapi.yaml
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										552
									
								
								api/openapi.yaml
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,552 @@ | ||||||
|  | openapi: 3.1.1 | ||||||
|  | info: | ||||||
|  |   title: Titles, Users, Reviews, Tags, and Media API | ||||||
|  |   version: 1.0.0 | ||||||
|  | servers: | ||||||
|  |   - url: https://api.example.com | ||||||
|  | paths: | ||||||
|  |   /title: | ||||||
|  |     get: | ||||||
|  |       summary: Get titles | ||||||
|  |       parameters: | ||||||
|  |         - in: query | ||||||
|  |           name: query | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: limit | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 10 | ||||||
|  |         - in: query | ||||||
|  |           name: offset | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 0 | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |             default: all | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of titles | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/Title' | ||||||
|  |         '204': | ||||||
|  |           description: No titles found | ||||||
|  | 
 | ||||||
|  |   /title/{title_id}: | ||||||
|  |     get: | ||||||
|  |       summary: Get title description | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: title_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |             default: all | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Title description | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 $ref: '#/components/schemas/Title' | ||||||
|  |         '404': | ||||||
|  |           description: Title not found | ||||||
|  | 
 | ||||||
|  |     patch: | ||||||
|  |       summary: Update title info | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: title_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/Title' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Update result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  |                   user_json: | ||||||
|  |                     $ref: '#/components/schemas/User' | ||||||
|  | 
 | ||||||
|  |   /title/{title_id}/reviews: | ||||||
|  |     get: | ||||||
|  |       summary: Get title reviews | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: title_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: limit | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 10 | ||||||
|  |         - in: query | ||||||
|  |           name: offset | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 0 | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of reviews | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/Review' | ||||||
|  |         '204': | ||||||
|  |           description: No reviews found | ||||||
|  | 
 | ||||||
|  |   /users/{user_id}: | ||||||
|  |     get: | ||||||
|  |       summary: Get user info | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |             default: all | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: User info | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 $ref: '#/components/schemas/User' | ||||||
|  |         '404': | ||||||
|  |           description: User not found | ||||||
|  | 
 | ||||||
|  |     patch: | ||||||
|  |       summary: Update user | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/User' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Update result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |     delete: | ||||||
|  |       summary: Delete user | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Delete result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |   /users: | ||||||
|  |     get: | ||||||
|  |       summary: Search user | ||||||
|  |       parameters: | ||||||
|  |         - in: query | ||||||
|  |           name: query | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of users | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/User' | ||||||
|  | 
 | ||||||
|  |     post: | ||||||
|  |       summary: Add new user | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/User' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Add result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  |                   user_json: | ||||||
|  |                     $ref: '#/components/schemas/User' | ||||||
|  | 
 | ||||||
|  |   /users/{user_id}/titles: | ||||||
|  |     get: | ||||||
|  |       summary: Get user titles | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: query | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: limit | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 10 | ||||||
|  |         - in: query | ||||||
|  |           name: offset | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 0 | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |             default: all | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of user titles | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/UserTitle' | ||||||
|  |         '204': | ||||||
|  |           description: No titles found | ||||||
|  | 
 | ||||||
|  |     post: | ||||||
|  |       summary: Add user title | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               type: object | ||||||
|  |               properties: | ||||||
|  |                 title_id: | ||||||
|  |                   type: string | ||||||
|  |                 status: | ||||||
|  |                   type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Add result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |     patch: | ||||||
|  |       summary: Update user title | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/UserTitle' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Update result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |     delete: | ||||||
|  |       summary: Delete user title | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: title_id | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Delete result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |   /users/{user_id}/reviews: | ||||||
|  |     get: | ||||||
|  |       summary: Get user reviews | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: user_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |         - in: query | ||||||
|  |           name: limit | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 10 | ||||||
|  |         - in: query | ||||||
|  |           name: offset | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 0 | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of reviews | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/Review' | ||||||
|  | 
 | ||||||
|  |   /reviews: | ||||||
|  |     post: | ||||||
|  |       summary: Add review | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/Review' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Add result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |   /reviews/{review_id}: | ||||||
|  |     patch: | ||||||
|  |       summary: Update review | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: review_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       requestBody: | ||||||
|  |         required: true | ||||||
|  |         content: | ||||||
|  |           application/json: | ||||||
|  |             schema: | ||||||
|  |               $ref: '#/components/schemas/Review' | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Update result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  |     delete: | ||||||
|  |       summary: Delete review | ||||||
|  |       parameters: | ||||||
|  |         - in: path | ||||||
|  |           name: review_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Delete result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |   /tags: | ||||||
|  |     get: | ||||||
|  |       summary: Get tags | ||||||
|  |       parameters: | ||||||
|  |         - in: query | ||||||
|  |           name: limit | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 10 | ||||||
|  |         - in: query | ||||||
|  |           name: offset | ||||||
|  |           schema: | ||||||
|  |             type: integer | ||||||
|  |             default: 0 | ||||||
|  |         - in: query | ||||||
|  |           name: fields | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: List of tags | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: array | ||||||
|  |                 items: | ||||||
|  |                   $ref: '#/components/schemas/Tag' | ||||||
|  | 
 | ||||||
|  |   /media: | ||||||
|  |     post: | ||||||
|  |       summary: Upload image | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Upload result | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  |                   image_id: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  |     get: | ||||||
|  |       summary: Get image path | ||||||
|  |       parameters: | ||||||
|  |         - in: query | ||||||
|  |           name: image_id | ||||||
|  |           required: true | ||||||
|  |           schema: | ||||||
|  |             type: string | ||||||
|  |       responses: | ||||||
|  |         '200': | ||||||
|  |           description: Image path | ||||||
|  |           content: | ||||||
|  |             application/json: | ||||||
|  |               schema: | ||||||
|  |                 type: object | ||||||
|  |                 properties: | ||||||
|  |                   success: | ||||||
|  |                     type: boolean | ||||||
|  |                   error: | ||||||
|  |                     type: string | ||||||
|  |                   image_path: | ||||||
|  |                     type: string | ||||||
|  | 
 | ||||||
|  | components: | ||||||
|  |   schemas: | ||||||
|  |     Title: | ||||||
|  |       type: object | ||||||
|  |       additionalProperties: true | ||||||
|  |     User: | ||||||
|  |       type: object | ||||||
|  |       additionalProperties: true | ||||||
|  |     UserTitle: | ||||||
|  |       type: object | ||||||
|  |       additionalProperties: true | ||||||
|  |     Review: | ||||||
|  |       type: object | ||||||
|  |       additionalProperties: true | ||||||
|  |     Tag: | ||||||
|  |       type: object | ||||||
|  |       additionalProperties: true | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue