database_mcp_sql/
error.rs1#[derive(Debug, thiserror::Error)]
5pub enum SqlError {
6 #[error("Query blocked: only SELECT, SHOW, DESC, DESCRIBE, USE queries are allowed in read-only mode")]
8 ReadOnlyViolation,
9
10 #[error("Operation forbidden: LOAD_FILE() is not allowed for security reasons")]
12 LoadFileBlocked,
13
14 #[error("Operation forbidden: SELECT INTO OUTFILE/DUMPFILE is not allowed for security reasons")]
16 IntoOutfileBlocked,
17
18 #[error("Query blocked: only single statements are allowed")]
20 MultiStatement,
21
22 #[error("Invalid identifier '{0}': must not be empty, whitespace-only, or contain control characters")]
24 InvalidIdentifier(String),
25
26 #[error("Query timed out after {elapsed_secs:.1}s: {sql}")]
28 QueryTimeout {
29 elapsed_secs: f64,
31 sql: String,
33 },
34
35 #[error("Database error: {0}")]
37 Query(String),
38
39 #[error("Table not found: {0}")]
41 TableNotFound(String),
42}
43
44impl From<SqlError> for rmcp::model::ErrorData {
45 fn from(e: SqlError) -> Self {
46 Self::internal_error(e.to_string(), None)
47 }
48}