mirror of
				https://github.com/SillyTavern/SillyTavern.git
				synced 2025-06-05 21:59:27 +02:00 
			
		
		
		
	Use abort endpoint for all supported koboldcpp generations
This commit is contained in:
		| @@ -95,6 +95,7 @@ function getKoboldGenerationData(finalPromt, this_settings, this_amount_gen, thi | |||||||
|         singleline: kai_settings.single_line, |         singleline: kai_settings.single_line, | ||||||
|         stop_sequence: kai_settings.use_stop_sequence ? getStoppingStrings(isImpersonate, false) : undefined, |         stop_sequence: kai_settings.use_stop_sequence ? getStoppingStrings(isImpersonate, false) : undefined, | ||||||
|         streaming: kai_settings.streaming_kobold && kai_settings.can_use_streaming, |         streaming: kai_settings.streaming_kobold && kai_settings.can_use_streaming, | ||||||
|  |         can_abort: kai_settings.can_use_streaming, | ||||||
|     }; |     }; | ||||||
|     return generate_data; |     return generate_data; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								server.js
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								server.js
									
									
									
									
									
								
							| @@ -354,7 +354,19 @@ app.post("/generate", jsonParser, async function (request, response_generate = r | |||||||
|     const request_prompt = request.body.prompt; |     const request_prompt = request.body.prompt; | ||||||
|     const controller = new AbortController(); |     const controller = new AbortController(); | ||||||
|     request.socket.removeAllListeners('close'); |     request.socket.removeAllListeners('close'); | ||||||
|     request.socket.on('close', function () { |     request.socket.on('close', async function () { | ||||||
|  |         if (request.body.can_abort && !response_generate.finished) { | ||||||
|  |             try { | ||||||
|  |                 // send abort signal to koboldcpp | ||||||
|  |                 await fetch(`${api_server}/extra/abort`, { | ||||||
|  |                     method: 'POST', | ||||||
|  |                 }); | ||||||
|  |             } catch { | ||||||
|  |                 if ('status' in error) { | ||||||
|  |                     console.log('Status Code from Kobold:', error.status); | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|         controller.abort(); |         controller.abort(); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @@ -412,20 +424,7 @@ app.post("/generate", jsonParser, async function (request, response_generate = r | |||||||
|             response = await fetch(url, { method: 'POST', timeout: 0, ...args }); |             response = await fetch(url, { method: 'POST', timeout: 0, ...args }); | ||||||
|  |  | ||||||
|             if (request.body.streaming) { |             if (request.body.streaming) { | ||||||
|                 request.socket.on('close', async function () { |                 request.socket.on('close', function () { | ||||||
|                     if (controller.signal.aborted) { |  | ||||||
|                         try { |  | ||||||
|                             // send abort signal to koboldcpp |  | ||||||
|                             await fetch(`${api_server}/extra/abort`, { |  | ||||||
|                                 method: 'POST', |  | ||||||
|                             }); |  | ||||||
|                         } catch { |  | ||||||
|                             // likely endpoint not available on older versions of koboldcpp |  | ||||||
|                             if ('status' in error) { |  | ||||||
|                                 console.log('Status Code from Kobold:', error.status); |  | ||||||
|                             } |  | ||||||
|                         } |  | ||||||
|                     } |  | ||||||
|                     response.body.destroy(); // Close the remote stream |                     response.body.destroy(); // Close the remote stream | ||||||
|                     response_generate.end(); // End the Express response |                     response_generate.end(); // End the Express response | ||||||
|                 }); |                 }); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user