Skip to main content
Glama
allowed-keywords.ts1.57 kB
import { ConnectorType } from "../connectors/interface.js"; import { stripCommentsAndStrings } from "./sql-parser.js"; /** * List of allowed keywords for SQL queries * Not only SELECT queries are allowed, * but also other queries that are not destructive */ export const allowedKeywords: Record<ConnectorType, string[]> = { postgres: ["select", "with", "explain", "analyze", "show"], mysql: ["select", "with", "explain", "analyze", "show", "describe", "desc"], mariadb: ["select", "with", "explain", "analyze", "show", "describe", "desc"], sqlite: ["select", "with", "explain", "analyze", "pragma"], sqlserver: ["select", "with", "explain", "showplan"], }; /** * Check if a SQL query is read-only based on its first keyword. * Strips comments and strings before analyzing to avoid false positives. * @param sql The SQL query to check * @param connectorType The database type to check against * @returns True if the query is read-only (starts with allowed keywords) */ export function isReadOnlySQL(sql: string, connectorType: ConnectorType | string): boolean { // Strip comments and strings before analyzing const cleanedSQL = stripCommentsAndStrings(sql).trim().toLowerCase(); // If the statement is empty after removing comments, consider it read-only if (!cleanedSQL) { return true; } const firstWord = cleanedSQL.split(/\s+/)[0]; // Get the appropriate allowed keywords list for this database type const keywordList = allowedKeywords[connectorType as ConnectorType] || []; return keywordList.includes(firstWord); }

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/bytebase/dbhub'

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