Skip to main content
Glama

SingleStore MCP Server

s2_manager.py1.93 kB
import singlestoredb as s2 from src.config.config import get_settings import src.version as version # Deployment can be local or remote MCP_PROGRAM_NAME = "{deployment} MCP Server" class S2Manager: """ Manages SingleStore database connections with custom connection attributes for tracking. """ def __init__(self, host, user, password, database=None, **kwargs): self.host = host self.user = user self.password = password self.database = database self.extra_kwargs = kwargs settings = get_settings() deployment = "Remote" if settings.is_remote else "Local" conn_attrs = { "program_name": MCP_PROGRAM_NAME.format(deployment=deployment), "program_version": getattr(version, "__version__", "unknown"), } if "conn_attrs" in self.extra_kwargs: conn_attrs.update(self.extra_kwargs.pop("conn_attrs")) self.connection = s2.connect( host=self.host, user=self.user, password=self.password, database=self.database, conn_attrs=conn_attrs, **self.extra_kwargs, ) self.cursor = self.connection.cursor() def execute(self, query, args=None): return self.cursor.execute(query, args=args) def fetchmany(self, size=10): """ Fetches the next set of rows from the result set of a query. Args: size (int): Number of rows to fetch. Defaults to 10. Returns: list: List of rows fetched from the database. """ return self.cursor.fetchmany(size) def fetchall(self): return self.cursor.fetchall() def close(self): """ Closes the cursor and the connection safely. """ if self.cursor: self.cursor.close() if self.connection: self.connection.close()

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/singlestore-labs/mcp-server-singlestore'

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