Skip to main content
Glama
importlib_util.py2.77 kB
import importlib.util from importlib import import_module import sys from types import ModuleType from typing import AnyStr from utils import logger def import_module_from_source(*, module_name: str, py_file_path: AnyStr, use_lazy_loader: bool = False) -> ModuleType: """ Low-level API (manual step control) Importing a module from the source file directly """ try: existed_spec = importlib.util.find_spec(module_name) if existed_spec: spec = existed_spec if not spec.loader: raise Exception(f"Failed to load module {module_name} from {py_file_path!r}") else: # Refer to: https://docs.python.org/3/library/importlib.html#importing-a-source-file-directly # FIXME: mypy does not support the type of spec.loader spec = importlib.util.spec_from_file_location(module_name, py_file_path) # type: ignore if not spec or not spec.loader: raise Exception(f"Failed to load module {module_name} from {py_file_path!r}") if use_lazy_loader: # Refer to: https://docs.python.org/3/library/importlib.html#implementing-lazy-imports spec.loader = importlib.util.LazyLoader(spec.loader) module = importlib.util.module_from_spec(spec) if not existed_spec: sys.modules[module_name] = module spec.loader.exec_module(module) return module except Exception as e: logger.error(f"Failed to load module {module_name} from script file '{py_file_path!r}'") raise e def get_subclasses_from_module(mod: ModuleType, parent_type: type) -> list[type]: """ Get all the subclasses of the parent type from the module """ classes = [ x for _, x in vars(mod).items() if isinstance(x, type) and x != parent_type and issubclass(x, parent_type) ] return classes def load_single_subclass_from_source( *, module_name: str, script_path: AnyStr, parent_type: type, use_lazy_loader: bool = False ) -> type: """ Load a single subclass from the source """ module = import_module_from_source( module_name=module_name, py_file_path=script_path, use_lazy_loader=use_lazy_loader ) subclasses = get_subclasses_from_module(module, parent_type) if len(subclasses) == 1: return subclasses[0] elif len(subclasses) == 0: raise Exception(f"Missing subclass of {parent_type.__name__} in {script_path!r}") else: raise Exception(f"Multiple subclasses of {parent_type.__name__} in {script_path!r}") def load_single_router_from_source(module_name: str): """ High-level API (encapsulating the underlying process) """ return import_module(module_name)

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/Cyanty/Arcs-MCP'

If you have feedback or need assistance with the MCP directory API, please join our Discord server