mirror of
				https://github.com/open-webui/open-webui
				synced 2025-06-26 18:26:48 +00:00 
			
		
		
		
	refac: tools removed UNNECESSARY CODE
This commit is contained in:
		
							parent
							
								
									c9e9ce931b
								
							
						
					
					
						commit
						66db2e1515
					
				| @ -18,6 +18,8 @@ from open_webui.models.tools import Tools | ||||
| from open_webui.models.users import UserModel | ||||
| from open_webui.utils.plugin import load_tools_module_by_id | ||||
| 
 | ||||
| import copy | ||||
| 
 | ||||
| log = logging.getLogger(__name__) | ||||
| 
 | ||||
| 
 | ||||
| @ -48,11 +50,14 @@ def get_tools( | ||||
|         tools = Tools.get_tool_by_id(tool_id) | ||||
|         if tools is None: | ||||
| 
 | ||||
|             if tool_id.startswith("server:"): | ||||
|                 server_idx = int(tool_id.split(":")[1]) | ||||
|                 tool_server_data = request.app.state.TOOL_SERVERS[server_idx] | ||||
| 
 | ||||
|                 tool_dict = { | ||||
|                     "spec": spec, | ||||
|                     "callable": callable, | ||||
|                     "toolkit_id": tool_id, | ||||
|                 "pydantic_model": function_to_pydantic_model(callable), | ||||
|                     # Misc info | ||||
|                     "metadata": { | ||||
|                         "file_handler": hasattr(module, "file_handler") | ||||
| @ -61,7 +66,7 @@ def get_tools( | ||||
|                     }, | ||||
|                 } | ||||
| 
 | ||||
|             continue | ||||
|         else: | ||||
| 
 | ||||
|             module = request.app.state.TOOLS.get(tool_id, None) | ||||
|             if module is None: | ||||
| @ -96,7 +101,9 @@ def get_tools( | ||||
| 
 | ||||
|                 # convert to function that takes only model params and inserts custom params | ||||
|                 original_func = getattr(module, function_name) | ||||
|             callable = apply_extra_params_to_tool_function(original_func, extra_params) | ||||
|                 callable = apply_extra_params_to_tool_function( | ||||
|                     original_func, extra_params | ||||
|                 ) | ||||
| 
 | ||||
|                 if callable.__doc__ and callable.__doc__.strip() != "": | ||||
|                     s = re.split(":(param|return)", callable.__doc__, 1) | ||||
| @ -104,12 +111,10 @@ def get_tools( | ||||
|                 else: | ||||
|                     spec["description"] = function_name | ||||
| 
 | ||||
|             # TODO: This needs to be a pydantic model | ||||
|                 tool_dict = { | ||||
|                     "spec": spec, | ||||
|                     "callable": callable, | ||||
|                     "toolkit_id": tool_id, | ||||
|                 "pydantic_model": function_to_pydantic_model(callable), | ||||
|                     # Misc info | ||||
|                     "metadata": { | ||||
|                         "file_handler": hasattr(module, "file_handler") | ||||
| @ -120,7 +125,9 @@ def get_tools( | ||||
| 
 | ||||
|                 # TODO: if collision, prepend toolkit name | ||||
|                 if function_name in tools_dict: | ||||
|                 log.warning(f"Tool {function_name} already exists in another tools!") | ||||
|                     log.warning( | ||||
|                         f"Tool {function_name} already exists in another tools!" | ||||
|                     ) | ||||
|                     log.warning(f"Collision between {tools} and {tool_id}.") | ||||
|                     log.warning(f"Discarding {tools}.{function_name}") | ||||
|                 else: | ||||
| @ -233,11 +240,11 @@ def get_callable_attributes(tool: object) -> list[Callable]: | ||||
| 
 | ||||
| def get_tools_specs(tool_class: object) -> list[dict]: | ||||
|     function_list = get_callable_attributes(tool_class) | ||||
|     models = map(function_to_pydantic_model, function_list) | ||||
|     return [convert_to_openai_function(tool) for tool in models] | ||||
| 
 | ||||
| 
 | ||||
| import copy | ||||
|     function_model_list = map(function_to_pydantic_model, function_list) | ||||
|     return [ | ||||
|         convert_to_openai_function(function_model) | ||||
|         for function_model in function_model_list | ||||
|     ] | ||||
| 
 | ||||
| 
 | ||||
| def resolve_schema(schema, components): | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user