recover v2 api doc
This commit is contained in:
		
							parent
							
								
									cc482df902
								
							
						
					
					
						commit
						44c322a506
					
				
					 1 changed files with 326 additions and 0 deletions
				
			
		
							
								
								
									
										326
									
								
								doc/llmapiv2.html
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										326
									
								
								doc/llmapiv2.html
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,326 @@ | |||
| <!DOCTYPE html> | ||||
| <html lang="en"> | ||||
| <head> | ||||
|     <meta charset="UTF-8"> | ||||
|     <meta name="viewport" content="width=device-width, initial-scale=1.0"> | ||||
|     <title>LLM API Documentation v2</title> | ||||
|     <style> | ||||
|         body { | ||||
|             font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif; | ||||
|             line-height: 1.6; | ||||
|             color: #333; | ||||
|             max-width: 1200px; | ||||
|             margin: 0 auto; | ||||
|             padding: 20px; | ||||
|         } | ||||
|         pre { | ||||
|             background-color: #f6f8fa; | ||||
|             border-radius: 6px; | ||||
|             padding: 16px; | ||||
|             overflow: auto; | ||||
|         } | ||||
|         code { | ||||
|             font-family: SFMono-Regular, Consolas, "Liberation Mono", Menlo, monospace; | ||||
|             font-size: 85%; | ||||
|             background-color: #f6f8fa; | ||||
|             padding: 0.2em 0.4em; | ||||
|             border-radius: 3px; | ||||
|         } | ||||
|         h1, h2, h3, h4 { | ||||
|             margin-top: 24px; | ||||
|             margin-bottom: 16px; | ||||
|             font-weight: 600; | ||||
|             line-height: 1.25; | ||||
|         } | ||||
|         h1 { font-size: 2em; border-bottom: 1px solid #eaecef; } | ||||
|         h2 { font-size: 1.5em; border-bottom: 1px solid #eaecef; } | ||||
|         h3 { font-size: 1.25em; } | ||||
|         h4 { font-size: 1em; } | ||||
|         .endpoint { | ||||
|             margin: 20px 0; | ||||
|             padding: 20px; | ||||
|             border: 1px solid #ddd; | ||||
|             border-radius: 6px; | ||||
|         } | ||||
|         .method { | ||||
|             font-weight: bold; | ||||
|             color: #fff; | ||||
|             padding: 4px 8px; | ||||
|             border-radius: 4px; | ||||
|             margin-right: 8px; | ||||
|         } | ||||
|         .get { background-color: #61affe; } | ||||
|         .post { background-color: #49cc90; } | ||||
|         .put { background-color: #fca130; } | ||||
|         .delete { background-color: #f93e3e; } | ||||
|     </style> | ||||
| </head> | ||||
| <body> | ||||
|     <h1>LLM API Documentation v2</h1> | ||||
| 
 | ||||
|     <h2>Overview</h2> | ||||
|     <p>This document describes the API endpoints for the LLM service.</p> | ||||
| 
 | ||||
|     <h2>Base URL</h2> | ||||
|     <pre><code>https://llmbackend.local:7890</code></pre> | ||||
| 
 | ||||
|     <h2>Authentication</h2> | ||||
|     <ul> | ||||
|         <li>Admin endpoints require Bearer token authentication obtained from <code>/api/admin/login</code></li> | ||||
|         <li>Client endpoints require access token obtained from <code>/api/auth/token</code></li> | ||||
|     </ul> | ||||
| 
 | ||||
|     <h2>Required Headers</h2> | ||||
|     <p>All API requests must include:</p> | ||||
|     <pre><code>Content-Type: application/json | ||||
| Accept: application/json | ||||
| X-API-Version: 1.0 | ||||
| X-Client-ID: your-client-id</code></pre> | ||||
| 
 | ||||
|     <h2>Endpoints</h2> | ||||
| 
 | ||||
|     <h3>Public Routes</h3> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method get">GET</span> /api/test</h4> | ||||
|         <p>Simple test endpoint to verify API connectivity.</p> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/auth/token</h4> | ||||
|         <p>Exchange auth token for an access token.</p> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "auth_token": "64-character-auth-token" | ||||
| }</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "access_token": "generated-access-token", | ||||
|         "expires_in": 3600 | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <h3>Protected Client Routes</h3> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/llm/request</h4> | ||||
|         <p>Make a request to the LLM service.</p> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {access_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "prompt": "Your prompt text here", | ||||
|     "max_tokens": 100, | ||||
|     "temperature": 0.7, | ||||
|     "top_p": 1, | ||||
|     "frequency_penalty": 0, | ||||
|     "presence_penalty": 0 | ||||
| }</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "response": "LLM generated response" | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <h3>Admin Authentication</h3> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/admin/login</h4> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "email": "your-email", | ||||
|     "password": "your-password" | ||||
| }</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "token": "admin-bearer-token", | ||||
|         "admin": { | ||||
|             "id": 1, | ||||
|             "email": "your-email" | ||||
|         } | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/admin/logout</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method put">PUT</span> /api/admin/change-password</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "current_password": "current-password", | ||||
|     "new_password": "new-password", | ||||
|     "new_password_confirmation": "new-password" | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <h3>Client Management</h3> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method get">GET</span> /api/admin/clients</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "items": [ | ||||
|             { | ||||
|                 "id": 1, | ||||
|                 "name": "Client Name", | ||||
|                 "llm_provider_id": 1, | ||||
|                 "created_at": "2024-12-05T00:00:00Z" | ||||
|             } | ||||
|         ] | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/admin/clients</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "name": "New Client Name", | ||||
|     "llm_provider_id": 1 | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method get">GET</span> /api/admin/clients/{client_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method put">PUT</span> /api/admin/clients/{client_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "name": "Updated Client Name", | ||||
|     "llm_provider_id": 1 | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method delete">DELETE</span> /api/admin/clients/{client_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/admin/clients/{client_id}/auth-token</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "client_id": 1, | ||||
|         "auth_token": "generated-auth-token", | ||||
|         "created_at": "2024-12-05T00:00:00Z" | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <h3>LLM Provider Management</h3> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method get">GET</span> /api/admin/llm-providers</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Response:</h5> | ||||
|         <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         "items": [ | ||||
|             { | ||||
|                 "id": 1, | ||||
|                 "name": "OpenAI", | ||||
|                 "service_name": "openai", | ||||
|                 "api_url": "https://api.openai.com/v1", | ||||
|                 "status": "active", | ||||
|                 "created_at": "2024-12-05T00:00:00Z" | ||||
|             } | ||||
|         ] | ||||
|     } | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method post">POST</span> /api/admin/llm-providers</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "name": "OpenAI", | ||||
|     "service_name": "openai", | ||||
|     "api_url": "https://api.openai.com/v1", | ||||
|     "api_token": "your-api-token", | ||||
|     "status": "active" | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method get">GET</span> /api/admin/llm-providers/{provider_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method put">PUT</span> /api/admin/llm-providers/{provider_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|         <h5>Request Body:</h5> | ||||
|         <pre><code>{ | ||||
|     "name": "Updated OpenAI", | ||||
|     "service_name": "openai", | ||||
|     "api_url": "https://api.openai.com/v1", | ||||
|     "api_token": "your-api-token", | ||||
|     "status": "active" | ||||
| }</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <div class="endpoint"> | ||||
|         <h4><span class="method delete">DELETE</span> /api/admin/llm-providers/{provider_id}</h4> | ||||
|         <h5>Headers:</h5> | ||||
|         <pre><code>Authorization: Bearer {admin_token}</code></pre> | ||||
|     </div> | ||||
| 
 | ||||
|     <h2>Error Responses</h2> | ||||
|     <p>All endpoints return standardized error responses:</p> | ||||
|     <pre><code>{ | ||||
|     "success": false, | ||||
|     "error": "error_code", | ||||
|     "message": "Error message", | ||||
|     "errors": { | ||||
|         "field": ["Error details"] | ||||
|     } | ||||
| }</code></pre> | ||||
| 
 | ||||
|     <h2>Success Responses</h2> | ||||
|     <p>All successful responses follow the format:</p> | ||||
|     <pre><code>{ | ||||
|     "success": true, | ||||
|     "data": { | ||||
|         // Response data | ||||
|     } | ||||
| }</code></pre> | ||||
| </body> | ||||
| </html> | ||||
		Loading…
	
		Reference in a new issue
	
	 Jethro Lin
						Jethro Lin