Class: DuckDBConnector
Defined in: src/connectors/duckdb.ts:50
Secure DuckDB connector
Uses a local DuckDB file (or :memory:) for lightweight, embedded analytics.
Features:
- SQL injection prevention
- File path validation
- Read-only query patterns
- Connection timeouts
- Secure error handling
Example
import { DuckDBConnector } from '@freshguard/freshguard-core';
const connector = new DuckDBConnector({
host: 'local', port: 0,
database: './warehouse.duckdb', // or ':memory:'
username: '', password: '',
});
const tables = await connector.listTables();
Extends
BaseConnector
Constructors
Constructor
new DuckDBConnector(
config,securityConfig?):DuckDBConnector
Defined in: src/connectors/duckdb.ts:60
Parameters
config
ConnectorConfig
Connection config; database is the DuckDB file path or ':memory:'
securityConfig?
Partial<SecurityConfig>
Optional overrides for query timeouts, max rows, and blocked keywords
Returns
DuckDBConnector
Overrides
BaseConnector.constructor
Properties
config
protectedconfig:ConnectorConfig
Defined in: src/connectors/base-connector.ts:63
Inherited from
BaseConnector.config
connectionTimeout
protectedreadonlyconnectionTimeout:number
Defined in: src/connectors/base-connector.ts:49
Inherited from
BaseConnector.connectionTimeout
enableDetailedLogging
protectedreadonlyenableDetailedLogging:boolean
Defined in: src/connectors/base-connector.ts:57
Inherited from
BaseConnector.enableDetailedLogging
enableQueryAnalysis
protectedreadonlyenableQueryAnalysis:boolean
Defined in: src/connectors/base-connector.ts:58
Inherited from
BaseConnector.enableQueryAnalysis
logger
protectedreadonlylogger:StructuredLogger
Defined in: src/connectors/base-connector.ts:53
Inherited from
BaseConnector.logger
maxRows
protectedreadonlymaxRows:number
Defined in: src/connectors/base-connector.ts:51
Inherited from
BaseConnector.maxRows
metrics
protectedreadonlymetrics:MetricsCollector
Defined in: src/connectors/base-connector.ts:54
Inherited from
BaseConnector.metrics
queryAnalyzer
protectedreadonlyqueryAnalyzer:QueryComplexityAnalyzer
Defined in: src/connectors/base-connector.ts:55
Inherited from
BaseConnector.queryAnalyzer
queryTimeout
protectedreadonlyqueryTimeout:number
Defined in: src/connectors/base-connector.ts:50
Inherited from
BaseConnector.queryTimeout
requireSSL
protectedreadonlyrequireSSL:boolean
Defined in: src/connectors/base-connector.ts:52
Inherited from
BaseConnector.requireSSL
schemaCache
protectedreadonlyschemaCache:SchemaCache
Defined in: src/connectors/base-connector.ts:56
Inherited from
BaseConnector.schemaCache
Methods
cleanup()
protectedcleanup():void
Defined in: src/connectors/base-connector.ts:806
Cleanup resources (should be called by subclasses in their close method)
Returns
void
Inherited from
BaseConnector.cleanup
clearSchemaCache()
protectedclearSchemaCache():void
Defined in: src/connectors/base-connector.ts:792
Clear schema cache for testing or maintenance
Returns
void
Inherited from
BaseConnector.clearSchemaCache
close()
close():
Promise<void>
Defined in: src/connectors/duckdb.ts:455
Close the database connection
Returns
Promise<void>
Overrides
BaseConnector.close
connectLegacy()
connectLegacy(
credentials):Promise<void>
Defined in: src/connectors/duckdb.ts:522
Legacy connect method for backward compatibility
Parameters
credentials
Returns
Promise<void>
Deprecated
Use constructor with ConnectorConfig instead
createDebugErrorFactory()
protectedcreateDebugErrorFactory(debugConfig?):DebugErrorFactory
Defined in: src/connectors/base-connector.ts:843
Helper method for subclasses to create debug-enabled error factory
Parameters
debugConfig?
DebugConfig
Returns
DebugErrorFactory
Inherited from
BaseConnector.createDebugErrorFactory
escapeIdentifier()
protectedescapeIdentifier(identifier):string
Defined in: src/connectors/base-connector.ts:475
Escape SQL identifiers to prevent injection
Parameters
identifier
string
Returns
string
Inherited from
BaseConnector.escapeIdentifier
executeParameterizedQuery()
protectedexecuteParameterizedQuery(sql,parameters?):Promise<QueryResultRow[]>
Defined in: src/connectors/duckdb.ts:162
Execute a parameterized SQL query (DuckDB with manual parameter substitution) Note: DuckDB node API has limited prepared statement support, so we use safe parameter substitution
Parameters
sql
string
parameters?
unknown[] = []
Returns
Promise<QueryResultRow[]>
Overrides
BaseConnector.executeParameterizedQuery
executeQuery()
protectedexecuteQuery(sql):Promise<QueryResultRow[]>
Defined in: src/connectors/duckdb.ts:154
Execute a validated SQL query with security measures
Parameters
sql
string
Returns
Promise<QueryResultRow[]>
Overrides
BaseConnector.executeQuery
executeWithTimeout()
protectedexecuteWithTimeout<T>(operation,timeoutMs):Promise<T>
Defined in: src/connectors/base-connector.ts:492
Execute function with timeout protection
Type Parameters
T
T
Parameters
operation
() => Promise<T>
timeoutMs
number
Returns
Promise<T>
Inherited from
BaseConnector.executeWithTimeout
getDatabasePath()
getDatabasePath():
string
Defined in: src/connectors/duckdb.ts:620
Get database file path (DuckDB-specific utility)
Returns
string
getLastModified()
getLastModified(
table):Promise<Date|null>
Defined in: src/connectors/duckdb.ts:428
Get last modified timestamp for DuckDB Since DuckDB doesn't have built-in table modification timestamps, we'll look for common timestamp columns
Parameters
table
string
Returns
Promise<Date | null>
Overrides
BaseConnector.getLastModified
getMaxTimestamp()
getMaxTimestamp(
table,column):Promise<Date|null>
Defined in: src/connectors/base-connector.ts:606
Get maximum timestamp value from a column
Parameters
table
string
column
string
Returns
Promise<Date | null>
Inherited from
BaseConnector.getMaxTimestamp
getMinTimestamp()
getMinTimestamp(
table,column):Promise<Date|null>
Defined in: src/connectors/base-connector.ts:674
Get minimum timestamp value from a column
Parameters
table
string
column
string
Returns
Promise<Date | null>
Inherited from
BaseConnector.getMinTimestamp
getQueryAnalyzerConfig()
protectedgetQueryAnalyzerConfig():QueryAnalyzerConfig
Defined in: src/connectors/base-connector.ts:799
Get query analyzer configuration
Returns
QueryAnalyzerConfig
Inherited from
BaseConnector.getQueryAnalyzerConfig
getRowCount()
getRowCount(
table):Promise<number>
Defined in: src/connectors/base-connector.ts:548
Get row count for a table using parameterized query
Parameters
table
string
Returns
Promise<number>
Inherited from
BaseConnector.getRowCount
getSchemaCacheStats()
protectedgetSchemaCacheStats():CacheStats
Defined in: src/connectors/base-connector.ts:785
Get schema cache statistics
Returns
CacheStats
Inherited from
BaseConnector.getSchemaCacheStats
getTableMetadata()
getTableMetadata(
tableName,timestampColumn?):Promise<{lastUpdate?:Date;rowCount:number; }>
Defined in: src/connectors/duckdb.ts:579
Legacy get table metadata method for backward compatibility
Parameters
tableName
string
timestampColumn?
string = 'updated_at'
Returns
Promise<{ lastUpdate?: Date; rowCount: number; }>
Deprecated
Use getRowCount() and getMaxTimestamp() instead
getTableMetadataFresh()
protectedgetTableMetadataFresh(tableName):Promise<TableMetadata|null>
Defined in: src/connectors/base-connector.ts:330
Get fresh table metadata (to be overridden by specific connectors)