ktx/packages/connector-bigquery/src/live-database-introspection.ts

35 lines
1.1 KiB
TypeScript
Raw Permalink Normal View History

2026-05-10 23:51:24 +02:00
import type { LiveDatabaseIntrospectionPort } from '@ktx/context/ingest';
import type { KtxProjectConnectionConfig } from '@ktx/context/project';
2026-05-10 23:12:26 +02:00
import {
2026-05-10 23:51:24 +02:00
KtxBigQueryScanConnector,
type KtxBigQueryClientFactory,
type KtxBigQueryConnectionConfig,
2026-05-10 23:12:26 +02:00
} from './connector.js';
interface CreateBigQueryLiveDatabaseIntrospectionOptions {
2026-05-10 23:51:24 +02:00
connections: Record<string, KtxProjectConnectionConfig>;
clientFactory?: KtxBigQueryClientFactory;
2026-05-10 23:12:26 +02:00
now?: () => Date;
}
export function createBigQueryLiveDatabaseIntrospection(
options: CreateBigQueryLiveDatabaseIntrospectionOptions,
): LiveDatabaseIntrospectionPort {
return {
async extractSchema(connectionId: string) {
2026-05-10 23:51:24 +02:00
const connection = options.connections[connectionId] as KtxBigQueryConnectionConfig | undefined;
const connector = new KtxBigQueryScanConnector({
2026-05-10 23:12:26 +02:00
connectionId,
connection,
clientFactory: options.clientFactory,
now: options.now,
});
try {
return await connector.introspect({ connectionId, driver: 'bigquery' }, { runId: `bigquery-${connectionId}` });
} finally {
await connector.cleanup();
}
},
};
}