@freshguard/freshguard-core 0.11.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +644 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +350 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/connectors/base-connector.d.ts +62 -0
- package/dist/connectors/base-connector.d.ts.map +1 -0
- package/dist/connectors/base-connector.js +549 -0
- package/dist/connectors/base-connector.js.map +1 -0
- package/dist/connectors/bigquery.d.ts +38 -0
- package/dist/connectors/bigquery.d.ts.map +1 -0
- package/dist/connectors/bigquery.js +406 -0
- package/dist/connectors/bigquery.js.map +1 -0
- package/dist/connectors/duckdb.d.ts +36 -0
- package/dist/connectors/duckdb.d.ts.map +1 -0
- package/dist/connectors/duckdb.js +364 -0
- package/dist/connectors/duckdb.js.map +1 -0
- package/dist/connectors/index.d.ts +7 -0
- package/dist/connectors/index.d.ts.map +1 -0
- package/dist/connectors/index.js +7 -0
- package/dist/connectors/index.js.map +1 -0
- package/dist/connectors/mysql.d.ts +32 -0
- package/dist/connectors/mysql.d.ts.map +1 -0
- package/dist/connectors/mysql.js +348 -0
- package/dist/connectors/mysql.js.map +1 -0
- package/dist/connectors/postgres.d.ts +31 -0
- package/dist/connectors/postgres.d.ts.map +1 -0
- package/dist/connectors/postgres.js +326 -0
- package/dist/connectors/postgres.js.map +1 -0
- package/dist/connectors/redshift.d.ts +32 -0
- package/dist/connectors/redshift.d.ts.map +1 -0
- package/dist/connectors/redshift.js +366 -0
- package/dist/connectors/redshift.js.map +1 -0
- package/dist/connectors/snowflake.d.ts +43 -0
- package/dist/connectors/snowflake.d.ts.map +1 -0
- package/dist/connectors/snowflake.js +442 -0
- package/dist/connectors/snowflake.js.map +1 -0
- package/dist/db/index.d.ts +9 -0
- package/dist/db/index.d.ts.map +1 -0
- package/dist/db/index.js +10 -0
- package/dist/db/index.js.map +1 -0
- package/dist/db/migrate.d.ts +12 -0
- package/dist/db/migrate.d.ts.map +1 -0
- package/dist/db/migrate.js +114 -0
- package/dist/db/migrate.js.map +1 -0
- package/dist/db/schema.d.ts +2053 -0
- package/dist/db/schema.d.ts.map +1 -0
- package/dist/db/schema.js +164 -0
- package/dist/db/schema.js.map +1 -0
- package/dist/errors/debug-factory.d.ts +23 -0
- package/dist/errors/debug-factory.d.ts.map +1 -0
- package/dist/errors/debug-factory.js +149 -0
- package/dist/errors/debug-factory.js.map +1 -0
- package/dist/errors/index.d.ts +119 -0
- package/dist/errors/index.d.ts.map +1 -0
- package/dist/errors/index.js +341 -0
- package/dist/errors/index.js.map +1 -0
- package/dist/index.d.ts +9 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -0
- package/dist/metadata/duckdb-storage.d.ts +31 -0
- package/dist/metadata/duckdb-storage.d.ts.map +1 -0
- package/dist/metadata/duckdb-storage.js +230 -0
- package/dist/metadata/duckdb-storage.js.map +1 -0
- package/dist/metadata/factory.d.ts +4 -0
- package/dist/metadata/factory.d.ts.map +1 -0
- package/dist/metadata/factory.js +23 -0
- package/dist/metadata/factory.js.map +1 -0
- package/dist/metadata/index.d.ts +6 -0
- package/dist/metadata/index.d.ts.map +1 -0
- package/dist/metadata/index.js +4 -0
- package/dist/metadata/index.js.map +1 -0
- package/dist/metadata/interface.d.ts +26 -0
- package/dist/metadata/interface.d.ts.map +1 -0
- package/dist/metadata/interface.js +2 -0
- package/dist/metadata/interface.js.map +1 -0
- package/dist/metadata/postgresql-storage.d.ts +32 -0
- package/dist/metadata/postgresql-storage.d.ts.map +1 -0
- package/dist/metadata/postgresql-storage.js +242 -0
- package/dist/metadata/postgresql-storage.js.map +1 -0
- package/dist/metadata/schema-config.d.ts +30 -0
- package/dist/metadata/schema-config.d.ts.map +1 -0
- package/dist/metadata/schema-config.js +94 -0
- package/dist/metadata/schema-config.js.map +1 -0
- package/dist/metadata/types.d.ts +35 -0
- package/dist/metadata/types.d.ts.map +1 -0
- package/dist/metadata/types.js +2 -0
- package/dist/metadata/types.js.map +1 -0
- package/dist/monitor/baseline-calculator.d.ts +30 -0
- package/dist/monitor/baseline-calculator.d.ts.map +1 -0
- package/dist/monitor/baseline-calculator.js +192 -0
- package/dist/monitor/baseline-calculator.js.map +1 -0
- package/dist/monitor/baseline-config.d.ts +37 -0
- package/dist/monitor/baseline-config.d.ts.map +1 -0
- package/dist/monitor/baseline-config.js +156 -0
- package/dist/monitor/baseline-config.js.map +1 -0
- package/dist/monitor/freshness.d.ts +5 -0
- package/dist/monitor/freshness.d.ts.map +1 -0
- package/dist/monitor/freshness.js +239 -0
- package/dist/monitor/freshness.js.map +1 -0
- package/dist/monitor/index.d.ts +5 -0
- package/dist/monitor/index.d.ts.map +1 -0
- package/dist/monitor/index.js +5 -0
- package/dist/monitor/index.js.map +1 -0
- package/dist/monitor/schema-baseline.d.ts +22 -0
- package/dist/monitor/schema-baseline.d.ts.map +1 -0
- package/dist/monitor/schema-baseline.js +211 -0
- package/dist/monitor/schema-baseline.js.map +1 -0
- package/dist/monitor/schema-changes.d.ts +5 -0
- package/dist/monitor/schema-changes.d.ts.map +1 -0
- package/dist/monitor/schema-changes.js +289 -0
- package/dist/monitor/schema-changes.js.map +1 -0
- package/dist/monitor/volume.d.ts +5 -0
- package/dist/monitor/volume.d.ts.map +1 -0
- package/dist/monitor/volume.js +262 -0
- package/dist/monitor/volume.js.map +1 -0
- package/dist/observability/logger.d.ts +63 -0
- package/dist/observability/logger.d.ts.map +1 -0
- package/dist/observability/logger.js +282 -0
- package/dist/observability/logger.js.map +1 -0
- package/dist/observability/metrics.d.ts +106 -0
- package/dist/observability/metrics.d.ts.map +1 -0
- package/dist/observability/metrics.js +441 -0
- package/dist/observability/metrics.js.map +1 -0
- package/dist/query-analyzer.js +526 -0
- package/dist/resilience/circuit-breaker.d.ts +94 -0
- package/dist/resilience/circuit-breaker.d.ts.map +1 -0
- package/dist/resilience/circuit-breaker.js +379 -0
- package/dist/resilience/circuit-breaker.js.map +1 -0
- package/dist/resilience/index.d.ts +7 -0
- package/dist/resilience/index.d.ts.map +1 -0
- package/dist/resilience/index.js +7 -0
- package/dist/resilience/index.js.map +1 -0
- package/dist/resilience/retry-policy.d.ts +87 -0
- package/dist/resilience/retry-policy.d.ts.map +1 -0
- package/dist/resilience/retry-policy.js +423 -0
- package/dist/resilience/retry-policy.js.map +1 -0
- package/dist/resilience/timeout-manager.d.ts +97 -0
- package/dist/resilience/timeout-manager.d.ts.map +1 -0
- package/dist/resilience/timeout-manager.js +339 -0
- package/dist/resilience/timeout-manager.js.map +1 -0
- package/dist/security/query-analyzer.d.ts +82 -0
- package/dist/security/query-analyzer.d.ts.map +1 -0
- package/dist/security/query-analyzer.js +381 -0
- package/dist/security/query-analyzer.js.map +1 -0
- package/dist/security/schema-cache.d.ts +95 -0
- package/dist/security/schema-cache.d.ts.map +1 -0
- package/dist/security/schema-cache.js +344 -0
- package/dist/security/schema-cache.js.map +1 -0
- package/dist/types/connector.d.ts +68 -0
- package/dist/types/connector.d.ts.map +1 -0
- package/dist/types/connector.js +26 -0
- package/dist/types/connector.js.map +1 -0
- package/dist/types.d.ts +244 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +2 -0
- package/dist/types.js.map +1 -0
- package/dist/validation/index.d.ts +7 -0
- package/dist/validation/index.d.ts.map +1 -0
- package/dist/validation/index.js +5 -0
- package/dist/validation/index.js.map +1 -0
- package/dist/validation/runtime-validator.d.ts +70 -0
- package/dist/validation/runtime-validator.d.ts.map +1 -0
- package/dist/validation/runtime-validator.js +206 -0
- package/dist/validation/runtime-validator.js.map +1 -0
- package/dist/validation/sanitizers.d.ts +56 -0
- package/dist/validation/sanitizers.d.ts.map +1 -0
- package/dist/validation/sanitizers.js +264 -0
- package/dist/validation/sanitizers.js.map +1 -0
- package/dist/validation/schemas.d.ts +224 -0
- package/dist/validation/schemas.d.ts.map +1 -0
- package/dist/validation/schemas.js +263 -0
- package/dist/validation/schemas.js.map +1 -0
- package/dist/validators/index.d.ts +18 -0
- package/dist/validators/index.d.ts.map +1 -0
- package/dist/validators/index.js +209 -0
- package/dist/validators/index.js.map +1 -0
- package/package.json +91 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"duckdb-storage.js","sourceRoot":"","sources":["../../src/metadata/duckdb-storage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.d.ts","sourceRoot":"","sources":["../../src/metadata/factory.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAOxD,wBAAsB,qBAAqB,CACzC,MAAM,CAAC,EAAE,qBAAqB,GAC7B,OAAO,CAAC,eAAe,CAAC,CAmB1B"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { DuckDBMetadataStorage } from './duckdb-storage.js';
|
|
2
|
+
import { PostgreSQLMetadataStorage } from './postgresql-storage.js';
|
|
3
|
+
export async function createMetadataStorage(config) {
|
|
4
|
+
let storage;
|
|
5
|
+
if (!config) {
|
|
6
|
+
storage = new DuckDBMetadataStorage();
|
|
7
|
+
}
|
|
8
|
+
else if (config.type === 'duckdb') {
|
|
9
|
+
storage = new DuckDBMetadataStorage(config.path);
|
|
10
|
+
}
|
|
11
|
+
else if (config.type === 'postgresql') {
|
|
12
|
+
if (!config.url) {
|
|
13
|
+
throw new Error('PostgreSQL URL is required');
|
|
14
|
+
}
|
|
15
|
+
storage = new PostgreSQLMetadataStorage(config.url, config);
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
throw new Error(`Unknown storage type: ${config.type}`);
|
|
19
|
+
}
|
|
20
|
+
await storage.initialize();
|
|
21
|
+
return storage;
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=factory.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"factory.js","sourceRoot":"","sources":["../../src/metadata/factory.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAKpE,MAAM,CAAC,KAAK,UAAU,qBAAqB,CACzC,MAA8B;IAE9B,IAAI,OAAwB,CAAC;IAE7B,IAAI,CAAC,MAAM,EAAE,CAAC;QAEZ,OAAO,GAAG,IAAI,qBAAqB,EAAE,CAAC;IACxC,CAAC;SAAM,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;QACpC,OAAO,GAAG,IAAI,qBAAqB,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACnD,CAAC;SAAM,IAAI,MAAM,CAAC,IAAI,KAAK,YAAY,EAAE,CAAC;QACxC,IAAI,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC;YAChB,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;QAChD,CAAC;QACD,OAAO,GAAG,IAAI,yBAAyB,CAAC,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC;IAC9D,CAAC;SAAM,CAAC;QACN,MAAM,IAAI,KAAK,CAAC,yBAA0B,MAAc,CAAC,IAAI,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,MAAM,OAAO,CAAC,UAAU,EAAE,CAAC;IAC3B,OAAO,OAAO,CAAC;AACjB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export type { MetadataStorage } from './interface.js';
|
|
2
|
+
export type { MetadataCheckExecution, MetadataMonitoringRule, MetadataStorageConfig } from './types.js';
|
|
3
|
+
export { createMetadataStorage } from './factory.js';
|
|
4
|
+
export { DuckDBMetadataStorage } from './duckdb-storage.js';
|
|
5
|
+
export { PostgreSQLMetadataStorage } from './postgresql-storage.js';
|
|
6
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/metadata/index.ts"],"names":[],"mappings":"AAIA,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACtD,YAAY,EAAE,sBAAsB,EAAE,sBAAsB,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACxG,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/metadata/index.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAC;AACrD,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAC5D,OAAO,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import type { MonitoringRule, SchemaBaseline } from '../types.js';
|
|
2
|
+
interface MetadataExecution {
|
|
3
|
+
ruleId: string;
|
|
4
|
+
status: 'ok' | 'alert' | 'failed' | 'pending';
|
|
5
|
+
rowCount?: number;
|
|
6
|
+
lagMinutes?: number;
|
|
7
|
+
deviation?: number;
|
|
8
|
+
baselineAverage?: number;
|
|
9
|
+
currentDeviationPercent?: number;
|
|
10
|
+
schemaChanges?: unknown;
|
|
11
|
+
executionDurationMs?: number;
|
|
12
|
+
executedAt: Date;
|
|
13
|
+
error?: string;
|
|
14
|
+
}
|
|
15
|
+
export interface MetadataStorage {
|
|
16
|
+
saveExecution(execution: MetadataExecution): Promise<void>;
|
|
17
|
+
getHistoricalData(ruleId: string, days: number): Promise<MetadataExecution[]>;
|
|
18
|
+
saveRule(rule: MonitoringRule): Promise<void>;
|
|
19
|
+
getRule(ruleId: string): Promise<MonitoringRule | null>;
|
|
20
|
+
storeSchemaBaseline(baseline: SchemaBaseline, adaptationReason?: string): Promise<void>;
|
|
21
|
+
getSchemaBaseline(ruleId: string): Promise<SchemaBaseline | null>;
|
|
22
|
+
initialize(): Promise<void>;
|
|
23
|
+
close(): Promise<void>;
|
|
24
|
+
}
|
|
25
|
+
export {};
|
|
26
|
+
//# sourceMappingURL=interface.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interface.d.ts","sourceRoot":"","sources":["../../src/metadata/interface.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAKlE,UAAU,iBAAiB;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,IAAI,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,UAAU,EAAE,IAAI,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,eAAe;IAI9B,aAAa,CAAC,SAAS,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAQ3D,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC,CAAC;IAK9E,QAAQ,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAK9C,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;IAKxD,mBAAmB,CAAC,QAAQ,EAAE,cAAc,EAAE,gBAAgB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAKxF,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC;IAKlE,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAK5B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CACxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interface.js","sourceRoot":"","sources":["../../src/metadata/interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { MetadataStorage } from './interface.js';
|
|
2
|
+
import type { MetadataStorageConfig } from './types.js';
|
|
3
|
+
import type { SchemaBaseline, MonitoringRule } from '../types.js';
|
|
4
|
+
interface MetadataExecution {
|
|
5
|
+
ruleId: string;
|
|
6
|
+
status: 'ok' | 'alert' | 'failed' | 'pending';
|
|
7
|
+
rowCount?: number;
|
|
8
|
+
lagMinutes?: number;
|
|
9
|
+
deviation?: number;
|
|
10
|
+
baselineAverage?: number;
|
|
11
|
+
currentDeviationPercent?: number;
|
|
12
|
+
schemaChanges?: unknown;
|
|
13
|
+
executionDurationMs?: number;
|
|
14
|
+
executedAt: Date;
|
|
15
|
+
error?: string;
|
|
16
|
+
}
|
|
17
|
+
export declare class PostgreSQLMetadataStorage implements MetadataStorage {
|
|
18
|
+
private readonly connectionUrl;
|
|
19
|
+
private client?;
|
|
20
|
+
private db?;
|
|
21
|
+
constructor(connectionUrl: string, metadataConfig?: MetadataStorageConfig);
|
|
22
|
+
initialize(): Promise<void>;
|
|
23
|
+
saveExecution(execution: MetadataExecution): Promise<void>;
|
|
24
|
+
getHistoricalData(ruleId: string, days: number): Promise<MetadataExecution[]>;
|
|
25
|
+
saveRule(rule: MonitoringRule): Promise<void>;
|
|
26
|
+
getRule(ruleId: string): Promise<MonitoringRule | null>;
|
|
27
|
+
storeSchemaBaseline(baseline: SchemaBaseline, adaptationReason?: string): Promise<void>;
|
|
28
|
+
getSchemaBaseline(ruleId: string): Promise<SchemaBaseline | null>;
|
|
29
|
+
close(): Promise<void>;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=postgresql-storage.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgresql-storage.d.ts","sourceRoot":"","sources":["../../src/metadata/postgresql-storage.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AACxD,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAGlE,UAAU,iBAAiB;IACzB,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,IAAI,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,UAAU,EAAE,IAAI,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAKD,qBAAa,yBAA0B,YAAW,eAAe;IAO7D,OAAO,CAAC,QAAQ,CAAC,aAAa;IANhC,OAAO,CAAC,MAAM,CAAC,CAAe;IAC9B,OAAO,CAAC,EAAE,CAAC,CAA6B;gBAKrB,aAAa,EAAE,MAAM,EACtC,cAAc,CAAC,EAAE,qBAAqB;IAUlC,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAe3B,aAAa,CAAC,SAAS,EAAE,iBAAiB,GAAG,OAAO,CAAC,IAAI,CAAC;IAwB1D,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,iBAAiB,EAAE,CAAC;IAiD7E,QAAQ,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAiC7C,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;IA4CvD,mBAAmB,CAAC,QAAQ,EAAE,cAAc,EAAE,gBAAgB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAwCvF,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,cAAc,GAAG,IAAI,CAAC;IAyCjE,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAO7B"}
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import { drizzle } from 'drizzle-orm/postgres-js';
|
|
2
|
+
import { sql, and, desc, gt } from 'drizzle-orm';
|
|
3
|
+
import postgres from 'postgres';
|
|
4
|
+
import { checkExecutions, monitoringRules, schemaBaselines } from '../db/schema.js';
|
|
5
|
+
import { SchemaConfigResolver } from './schema-config.js';
|
|
6
|
+
import { MetadataStorageError, ErrorHandler } from '../errors/index.js';
|
|
7
|
+
export class PostgreSQLMetadataStorage {
|
|
8
|
+
connectionUrl;
|
|
9
|
+
client;
|
|
10
|
+
db;
|
|
11
|
+
constructor(connectionUrl, metadataConfig) {
|
|
12
|
+
this.connectionUrl = connectionUrl;
|
|
13
|
+
if (metadataConfig?.schema) {
|
|
14
|
+
new SchemaConfigResolver(metadataConfig);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
async initialize() {
|
|
18
|
+
if (this.db)
|
|
19
|
+
return;
|
|
20
|
+
try {
|
|
21
|
+
this.client = postgres(this.connectionUrl);
|
|
22
|
+
this.db = drizzle(this.client);
|
|
23
|
+
await this.db.execute(sql `SELECT 1`);
|
|
24
|
+
}
|
|
25
|
+
catch (error) {
|
|
26
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
27
|
+
throw MetadataStorageError.initializationFailed(sanitizedError.message);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
async saveExecution(execution) {
|
|
31
|
+
if (!this.db) {
|
|
32
|
+
throw MetadataStorageError.initializationFailed('Storage not initialized');
|
|
33
|
+
}
|
|
34
|
+
try {
|
|
35
|
+
await this.db.insert(checkExecutions).values({
|
|
36
|
+
ruleId: execution.ruleId,
|
|
37
|
+
sourceId: execution.ruleId,
|
|
38
|
+
status: execution.status,
|
|
39
|
+
rowCount: execution.rowCount,
|
|
40
|
+
lagMinutes: execution.lagMinutes,
|
|
41
|
+
baselineAverage: execution.baselineAverage?.toString(),
|
|
42
|
+
currentDeviationPercent: execution.deviation?.toString(),
|
|
43
|
+
executionDurationMs: execution.executionDurationMs,
|
|
44
|
+
executedAt: execution.executedAt,
|
|
45
|
+
errorMessage: execution.error,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
catch (error) {
|
|
49
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
50
|
+
throw MetadataStorageError.saveExecutionFailed(execution.ruleId, sanitizedError);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
async getHistoricalData(ruleId, days) {
|
|
54
|
+
if (!this.db) {
|
|
55
|
+
throw MetadataStorageError.initializationFailed('Storage not initialized');
|
|
56
|
+
}
|
|
57
|
+
try {
|
|
58
|
+
const cutoffDate = new Date();
|
|
59
|
+
cutoffDate.setDate(cutoffDate.getDate() - days);
|
|
60
|
+
const results = await this.db
|
|
61
|
+
.select({
|
|
62
|
+
ruleId: checkExecutions.ruleId,
|
|
63
|
+
status: checkExecutions.status,
|
|
64
|
+
rowCount: checkExecutions.rowCount,
|
|
65
|
+
lagMinutes: checkExecutions.lagMinutes,
|
|
66
|
+
deviation: checkExecutions.currentDeviationPercent,
|
|
67
|
+
baselineAverage: checkExecutions.baselineAverage,
|
|
68
|
+
executionDurationMs: checkExecutions.executionDurationMs,
|
|
69
|
+
executedAt: checkExecutions.executedAt,
|
|
70
|
+
error: checkExecutions.errorMessage,
|
|
71
|
+
})
|
|
72
|
+
.from(checkExecutions)
|
|
73
|
+
.where(and(sql `${checkExecutions.ruleId} = ${ruleId}`, gt(checkExecutions.executedAt, cutoffDate), sql `${checkExecutions.rowCount} IS NOT NULL`))
|
|
74
|
+
.orderBy(desc(checkExecutions.executedAt))
|
|
75
|
+
.limit(1000);
|
|
76
|
+
return results.map(row => ({
|
|
77
|
+
ruleId: row.ruleId,
|
|
78
|
+
status: row.status,
|
|
79
|
+
rowCount: row.rowCount || undefined,
|
|
80
|
+
lagMinutes: row.lagMinutes || undefined,
|
|
81
|
+
deviation: row.deviation ? parseFloat(row.deviation) : undefined,
|
|
82
|
+
baselineAverage: row.baselineAverage ? parseFloat(row.baselineAverage) : undefined,
|
|
83
|
+
executionDurationMs: row.executionDurationMs || undefined,
|
|
84
|
+
executedAt: row.executedAt || new Date(),
|
|
85
|
+
error: row.error || undefined,
|
|
86
|
+
}));
|
|
87
|
+
}
|
|
88
|
+
catch (error) {
|
|
89
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
90
|
+
throw MetadataStorageError.getHistoricalDataFailed(ruleId, days, sanitizedError);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
async saveRule(rule) {
|
|
94
|
+
if (!this.db) {
|
|
95
|
+
throw MetadataStorageError.initializationFailed('Storage not initialized');
|
|
96
|
+
}
|
|
97
|
+
try {
|
|
98
|
+
await this.db
|
|
99
|
+
.insert(monitoringRules)
|
|
100
|
+
.values({
|
|
101
|
+
id: rule.id,
|
|
102
|
+
sourceId: rule.sourceId,
|
|
103
|
+
name: rule.name,
|
|
104
|
+
ruleType: rule.ruleType,
|
|
105
|
+
tableName: rule.tableName,
|
|
106
|
+
checkIntervalMinutes: rule.checkIntervalMinutes,
|
|
107
|
+
isActive: rule.isActive,
|
|
108
|
+
createdAt: rule.createdAt,
|
|
109
|
+
updatedAt: rule.updatedAt,
|
|
110
|
+
})
|
|
111
|
+
.onConflictDoUpdate({
|
|
112
|
+
target: monitoringRules.id,
|
|
113
|
+
set: {
|
|
114
|
+
name: rule.name,
|
|
115
|
+
ruleType: rule.ruleType,
|
|
116
|
+
updatedAt: rule.updatedAt,
|
|
117
|
+
},
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
catch (error) {
|
|
121
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
122
|
+
throw MetadataStorageError.saveRuleFailed(rule.id, sanitizedError);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
async getRule(ruleId) {
|
|
126
|
+
if (!this.db) {
|
|
127
|
+
throw MetadataStorageError.initializationFailed('Storage not initialized');
|
|
128
|
+
}
|
|
129
|
+
try {
|
|
130
|
+
const results = await this.db
|
|
131
|
+
.select({
|
|
132
|
+
id: monitoringRules.id,
|
|
133
|
+
sourceId: monitoringRules.sourceId,
|
|
134
|
+
name: monitoringRules.name,
|
|
135
|
+
tableName: monitoringRules.tableName,
|
|
136
|
+
ruleType: monitoringRules.ruleType,
|
|
137
|
+
checkIntervalMinutes: monitoringRules.checkIntervalMinutes,
|
|
138
|
+
isActive: monitoringRules.isActive,
|
|
139
|
+
createdAt: monitoringRules.createdAt,
|
|
140
|
+
updatedAt: monitoringRules.updatedAt,
|
|
141
|
+
})
|
|
142
|
+
.from(monitoringRules)
|
|
143
|
+
.where(sql `${monitoringRules.id} = ${ruleId}`)
|
|
144
|
+
.limit(1);
|
|
145
|
+
if (results.length === 0)
|
|
146
|
+
return null;
|
|
147
|
+
const row = results[0];
|
|
148
|
+
if (!row)
|
|
149
|
+
return null;
|
|
150
|
+
return {
|
|
151
|
+
id: row.id,
|
|
152
|
+
sourceId: row.sourceId,
|
|
153
|
+
name: row.name,
|
|
154
|
+
tableName: row.tableName,
|
|
155
|
+
ruleType: row.ruleType,
|
|
156
|
+
checkIntervalMinutes: row.checkIntervalMinutes || 5,
|
|
157
|
+
isActive: row.isActive || false,
|
|
158
|
+
createdAt: row.createdAt || new Date(),
|
|
159
|
+
updatedAt: row.updatedAt || new Date(),
|
|
160
|
+
};
|
|
161
|
+
}
|
|
162
|
+
catch (error) {
|
|
163
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
164
|
+
throw MetadataStorageError.getRuleFailed(ruleId, sanitizedError);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
async storeSchemaBaseline(baseline, adaptationReason) {
|
|
168
|
+
if (!this.db) {
|
|
169
|
+
throw MetadataStorageError.initializationFailed('Database not initialized');
|
|
170
|
+
}
|
|
171
|
+
try {
|
|
172
|
+
await this.db
|
|
173
|
+
.insert(schemaBaselines)
|
|
174
|
+
.values({
|
|
175
|
+
ruleId: baseline.ruleId,
|
|
176
|
+
tableName: baseline.tableName,
|
|
177
|
+
schemaSnapshot: baseline.schema,
|
|
178
|
+
schemaHash: baseline.schemaHash,
|
|
179
|
+
capturedAt: baseline.capturedAt,
|
|
180
|
+
updatedAt: new Date(),
|
|
181
|
+
adaptationReason: adaptationReason || null,
|
|
182
|
+
})
|
|
183
|
+
.onConflictDoUpdate({
|
|
184
|
+
target: [schemaBaselines.ruleId],
|
|
185
|
+
set: {
|
|
186
|
+
tableName: baseline.tableName,
|
|
187
|
+
schemaSnapshot: baseline.schema,
|
|
188
|
+
schemaHash: baseline.schemaHash,
|
|
189
|
+
capturedAt: baseline.capturedAt,
|
|
190
|
+
updatedAt: new Date(),
|
|
191
|
+
adaptationReason: adaptationReason || null,
|
|
192
|
+
},
|
|
193
|
+
});
|
|
194
|
+
}
|
|
195
|
+
catch (error) {
|
|
196
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
197
|
+
throw new MetadataStorageError('Failed to store schema baseline', 'storeSchemaBaseline', { ruleId: baseline.ruleId }, sanitizedError);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
async getSchemaBaseline(ruleId) {
|
|
201
|
+
if (!this.db) {
|
|
202
|
+
throw MetadataStorageError.initializationFailed('Database not initialized');
|
|
203
|
+
}
|
|
204
|
+
try {
|
|
205
|
+
const results = await this.db
|
|
206
|
+
.select({
|
|
207
|
+
ruleId: schemaBaselines.ruleId,
|
|
208
|
+
tableName: schemaBaselines.tableName,
|
|
209
|
+
schema: schemaBaselines.schemaSnapshot,
|
|
210
|
+
schemaHash: schemaBaselines.schemaHash,
|
|
211
|
+
capturedAt: schemaBaselines.capturedAt,
|
|
212
|
+
})
|
|
213
|
+
.from(schemaBaselines)
|
|
214
|
+
.where(sql `${schemaBaselines.ruleId} = ${ruleId}`)
|
|
215
|
+
.limit(1);
|
|
216
|
+
if (results.length === 0)
|
|
217
|
+
return null;
|
|
218
|
+
const row = results[0];
|
|
219
|
+
if (!row)
|
|
220
|
+
return null;
|
|
221
|
+
return {
|
|
222
|
+
ruleId: row.ruleId,
|
|
223
|
+
tableName: row.tableName,
|
|
224
|
+
schema: row.schema,
|
|
225
|
+
schemaHash: row.schemaHash,
|
|
226
|
+
capturedAt: row.capturedAt,
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
catch (error) {
|
|
230
|
+
const sanitizedError = ErrorHandler.sanitize(error);
|
|
231
|
+
throw new MetadataStorageError('Failed to get schema baseline', 'getSchemaBaseline', { ruleId }, sanitizedError);
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
async close() {
|
|
235
|
+
if (this.client) {
|
|
236
|
+
await this.client.end();
|
|
237
|
+
this.client = undefined;
|
|
238
|
+
this.db = undefined;
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
//# sourceMappingURL=postgresql-storage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgresql-storage.js","sourceRoot":"","sources":["../../src/metadata/postgresql-storage.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { MetadataStorageConfig } from './types.js';
|
|
2
|
+
export interface ResolvedSchemaConfig {
|
|
3
|
+
schemaName: string;
|
|
4
|
+
tablePrefix: string;
|
|
5
|
+
tables: {
|
|
6
|
+
checkExecutions: string;
|
|
7
|
+
monitoringRules: string;
|
|
8
|
+
};
|
|
9
|
+
qualifiedNames: {
|
|
10
|
+
checkExecutions: string;
|
|
11
|
+
monitoringRules: string;
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
export declare class SchemaConfigResolver {
|
|
15
|
+
private readonly config;
|
|
16
|
+
constructor(metadataConfig: MetadataStorageConfig);
|
|
17
|
+
getConfig(): ResolvedSchemaConfig;
|
|
18
|
+
getQualifiedTableName(baseTableName: keyof ResolvedSchemaConfig['tables']): string;
|
|
19
|
+
getSchemaName(): string;
|
|
20
|
+
getTablePrefix(): string;
|
|
21
|
+
getTableName(baseTableName: keyof ResolvedSchemaConfig['tables']): string;
|
|
22
|
+
private resolveConfiguration;
|
|
23
|
+
private applyTablePrefix;
|
|
24
|
+
private createQualifiedName;
|
|
25
|
+
private validateConfiguration;
|
|
26
|
+
private isValidIdentifier;
|
|
27
|
+
private isValidTablePrefix;
|
|
28
|
+
private isReservedKeyword;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=schema-config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-config.d.ts","sourceRoot":"","sources":["../../src/metadata/schema-config.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,YAAY,CAAC;AAMxD,MAAM,WAAW,oBAAoB;IACnC,UAAU,EAAE,MAAM,CAAC;IACnB,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE;QACN,eAAe,EAAE,MAAM,CAAC;QACxB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;IACF,cAAc,EAAE;QACd,eAAe,EAAE,MAAM,CAAC;QACxB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAQD,qBAAa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAuB;gBAElC,cAAc,EAAE,qBAAqB;IAQjD,SAAS,IAAI,oBAAoB;IAOjC,qBAAqB,CAAC,aAAa,EAAE,MAAM,oBAAoB,CAAC,QAAQ,CAAC,GAAG,MAAM;IAOlF,aAAa,IAAI,MAAM;IAOvB,cAAc,IAAI,MAAM;IAOxB,YAAY,CAAC,aAAa,EAAE,MAAM,oBAAoB,CAAC,QAAQ,CAAC,GAAG,MAAM;IAOzE,OAAO,CAAC,oBAAoB;IAoC5B,OAAO,CAAC,gBAAgB;IAcxB,OAAO,CAAC,mBAAmB;IAQ3B,OAAO,CAAC,qBAAqB;IAkC7B,OAAO,CAAC,iBAAiB;IAqBzB,OAAO,CAAC,kBAAkB;IAiB1B,OAAO,CAAC,iBAAiB;CAY1B"}
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
import { ConfigurationError } from '../errors/index.js';
|
|
2
|
+
export class SchemaConfigResolver {
|
|
3
|
+
config;
|
|
4
|
+
constructor(metadataConfig) {
|
|
5
|
+
this.config = this.resolveConfiguration(metadataConfig);
|
|
6
|
+
this.validateConfiguration();
|
|
7
|
+
}
|
|
8
|
+
getConfig() {
|
|
9
|
+
return this.config;
|
|
10
|
+
}
|
|
11
|
+
getQualifiedTableName(baseTableName) {
|
|
12
|
+
return this.config.qualifiedNames[baseTableName];
|
|
13
|
+
}
|
|
14
|
+
getSchemaName() {
|
|
15
|
+
return this.config.schemaName;
|
|
16
|
+
}
|
|
17
|
+
getTablePrefix() {
|
|
18
|
+
return this.config.tablePrefix;
|
|
19
|
+
}
|
|
20
|
+
getTableName(baseTableName) {
|
|
21
|
+
return this.config.tables[baseTableName];
|
|
22
|
+
}
|
|
23
|
+
resolveConfiguration(metadataConfig) {
|
|
24
|
+
const schemaConfig = metadataConfig.schema || {};
|
|
25
|
+
const schemaName = schemaConfig.name || 'public';
|
|
26
|
+
const tablePrefix = schemaConfig.tablePrefix || '';
|
|
27
|
+
const tables = {
|
|
28
|
+
checkExecutions: this.applyTablePrefix(schemaConfig.tables?.checkExecutions || 'checkExecutions', tablePrefix),
|
|
29
|
+
monitoringRules: this.applyTablePrefix(schemaConfig.tables?.monitoringRules || 'monitoringRules', tablePrefix),
|
|
30
|
+
};
|
|
31
|
+
const qualifiedNames = {
|
|
32
|
+
checkExecutions: this.createQualifiedName(schemaName, tables.checkExecutions),
|
|
33
|
+
monitoringRules: this.createQualifiedName(schemaName, tables.monitoringRules),
|
|
34
|
+
};
|
|
35
|
+
return {
|
|
36
|
+
schemaName,
|
|
37
|
+
tablePrefix,
|
|
38
|
+
tables,
|
|
39
|
+
qualifiedNames,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
applyTablePrefix(tableName, prefix) {
|
|
43
|
+
if (!prefix)
|
|
44
|
+
return tableName;
|
|
45
|
+
if (tableName.startsWith(prefix)) {
|
|
46
|
+
return tableName;
|
|
47
|
+
}
|
|
48
|
+
return `${prefix}${tableName}`;
|
|
49
|
+
}
|
|
50
|
+
createQualifiedName(schemaName, tableName) {
|
|
51
|
+
return `${schemaName}.${tableName}`;
|
|
52
|
+
}
|
|
53
|
+
validateConfiguration() {
|
|
54
|
+
if (!this.isValidIdentifier(this.config.schemaName)) {
|
|
55
|
+
throw ConfigurationError.invalidValue('schema.name', this.config.schemaName, 'valid PostgreSQL schema name');
|
|
56
|
+
}
|
|
57
|
+
if (this.config.tablePrefix && !this.isValidTablePrefix(this.config.tablePrefix)) {
|
|
58
|
+
throw ConfigurationError.invalidValue('schema.tablePrefix', this.config.tablePrefix, 'valid PostgreSQL table prefix');
|
|
59
|
+
}
|
|
60
|
+
Object.entries(this.config.tables).forEach(([key, tableName]) => {
|
|
61
|
+
if (!this.isValidIdentifier(tableName)) {
|
|
62
|
+
throw ConfigurationError.invalidValue(`schema.tables.${key}`, tableName, 'valid PostgreSQL table name');
|
|
63
|
+
}
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
isValidIdentifier(identifier) {
|
|
67
|
+
if (!identifier || typeof identifier !== 'string') {
|
|
68
|
+
return false;
|
|
69
|
+
}
|
|
70
|
+
const identifierPattern = /^[a-zA-Z_][a-zA-Z0-9_]*$/;
|
|
71
|
+
return (identifier.length <= 63 &&
|
|
72
|
+
identifierPattern.test(identifier) &&
|
|
73
|
+
!this.isReservedKeyword(identifier.toLowerCase()));
|
|
74
|
+
}
|
|
75
|
+
isValidTablePrefix(prefix) {
|
|
76
|
+
if (!prefix || typeof prefix !== 'string') {
|
|
77
|
+
return false;
|
|
78
|
+
}
|
|
79
|
+
const prefixPattern = /^[a-zA-Z0-9_]*$/;
|
|
80
|
+
return (prefix.length <= 20 &&
|
|
81
|
+
prefixPattern.test(prefix));
|
|
82
|
+
}
|
|
83
|
+
isReservedKeyword(identifier) {
|
|
84
|
+
const reservedKeywords = new Set([
|
|
85
|
+
'select', 'from', 'where', 'insert', 'update', 'delete', 'create', 'drop',
|
|
86
|
+
'table', 'index', 'view', 'user', 'group', 'order', 'by', 'limit',
|
|
87
|
+
'offset', 'join', 'inner', 'left', 'right', 'outer', 'on', 'as',
|
|
88
|
+
'and', 'or', 'not', 'null', 'true', 'false', 'default', 'primary',
|
|
89
|
+
'key', 'foreign', 'references', 'constraint', 'unique', 'check'
|
|
90
|
+
]);
|
|
91
|
+
return reservedKeywords.has(identifier);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=schema-config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schema-config.js","sourceRoot":"","sources":["../../src/metadata/schema-config.ts"],"names":[],"mappings":"AAUA,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAwBxD,MAAM,OAAO,oBAAoB;IACd,MAAM,CAAuB;IAE9C,YAAY,cAAqC;QAC/C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAC;QACxD,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAKD,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;IAKD,qBAAqB,CAAC,aAAmD;QACvE,OAAO,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,aAAa,CAAC,CAAC;IACnD,CAAC;IAKD,aAAa;QACX,OAAO,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC;IAChC,CAAC;IAKD,cAAc;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC;IACjC,CAAC;IAKD,YAAY,CAAC,aAAmD;QAC9D,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;IAC3C,CAAC;IAKO,oBAAoB,CAAC,cAAqC;QAChE,MAAM,YAAY,GAAG,cAAc,CAAC,MAAM,IAAI,EAAE,CAAC;QAGjD,MAAM,UAAU,GAAG,YAAY,CAAC,IAAI,IAAI,QAAQ,CAAC;QACjD,MAAM,WAAW,GAAG,YAAY,CAAC,WAAW,IAAI,EAAE,CAAC;QAGnD,MAAM,MAAM,GAAG;YACb,eAAe,EAAE,IAAI,CAAC,gBAAgB,CACpC,YAAY,CAAC,MAAM,EAAE,eAAe,IAAI,iBAAiB,EACzD,WAAW,CACZ;YACD,eAAe,EAAE,IAAI,CAAC,gBAAgB,CACpC,YAAY,CAAC,MAAM,EAAE,eAAe,IAAI,iBAAiB,EACzD,WAAW,CACZ;SACF,CAAC;QAGF,MAAM,cAAc,GAAG;YACrB,eAAe,EAAE,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC;YAC7E,eAAe,EAAE,IAAI,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,eAAe,CAAC;SAC9E,CAAC;QAEF,OAAO;YACL,UAAU;YACV,WAAW;YACX,MAAM;YACN,cAAc;SACf,CAAC;IACJ,CAAC;IAKO,gBAAgB,CAAC,SAAiB,EAAE,MAAc;QACxD,IAAI,CAAC,MAAM;YAAE,OAAO,SAAS,CAAC;QAG9B,IAAI,SAAS,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YACjC,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,OAAO,GAAG,MAAM,GAAG,SAAS,EAAE,CAAC;IACjC,CAAC;IAKO,mBAAmB,CAAC,UAAkB,EAAE,SAAiB;QAE/D,OAAO,GAAG,UAAU,IAAI,SAAS,EAAE,CAAC;IACtC,CAAC;IAKO,qBAAqB;QAE3B,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,EAAE,CAAC;YACpD,MAAM,kBAAkB,CAAC,YAAY,CACnC,aAAa,EACb,IAAI,CAAC,MAAM,CAAC,UAAU,EACtB,8BAA8B,CAC/B,CAAC;QACJ,CAAC;QAGD,IAAI,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;YACjF,MAAM,kBAAkB,CAAC,YAAY,CACnC,oBAAoB,EACpB,IAAI,CAAC,MAAM,CAAC,WAAW,EACvB,+BAA+B,CAChC,CAAC;QACJ,CAAC;QAGD,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,EAAE,SAAS,CAAC,EAAE,EAAE;YAC9D,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAAE,CAAC;gBACvC,MAAM,kBAAkB,CAAC,YAAY,CACnC,iBAAiB,GAAG,EAAE,EACtB,SAAS,EACT,6BAA6B,CAC9B,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAKO,iBAAiB,CAAC,UAAkB;QAC1C,IAAI,CAAC,UAAU,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE,CAAC;YAClD,OAAO,KAAK,CAAC;QACf,CAAC;QAMD,MAAM,iBAAiB,GAAG,0BAA0B,CAAC;QAErD,OAAO,CACL,UAAU,CAAC,MAAM,IAAI,EAAE;YACvB,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC;YAClC,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CAClD,CAAC;IACJ,CAAC;IAKO,kBAAkB,CAAC,MAAc;QACvC,IAAI,CAAC,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;YAC1C,OAAO,KAAK,CAAC;QACf,CAAC;QAGD,MAAM,aAAa,GAAG,iBAAiB,CAAC;QAExC,OAAO,CACL,MAAM,CAAC,MAAM,IAAI,EAAE;YACnB,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAC3B,CAAC;IACJ,CAAC;IAKO,iBAAiB,CAAC,UAAkB;QAE1C,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC;YAC/B,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM;YACzE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO;YACjE,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI;YAC/D,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE,SAAS;YACjE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,YAAY,EAAE,QAAQ,EAAE,OAAO;SAChE,CAAC,CAAC;QAEH,OAAO,gBAAgB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;CACF"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface MetadataCheckExecution {
|
|
2
|
+
ruleId: string;
|
|
3
|
+
status: 'ok' | 'alert' | 'failed' | 'pending';
|
|
4
|
+
rowCount?: number;
|
|
5
|
+
lagMinutes?: number;
|
|
6
|
+
deviation?: number;
|
|
7
|
+
baselineAverage?: number;
|
|
8
|
+
currentDeviationPercent?: number;
|
|
9
|
+
schemaChanges?: unknown;
|
|
10
|
+
executionDurationMs?: number;
|
|
11
|
+
executedAt: Date;
|
|
12
|
+
error?: string;
|
|
13
|
+
}
|
|
14
|
+
export interface MetadataMonitoringRule {
|
|
15
|
+
id: string;
|
|
16
|
+
name: string;
|
|
17
|
+
type: 'freshness' | 'volume' | 'custom';
|
|
18
|
+
config: Record<string, any>;
|
|
19
|
+
createdAt: Date;
|
|
20
|
+
updatedAt: Date;
|
|
21
|
+
}
|
|
22
|
+
export interface MetadataStorageConfig {
|
|
23
|
+
type: 'duckdb' | 'postgresql';
|
|
24
|
+
path?: string;
|
|
25
|
+
url?: string;
|
|
26
|
+
schema?: {
|
|
27
|
+
name?: string;
|
|
28
|
+
tablePrefix?: string;
|
|
29
|
+
tables?: {
|
|
30
|
+
checkExecutions?: string;
|
|
31
|
+
monitoringRules?: string;
|
|
32
|
+
};
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/metadata/types.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,IAAI,GAAG,OAAO,GAAG,QAAQ,GAAG,SAAS,CAAC;IAC9C,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,uBAAuB,CAAC,EAAE,MAAM,CAAC;IACjC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,UAAU,EAAE,IAAI,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,sBAAsB;IACrC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,WAAW,GAAG,QAAQ,GAAG,QAAQ,CAAC;IACxC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC5B,SAAS,EAAE,IAAI,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;CACjB;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,QAAQ,GAAG,YAAY,CAAC;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IAGb,MAAM,CAAC,EAAE;QACP,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,WAAW,CAAC,EAAE,MAAM,CAAC;QACrB,MAAM,CAAC,EAAE;YACP,eAAe,CAAC,EAAE,MAAM,CAAC;YACzB,eAAe,CAAC,EAAE,MAAM,CAAC;SAC1B,CAAC;KACH,CAAC;CACH"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/metadata/types.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { MetadataCheckExecution } from '../metadata/types.js';
|
|
2
|
+
import type { ResolvedBaselineConfig } from './baseline-config.js';
|
|
3
|
+
export interface HistoricalDataPoint {
|
|
4
|
+
rowCount: number;
|
|
5
|
+
executedAt: Date;
|
|
6
|
+
}
|
|
7
|
+
export interface BaselineResult {
|
|
8
|
+
mean: number;
|
|
9
|
+
deviationPercent: number;
|
|
10
|
+
dataPointsUsed: number;
|
|
11
|
+
calculationMethod: string;
|
|
12
|
+
seasonalAdjusted?: boolean;
|
|
13
|
+
}
|
|
14
|
+
export declare class BaselineCalculator {
|
|
15
|
+
private readonly config;
|
|
16
|
+
constructor(config: ResolvedBaselineConfig);
|
|
17
|
+
calculateBaseline(historicalData: MetadataCheckExecution[], currentRowCount: number): BaselineResult;
|
|
18
|
+
private convertToDataPoints;
|
|
19
|
+
private filterData;
|
|
20
|
+
private applySeasonalAdjustment;
|
|
21
|
+
private adjustCurrentValueForSeason;
|
|
22
|
+
private calculateDayOfWeekStats;
|
|
23
|
+
private calculateStatistic;
|
|
24
|
+
private validateValues;
|
|
25
|
+
private calculateMean;
|
|
26
|
+
private calculateMedian;
|
|
27
|
+
private calculateTrimmedMean;
|
|
28
|
+
private calculateDeviation;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=baseline-calculator.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"baseline-calculator.d.ts","sourceRoot":"","sources":["../../src/monitor/baseline-calculator.ts"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AACnE,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAMnE,MAAM,WAAW,mBAAmB;IAClC,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,IAAI,CAAC;CAClB;AAKD,MAAM,WAAW,cAAc;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,EAAE,MAAM,CAAC;IACzB,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAgBD,qBAAa,kBAAkB;IACjB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,sBAAsB;IAK3D,iBAAiB,CACf,cAAc,EAAE,sBAAsB,EAAE,EACxC,eAAe,EAAE,MAAM,GACtB,cAAc;IA4DjB,OAAO,CAAC,mBAAmB;IAY3B,OAAO,CAAC,UAAU;IAelB,OAAO,CAAC,uBAAuB;IAsC/B,OAAO,CAAC,2BAA2B;IA8BnC,OAAO,CAAC,uBAAuB;IA2B/B,OAAO,CAAC,kBAAkB;IAwB1B,OAAO,CAAC,cAAc;IAatB,OAAO,CAAC,aAAa;IAerB,OAAO,CAAC,eAAe;IAuBvB,OAAO,CAAC,oBAAoB;IAuB5B,OAAO,CAAC,kBAAkB;CAe3B"}
|