@pipeline-builder/pipeline-data 3.1.0

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.
@@ -0,0 +1,74 @@
1
+ import { SQL } from 'drizzle-orm';
2
+ import { MessageFilter, PipelineFilter, PluginFilter, CompliancePolicyFilter, ComplianceRuleFilter, ComplianceExemptionFilter, ComplianceAuditFilter, ComplianceScanFilter, ComplianceRuleSubscriptionFilter } from '../core/query-filters';
3
+ /**
4
+ * Build SQL conditions for pipeline queries
5
+ *
6
+ * Access control behavior:
7
+ * - No orgId: system org public only
8
+ * - accessModifier='private': Own org private only
9
+ * - accessModifier='public': Own org public only
10
+ * - No accessModifier (default): Own org public + system org public
11
+ *
12
+ * @param filter - Pipeline filter criteria
13
+ * @param orgId - User's organization ID (optional — anonymous gets system public only)
14
+ * @returns Array of SQL conditions
15
+ */
16
+ export declare function buildPipelineConditions(filter: Partial<PipelineFilter>, orgId?: string): SQL[];
17
+ /**
18
+ * Build SQL conditions for plugin queries
19
+ *
20
+ * Access control behavior:
21
+ * - No orgId: system org public only
22
+ * - accessModifier='private': Own org private only
23
+ * - accessModifier='public': Own org public only
24
+ * - No accessModifier (default): Own org public + system org public
25
+ *
26
+ * @param filter - Plugin filter criteria
27
+ * @param orgId - User's organization ID (optional — anonymous gets system public only)
28
+ * @returns Array of SQL conditions
29
+ */
30
+ export declare function buildPluginConditions(filter: Partial<PluginFilter>, orgId?: string): SQL[];
31
+ /**
32
+ * Build SQL conditions for message queries.
33
+ *
34
+ * Custom access control for messages:
35
+ * - Messages are visible to the sender org (orgId) OR the recipient org (recipientOrgId)
36
+ * - Broadcast announcements (recipientOrgId = '*') are visible to all orgs
37
+ * - System org can see all messages
38
+ *
39
+ * @param filter - Message filter criteria
40
+ * @param orgId - User's organization ID
41
+ * @returns Array of SQL conditions
42
+ */
43
+ export declare function buildMessageConditions(filter: Partial<MessageFilter>, orgId: string): SQL[];
44
+ /**
45
+ * Build SQL conditions for compliance policy queries.
46
+ * Org-scoped: always filters by orgId.
47
+ */
48
+ export declare function buildCompliancePolicyConditions(filter: Partial<CompliancePolicyFilter>, orgId?: string): SQL[];
49
+ /**
50
+ * Build SQL conditions for compliance rule queries.
51
+ * Returns only the requesting org's own rules (org-scoped).
52
+ */
53
+ export declare function buildComplianceRuleConditions(filter: Partial<ComplianceRuleFilter>, orgId?: string): SQL[];
54
+ /**
55
+ * Build SQL conditions for browsing the published rules catalog.
56
+ * Only returns system-org published rules.
57
+ */
58
+ export declare function buildPublishedRuleCatalogConditions(filter: Partial<ComplianceRuleFilter>): SQL[];
59
+ /**
60
+ * Build SQL conditions for compliance rule subscription queries.
61
+ */
62
+ export declare function buildComplianceRuleSubscriptionConditions(filter: Partial<ComplianceRuleSubscriptionFilter>, orgId?: string): SQL[];
63
+ /**
64
+ * Build SQL conditions for compliance exemption queries.
65
+ */
66
+ export declare function buildComplianceExemptionConditions(filter: Partial<ComplianceExemptionFilter>, orgId?: string): SQL[];
67
+ /**
68
+ * Build SQL conditions for compliance audit log queries.
69
+ */
70
+ export declare function buildComplianceAuditConditions(filter: Partial<ComplianceAuditFilter>, orgId?: string): SQL[];
71
+ /**
72
+ * Build SQL conditions for compliance scan queries.
73
+ */
74
+ export declare function buildComplianceScanConditions(filter: Partial<ComplianceScanFilter>, orgId?: string): SQL[];
@@ -0,0 +1,336 @@
1
+ "use strict";
2
+ // Copyright 2026 Pipeline Builder Contributors
3
+ // SPDX-License-Identifier: Apache-2.0
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.buildPipelineConditions = buildPipelineConditions;
6
+ exports.buildPluginConditions = buildPluginConditions;
7
+ exports.buildMessageConditions = buildMessageConditions;
8
+ exports.buildCompliancePolicyConditions = buildCompliancePolicyConditions;
9
+ exports.buildComplianceRuleConditions = buildComplianceRuleConditions;
10
+ exports.buildPublishedRuleCatalogConditions = buildPublishedRuleCatalogConditions;
11
+ exports.buildComplianceRuleSubscriptionConditions = buildComplianceRuleSubscriptionConditions;
12
+ exports.buildComplianceExemptionConditions = buildComplianceExemptionConditions;
13
+ exports.buildComplianceAuditConditions = buildComplianceAuditConditions;
14
+ exports.buildComplianceScanConditions = buildComplianceScanConditions;
15
+ const api_core_1 = require("@pipeline-builder/api-core");
16
+ const drizzle_orm_1 = require("drizzle-orm");
17
+ const access_control_builder_1 = require("./access-control-builder");
18
+ const drizzle_schema_1 = require("../database/drizzle-schema");
19
+ // Query builder instances
20
+ const pipelineBuilder = new access_control_builder_1.AccessControlQueryBuilder(drizzle_schema_1.schema.pipeline);
21
+ const pluginBuilder = new access_control_builder_1.AccessControlQueryBuilder(drizzle_schema_1.schema.plugin);
22
+ /**
23
+ * Build SQL conditions for pipeline queries
24
+ *
25
+ * Access control behavior:
26
+ * - No orgId: system org public only
27
+ * - accessModifier='private': Own org private only
28
+ * - accessModifier='public': Own org public only
29
+ * - No accessModifier (default): Own org public + system org public
30
+ *
31
+ * @param filter - Pipeline filter criteria
32
+ * @param orgId - User's organization ID (optional — anonymous gets system public only)
33
+ * @returns Array of SQL conditions
34
+ */
35
+ function buildPipelineConditions(filter, orgId) {
36
+ // Use generic builder for common conditions (access control, ID, booleans, accessModifier)
37
+ const conditions = pipelineBuilder.buildCommonConditions(filter, orgId);
38
+ // Add pipeline-specific filters
39
+ if (filter.project !== undefined) {
40
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.pipeline.project, (0, access_control_builder_1.normalizeStringFilter)(filter.project)));
41
+ }
42
+ if (filter.organization !== undefined) {
43
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.pipeline.organization, (0, access_control_builder_1.normalizeStringFilter)(filter.organization)));
44
+ }
45
+ if (filter.keyword !== undefined) {
46
+ conditions.push((0, access_control_builder_1.buildJsonbKeywordCondition)(drizzle_schema_1.schema.pipeline.keywords, (0, access_control_builder_1.normalizeStringFilter)(filter.keyword)));
47
+ }
48
+ return conditions;
49
+ }
50
+ /**
51
+ * Build SQL conditions for plugin queries
52
+ *
53
+ * Access control behavior:
54
+ * - No orgId: system org public only
55
+ * - accessModifier='private': Own org private only
56
+ * - accessModifier='public': Own org public only
57
+ * - No accessModifier (default): Own org public + system org public
58
+ *
59
+ * @param filter - Plugin filter criteria
60
+ * @param orgId - User's organization ID (optional — anonymous gets system public only)
61
+ * @returns Array of SQL conditions
62
+ */
63
+ function buildPluginConditions(filter, orgId) {
64
+ // Use generic builder for common conditions (access control, ID, booleans, accessModifier)
65
+ const conditions = pluginBuilder.buildCommonConditions(filter, orgId);
66
+ // Add plugin-specific filters
67
+ if (filter.orgId !== undefined) {
68
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.plugin.orgId, (0, access_control_builder_1.normalizeStringFilter)(filter.orgId)));
69
+ }
70
+ if (filter.name !== undefined) {
71
+ conditions.push((0, drizzle_orm_1.ilike)(drizzle_schema_1.schema.plugin.name, `%${(0, access_control_builder_1.escapeLikeWildcards)((0, access_control_builder_1.normalizeStringFilter)(filter.name))}%`));
72
+ }
73
+ if (filter.version !== undefined) {
74
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.plugin.version, filter.version));
75
+ }
76
+ if (filter.imageTag !== undefined) {
77
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.plugin.imageTag, filter.imageTag));
78
+ }
79
+ if (filter.keyword !== undefined) {
80
+ conditions.push((0, access_control_builder_1.buildJsonbKeywordCondition)(drizzle_schema_1.schema.plugin.keywords, (0, access_control_builder_1.normalizeStringFilter)(filter.keyword)));
81
+ }
82
+ if (filter.category !== undefined) {
83
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.plugin.category, filter.category));
84
+ }
85
+ return conditions;
86
+ }
87
+ /**
88
+ * Build SQL conditions for message queries.
89
+ *
90
+ * Custom access control for messages:
91
+ * - Messages are visible to the sender org (orgId) OR the recipient org (recipientOrgId)
92
+ * - Broadcast announcements (recipientOrgId = '*') are visible to all orgs
93
+ * - System org can see all messages
94
+ *
95
+ * @param filter - Message filter criteria
96
+ * @param orgId - User's organization ID
97
+ * @returns Array of SQL conditions
98
+ */
99
+ function buildMessageConditions(filter, orgId) {
100
+ const conditions = [];
101
+ const normalizedOrgId = orgId.toLowerCase();
102
+ // Custom access control: sender OR recipient OR broadcast
103
+ if (normalizedOrgId === api_core_1.SYSTEM_ORG_ID) {
104
+ // System org can see all messages
105
+ }
106
+ else {
107
+ conditions.push((0, drizzle_orm_1.or)((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.orgId, normalizedOrgId), (0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.recipientOrgId, normalizedOrgId), (0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.recipientOrgId, '*')));
108
+ }
109
+ // Active filter (default to active only)
110
+ if (filter.isActive !== undefined) {
111
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.isActive, (0, access_control_builder_1.parseBooleanFilter)(filter.isActive)));
112
+ }
113
+ else {
114
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.isActive, true));
115
+ }
116
+ // Thread filter (null = root messages only via IS NULL)
117
+ if (filter.threadId !== undefined) {
118
+ if (filter.threadId === null) {
119
+ conditions.push((0, drizzle_orm_1.isNull)(drizzle_schema_1.schema.message.threadId));
120
+ }
121
+ else {
122
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.threadId, filter.threadId));
123
+ }
124
+ }
125
+ // Recipient org filter
126
+ if (filter.recipientOrgId !== undefined) {
127
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.recipientOrgId, (0, access_control_builder_1.normalizeStringFilter)(filter.recipientOrgId)));
128
+ }
129
+ // Message type filter
130
+ if (filter.messageType !== undefined) {
131
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.messageType, filter.messageType));
132
+ }
133
+ // Read status filter
134
+ if (filter.isRead !== undefined) {
135
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.isRead, (0, access_control_builder_1.parseBooleanFilter)(filter.isRead)));
136
+ }
137
+ // Priority filter
138
+ if (filter.priority !== undefined) {
139
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.priority, filter.priority));
140
+ }
141
+ // ID filter
142
+ if (filter.id !== undefined) {
143
+ const id = typeof filter.id === 'string' ? filter.id : filter.id[0];
144
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.message.id, id));
145
+ }
146
+ return conditions;
147
+ }
148
+ // ========================================
149
+ // Compliance Query Builders
150
+ // ========================================
151
+ /**
152
+ * Build SQL conditions for compliance policy queries.
153
+ * Org-scoped: always filters by orgId.
154
+ */
155
+ function buildCompliancePolicyConditions(filter, orgId) {
156
+ const conditions = [];
157
+ if (orgId) {
158
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.compliancePolicy.orgId, orgId));
159
+ }
160
+ if (filter.id !== undefined) {
161
+ const id = typeof filter.id === 'string' ? filter.id : filter.id[0];
162
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.compliancePolicy.id, id));
163
+ }
164
+ if (filter.name !== undefined) {
165
+ conditions.push((0, drizzle_orm_1.ilike)(drizzle_schema_1.schema.compliancePolicy.name, `%${(0, access_control_builder_1.escapeLikeWildcards)((0, access_control_builder_1.normalizeStringFilter)(filter.name))}%`));
166
+ }
167
+ if (filter.isTemplate !== undefined) {
168
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.compliancePolicy.isTemplate, (0, access_control_builder_1.parseBooleanFilter)(filter.isTemplate)));
169
+ }
170
+ if (filter.isActive !== undefined) {
171
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.compliancePolicy.isActive, (0, access_control_builder_1.parseBooleanFilter)(filter.isActive)));
172
+ }
173
+ else {
174
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.compliancePolicy.isActive, true));
175
+ }
176
+ return conditions;
177
+ }
178
+ /**
179
+ * Build SQL conditions for compliance rule queries.
180
+ * Returns only the requesting org's own rules (org-scoped).
181
+ */
182
+ function buildComplianceRuleConditions(filter, orgId) {
183
+ const conditions = [];
184
+ if (orgId) {
185
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.orgId, orgId));
186
+ }
187
+ if (filter.id !== undefined) {
188
+ const id = typeof filter.id === 'string' ? filter.id : filter.id[0];
189
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.id, id));
190
+ }
191
+ if (filter.name !== undefined) {
192
+ conditions.push((0, drizzle_orm_1.ilike)(drizzle_schema_1.schema.complianceRule.name, `%${(0, access_control_builder_1.escapeLikeWildcards)((0, access_control_builder_1.normalizeStringFilter)(filter.name))}%`));
193
+ }
194
+ if (filter.policyId !== undefined) {
195
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.policyId, filter.policyId));
196
+ }
197
+ if (filter.target !== undefined) {
198
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.target, filter.target));
199
+ }
200
+ if (filter.severity !== undefined) {
201
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.severity, filter.severity));
202
+ }
203
+ if (filter.scope !== undefined) {
204
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.scope, filter.scope));
205
+ }
206
+ if (filter.tag !== undefined) {
207
+ conditions.push((0, access_control_builder_1.buildJsonbKeywordCondition)(drizzle_schema_1.schema.complianceRule.tags, (0, access_control_builder_1.normalizeStringFilter)(filter.tag)));
208
+ }
209
+ if (filter.isActive !== undefined) {
210
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.isActive, (0, access_control_builder_1.parseBooleanFilter)(filter.isActive)));
211
+ }
212
+ else if (filter.id === undefined) {
213
+ // Only default to active=true for list queries, not single-entity lookups by ID
214
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.isActive, true));
215
+ }
216
+ return conditions;
217
+ }
218
+ /**
219
+ * Build SQL conditions for browsing the published rules catalog.
220
+ * Only returns system-org published rules.
221
+ */
222
+ function buildPublishedRuleCatalogConditions(filter) {
223
+ const conditions = [];
224
+ // Only scope='published' is needed — the create endpoint already enforces
225
+ // that only the system org can create published rules, so filtering by orgId
226
+ // is redundant and breaks when the system org's DB ID differs from SYSTEM_ORG_ID.
227
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.scope, 'published'));
228
+ if (filter.name !== undefined) {
229
+ conditions.push((0, drizzle_orm_1.ilike)(drizzle_schema_1.schema.complianceRule.name, `%${(0, access_control_builder_1.escapeLikeWildcards)((0, access_control_builder_1.normalizeStringFilter)(filter.name))}%`));
230
+ }
231
+ if (filter.target !== undefined) {
232
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.target, filter.target));
233
+ }
234
+ if (filter.severity !== undefined) {
235
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.severity, filter.severity));
236
+ }
237
+ if (filter.tag !== undefined) {
238
+ conditions.push((0, access_control_builder_1.buildJsonbKeywordCondition)(drizzle_schema_1.schema.complianceRule.tags, (0, access_control_builder_1.normalizeStringFilter)(filter.tag)));
239
+ }
240
+ if (filter.isActive !== undefined) {
241
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.isActive, (0, access_control_builder_1.parseBooleanFilter)(filter.isActive)));
242
+ }
243
+ else {
244
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRule.isActive, true));
245
+ }
246
+ return conditions;
247
+ }
248
+ /**
249
+ * Build SQL conditions for compliance rule subscription queries.
250
+ */
251
+ function buildComplianceRuleSubscriptionConditions(filter, orgId) {
252
+ const conditions = [];
253
+ if (orgId) {
254
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRuleSubscription.orgId, orgId));
255
+ }
256
+ if (filter.ruleId !== undefined) {
257
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRuleSubscription.ruleId, filter.ruleId));
258
+ }
259
+ if (filter.isActive !== undefined) {
260
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRuleSubscription.isActive, (0, access_control_builder_1.parseBooleanFilter)(filter.isActive)));
261
+ }
262
+ else {
263
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceRuleSubscription.isActive, true));
264
+ }
265
+ return conditions;
266
+ }
267
+ /**
268
+ * Build SQL conditions for compliance exemption queries.
269
+ */
270
+ function buildComplianceExemptionConditions(filter, orgId) {
271
+ const conditions = [];
272
+ if (orgId) {
273
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceExemption.orgId, orgId));
274
+ }
275
+ if (filter.ruleId !== undefined) {
276
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceExemption.ruleId, filter.ruleId));
277
+ }
278
+ if (filter.entityType !== undefined) {
279
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceExemption.entityType, filter.entityType));
280
+ }
281
+ if (filter.entityId !== undefined) {
282
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceExemption.entityId, filter.entityId));
283
+ }
284
+ if (filter.status !== undefined) {
285
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceExemption.status, filter.status));
286
+ }
287
+ return conditions;
288
+ }
289
+ /**
290
+ * Build SQL conditions for compliance audit log queries.
291
+ */
292
+ function buildComplianceAuditConditions(filter, orgId) {
293
+ const conditions = [];
294
+ if (orgId) {
295
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceAuditLog.orgId, orgId));
296
+ }
297
+ if (filter.target !== undefined) {
298
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceAuditLog.target, filter.target));
299
+ }
300
+ if (filter.action !== undefined) {
301
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceAuditLog.action, filter.action));
302
+ }
303
+ if (filter.result !== undefined) {
304
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceAuditLog.result, filter.result));
305
+ }
306
+ if (filter.scanId !== undefined) {
307
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceAuditLog.scanId, filter.scanId));
308
+ }
309
+ if (filter.dateFrom !== undefined) {
310
+ conditions.push((0, drizzle_orm_1.gte)(drizzle_schema_1.schema.complianceAuditLog.createdAt, new Date(filter.dateFrom)));
311
+ }
312
+ if (filter.dateTo !== undefined) {
313
+ conditions.push((0, drizzle_orm_1.lte)(drizzle_schema_1.schema.complianceAuditLog.createdAt, new Date(filter.dateTo)));
314
+ }
315
+ return conditions;
316
+ }
317
+ /**
318
+ * Build SQL conditions for compliance scan queries.
319
+ */
320
+ function buildComplianceScanConditions(filter, orgId) {
321
+ const conditions = [];
322
+ if (orgId) {
323
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceScan.orgId, orgId));
324
+ }
325
+ if (filter.target !== undefined) {
326
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceScan.target, filter.target));
327
+ }
328
+ if (filter.status !== undefined) {
329
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceScan.status, filter.status));
330
+ }
331
+ if (filter.triggeredBy !== undefined) {
332
+ conditions.push((0, drizzle_orm_1.eq)(drizzle_schema_1.schema.complianceScan.triggeredBy, filter.triggeredBy));
333
+ }
334
+ return conditions;
335
+ }
336
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-builders.js","sourceRoot":"","sources":["../../src/api/query-builders.ts"],"names":[],"mappings":"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","sourcesContent":["// Copyright 2026 Pipeline Builder Contributors\n// SPDX-License-Identifier: Apache-2.0\n\nimport { SYSTEM_ORG_ID } from '@pipeline-builder/api-core';\nimport { eq, ilike, isNull, or, gte, lte, SQL } from 'drizzle-orm';\nimport {\n  AccessControlQueryBuilder,\n  buildJsonbKeywordCondition,\n  escapeLikeWildcards,\n  normalizeStringFilter,\n  parseBooleanFilter,\n} from './access-control-builder';\nimport {\n  MessageFilter,\n  PipelineFilter,\n  PluginFilter,\n  CompliancePolicyFilter,\n  ComplianceRuleFilter,\n  ComplianceExemptionFilter,\n  ComplianceAuditFilter,\n  ComplianceScanFilter,\n  ComplianceRuleSubscriptionFilter,\n} from '../core/query-filters';\nimport {\n  schema,\n  type MessagePriority,\n  type MessageType,\n  type RuleTarget,\n  type RuleSeverity,\n  type RuleScope,\n} from '../database/drizzle-schema';\n\n// Query builder instances\nconst pipelineBuilder = new AccessControlQueryBuilder(schema.pipeline);\nconst pluginBuilder = new AccessControlQueryBuilder(schema.plugin);\n\n/**\n * Build SQL conditions for pipeline queries\n *\n * Access control behavior:\n * - No orgId: system org public only\n * - accessModifier='private': Own org private only\n * - accessModifier='public': Own org public only\n * - No accessModifier (default): Own org public + system org public\n *\n * @param filter - Pipeline filter criteria\n * @param orgId - User's organization ID (optional — anonymous gets system public only)\n * @returns Array of SQL conditions\n */\nexport function buildPipelineConditions(\n  filter: Partial<PipelineFilter>,\n  orgId?: string,\n): SQL[] {\n  // Use generic builder for common conditions (access control, ID, booleans, accessModifier)\n  const conditions = pipelineBuilder.buildCommonConditions(filter, orgId);\n\n  // Add pipeline-specific filters\n  if (filter.project !== undefined) {\n    conditions.push(eq(schema.pipeline.project, normalizeStringFilter(filter.project)));\n  }\n\n  if (filter.organization !== undefined) {\n    conditions.push(eq(schema.pipeline.organization, normalizeStringFilter(filter.organization)));\n  }\n\n  if (filter.keyword !== undefined) {\n    conditions.push(buildJsonbKeywordCondition(schema.pipeline.keywords, normalizeStringFilter(filter.keyword)));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for plugin queries\n *\n * Access control behavior:\n * - No orgId: system org public only\n * - accessModifier='private': Own org private only\n * - accessModifier='public': Own org public only\n * - No accessModifier (default): Own org public + system org public\n *\n * @param filter - Plugin filter criteria\n * @param orgId - User's organization ID (optional — anonymous gets system public only)\n * @returns Array of SQL conditions\n */\nexport function buildPluginConditions(\n  filter: Partial<PluginFilter>,\n  orgId?: string,\n): SQL[] {\n  // Use generic builder for common conditions (access control, ID, booleans, accessModifier)\n  const conditions = pluginBuilder.buildCommonConditions(filter, orgId);\n\n  // Add plugin-specific filters\n  if (filter.orgId !== undefined) {\n    conditions.push(eq(schema.plugin.orgId, normalizeStringFilter(filter.orgId)));\n  }\n\n  if (filter.name !== undefined) {\n    conditions.push(ilike(schema.plugin.name, `%${escapeLikeWildcards(normalizeStringFilter(filter.name))}%`));\n  }\n\n  if (filter.version !== undefined) {\n    conditions.push(eq(schema.plugin.version, filter.version as string));\n  }\n\n  if (filter.imageTag !== undefined) {\n    conditions.push(eq(schema.plugin.imageTag, filter.imageTag as string));\n  }\n\n  if (filter.keyword !== undefined) {\n    conditions.push(buildJsonbKeywordCondition(schema.plugin.keywords, normalizeStringFilter(filter.keyword)));\n  }\n\n  if (filter.category !== undefined) {\n    conditions.push(eq(schema.plugin.category, filter.category as string));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for message queries.\n *\n * Custom access control for messages:\n * - Messages are visible to the sender org (orgId) OR the recipient org (recipientOrgId)\n * - Broadcast announcements (recipientOrgId = '*') are visible to all orgs\n * - System org can see all messages\n *\n * @param filter - Message filter criteria\n * @param orgId - User's organization ID\n * @returns Array of SQL conditions\n */\nexport function buildMessageConditions(\n  filter: Partial<MessageFilter>,\n  orgId: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n  const normalizedOrgId = orgId.toLowerCase();\n\n  // Custom access control: sender OR recipient OR broadcast\n  if (normalizedOrgId === SYSTEM_ORG_ID) {\n    // System org can see all messages\n  } else {\n    conditions.push(\n      or(\n        eq(schema.message.orgId, normalizedOrgId),\n        eq(schema.message.recipientOrgId, normalizedOrgId),\n        eq(schema.message.recipientOrgId, '*'),\n      )!,\n    );\n  }\n\n  // Active filter (default to active only)\n  if (filter.isActive !== undefined) {\n    conditions.push(eq(schema.message.isActive, parseBooleanFilter(filter.isActive)));\n  } else {\n    conditions.push(eq(schema.message.isActive, true));\n  }\n\n  // Thread filter (null = root messages only via IS NULL)\n  if (filter.threadId !== undefined) {\n    if (filter.threadId === null) {\n      conditions.push(isNull(schema.message.threadId));\n    } else {\n      conditions.push(eq(schema.message.threadId, filter.threadId));\n    }\n  }\n\n  // Recipient org filter\n  if (filter.recipientOrgId !== undefined) {\n    conditions.push(eq(schema.message.recipientOrgId, normalizeStringFilter(filter.recipientOrgId)));\n  }\n\n  // Message type filter\n  if (filter.messageType !== undefined) {\n    conditions.push(eq(schema.message.messageType, filter.messageType as MessageType));\n  }\n\n  // Read status filter\n  if (filter.isRead !== undefined) {\n    conditions.push(eq(schema.message.isRead, parseBooleanFilter(filter.isRead)));\n  }\n\n  // Priority filter\n  if (filter.priority !== undefined) {\n    conditions.push(eq(schema.message.priority, filter.priority as MessagePriority));\n  }\n\n  // ID filter\n  if (filter.id !== undefined) {\n    const id = typeof filter.id === 'string' ? filter.id : filter.id[0];\n    conditions.push(eq(schema.message.id, id));\n  }\n\n  return conditions;\n}\n\n// ========================================\n// Compliance Query Builders\n// ========================================\n\n/**\n * Build SQL conditions for compliance policy queries.\n * Org-scoped: always filters by orgId.\n */\nexport function buildCompliancePolicyConditions(\n  filter: Partial<CompliancePolicyFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.compliancePolicy.orgId, orgId));\n  }\n\n  if (filter.id !== undefined) {\n    const id = typeof filter.id === 'string' ? filter.id : filter.id[0];\n    conditions.push(eq(schema.compliancePolicy.id, id));\n  }\n\n  if (filter.name !== undefined) {\n    conditions.push(ilike(schema.compliancePolicy.name, `%${escapeLikeWildcards(normalizeStringFilter(filter.name))}%`));\n  }\n\n  if (filter.isTemplate !== undefined) {\n    conditions.push(eq(schema.compliancePolicy.isTemplate, parseBooleanFilter(filter.isTemplate)));\n  }\n\n  if (filter.isActive !== undefined) {\n    conditions.push(eq(schema.compliancePolicy.isActive, parseBooleanFilter(filter.isActive)));\n  } else {\n    conditions.push(eq(schema.compliancePolicy.isActive, true));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for compliance rule queries.\n * Returns only the requesting org's own rules (org-scoped).\n */\nexport function buildComplianceRuleConditions(\n  filter: Partial<ComplianceRuleFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.complianceRule.orgId, orgId));\n  }\n\n  if (filter.id !== undefined) {\n    const id = typeof filter.id === 'string' ? filter.id : filter.id[0];\n    conditions.push(eq(schema.complianceRule.id, id));\n  }\n\n  if (filter.name !== undefined) {\n    conditions.push(ilike(schema.complianceRule.name, `%${escapeLikeWildcards(normalizeStringFilter(filter.name))}%`));\n  }\n\n  if (filter.policyId !== undefined) {\n    conditions.push(eq(schema.complianceRule.policyId, filter.policyId));\n  }\n\n  if (filter.target !== undefined) {\n    conditions.push(eq(schema.complianceRule.target, filter.target as RuleTarget));\n  }\n\n  if (filter.severity !== undefined) {\n    conditions.push(eq(schema.complianceRule.severity, filter.severity as RuleSeverity));\n  }\n\n  if (filter.scope !== undefined) {\n    conditions.push(eq(schema.complianceRule.scope, filter.scope as RuleScope));\n  }\n\n  if (filter.tag !== undefined) {\n    conditions.push(buildJsonbKeywordCondition(schema.complianceRule.tags, normalizeStringFilter(filter.tag)));\n  }\n\n  if (filter.isActive !== undefined) {\n    conditions.push(eq(schema.complianceRule.isActive, parseBooleanFilter(filter.isActive)));\n  } else if (filter.id === undefined) {\n    // Only default to active=true for list queries, not single-entity lookups by ID\n    conditions.push(eq(schema.complianceRule.isActive, true));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for browsing the published rules catalog.\n * Only returns system-org published rules.\n */\nexport function buildPublishedRuleCatalogConditions(\n  filter: Partial<ComplianceRuleFilter>,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  // Only scope='published' is needed — the create endpoint already enforces\n  // that only the system org can create published rules, so filtering by orgId\n  // is redundant and breaks when the system org's DB ID differs from SYSTEM_ORG_ID.\n  conditions.push(eq(schema.complianceRule.scope, 'published' as RuleScope));\n\n  if (filter.name !== undefined) {\n    conditions.push(ilike(schema.complianceRule.name, `%${escapeLikeWildcards(normalizeStringFilter(filter.name))}%`));\n  }\n\n  if (filter.target !== undefined) {\n    conditions.push(eq(schema.complianceRule.target, filter.target as RuleTarget));\n  }\n\n  if (filter.severity !== undefined) {\n    conditions.push(eq(schema.complianceRule.severity, filter.severity as RuleSeverity));\n  }\n\n  if (filter.tag !== undefined) {\n    conditions.push(buildJsonbKeywordCondition(schema.complianceRule.tags, normalizeStringFilter(filter.tag)));\n  }\n\n  if (filter.isActive !== undefined) {\n    conditions.push(eq(schema.complianceRule.isActive, parseBooleanFilter(filter.isActive)));\n  } else {\n    conditions.push(eq(schema.complianceRule.isActive, true));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for compliance rule subscription queries.\n */\nexport function buildComplianceRuleSubscriptionConditions(\n  filter: Partial<ComplianceRuleSubscriptionFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.complianceRuleSubscription.orgId, orgId));\n  }\n\n  if (filter.ruleId !== undefined) {\n    conditions.push(eq(schema.complianceRuleSubscription.ruleId, filter.ruleId));\n  }\n\n  if (filter.isActive !== undefined) {\n    conditions.push(eq(schema.complianceRuleSubscription.isActive, parseBooleanFilter(filter.isActive)));\n  } else {\n    conditions.push(eq(schema.complianceRuleSubscription.isActive, true));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for compliance exemption queries.\n */\nexport function buildComplianceExemptionConditions(\n  filter: Partial<ComplianceExemptionFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.complianceExemption.orgId, orgId));\n  }\n\n  if (filter.ruleId !== undefined) {\n    conditions.push(eq(schema.complianceExemption.ruleId, filter.ruleId));\n  }\n\n  if (filter.entityType !== undefined) {\n    conditions.push(eq(schema.complianceExemption.entityType, filter.entityType as RuleTarget));\n  }\n\n  if (filter.entityId !== undefined) {\n    conditions.push(eq(schema.complianceExemption.entityId, filter.entityId));\n  }\n\n  if (filter.status !== undefined) {\n    conditions.push(eq(schema.complianceExemption.status, filter.status));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for compliance audit log queries.\n */\nexport function buildComplianceAuditConditions(\n  filter: Partial<ComplianceAuditFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.complianceAuditLog.orgId, orgId));\n  }\n\n  if (filter.target !== undefined) {\n    conditions.push(eq(schema.complianceAuditLog.target, filter.target as RuleTarget));\n  }\n\n  if (filter.action !== undefined) {\n    conditions.push(eq(schema.complianceAuditLog.action, filter.action));\n  }\n\n  if (filter.result !== undefined) {\n    conditions.push(eq(schema.complianceAuditLog.result, filter.result));\n  }\n\n  if (filter.scanId !== undefined) {\n    conditions.push(eq(schema.complianceAuditLog.scanId, filter.scanId));\n  }\n\n  if (filter.dateFrom !== undefined) {\n    conditions.push(gte(schema.complianceAuditLog.createdAt, new Date(filter.dateFrom)));\n  }\n\n  if (filter.dateTo !== undefined) {\n    conditions.push(lte(schema.complianceAuditLog.createdAt, new Date(filter.dateTo)));\n  }\n\n  return conditions;\n}\n\n/**\n * Build SQL conditions for compliance scan queries.\n */\nexport function buildComplianceScanConditions(\n  filter: Partial<ComplianceScanFilter>,\n  orgId?: string,\n): SQL[] {\n  const conditions: SQL[] = [];\n\n  if (orgId) {\n    conditions.push(eq(schema.complianceScan.orgId, orgId));\n  }\n\n  if (filter.target !== undefined) {\n    conditions.push(eq(schema.complianceScan.target, filter.target));\n  }\n\n  if (filter.status !== undefined) {\n    conditions.push(eq(schema.complianceScan.status, filter.status));\n  }\n\n  if (filter.triggeredBy !== undefined) {\n    conditions.push(eq(schema.complianceScan.triggeredBy, filter.triggeredBy));\n  }\n\n  return conditions;\n}\n"]}
@@ -0,0 +1,131 @@
1
+ interface ExecutionCount {
2
+ id: string;
3
+ project: string;
4
+ organization: string;
5
+ pipelineName: string | null;
6
+ total: number;
7
+ succeeded: number;
8
+ failed: number;
9
+ canceled: number;
10
+ firstExecution: string | null;
11
+ lastExecution: string | null;
12
+ }
13
+ interface TimeSeriesEntry {
14
+ period: string;
15
+ succeeded: number;
16
+ failed: number;
17
+ canceled: number;
18
+ successPct: number;
19
+ }
20
+ interface DurationStats {
21
+ id: string;
22
+ project: string;
23
+ pipelineName: string | null;
24
+ avgMs: number;
25
+ minMs: number;
26
+ maxMs: number;
27
+ p95Ms: number;
28
+ executions: number;
29
+ }
30
+ interface StageFailure {
31
+ stageName: string;
32
+ failures: number;
33
+ total: number;
34
+ failurePct: number;
35
+ }
36
+ interface StageBottleneck {
37
+ id: string;
38
+ pipelineName: string | null;
39
+ stageName: string;
40
+ avgMs: number;
41
+ maxMs: number;
42
+ }
43
+ interface ActionFailure {
44
+ actionName: string;
45
+ failures: number;
46
+ total: number;
47
+ failurePct: number;
48
+ }
49
+ interface ErrorEntry {
50
+ errorPattern: string;
51
+ occurrences: number;
52
+ affectedPipelines: number;
53
+ lastSeen: string;
54
+ }
55
+ interface PluginSummary {
56
+ total: number;
57
+ active: number;
58
+ inactive: number;
59
+ public: number;
60
+ private: number;
61
+ uniqueNames: number;
62
+ }
63
+ interface TypeComputeDistribution {
64
+ pluginType: string;
65
+ computeType: string;
66
+ count: number;
67
+ }
68
+ interface VersionCount {
69
+ name: string;
70
+ versionCount: number;
71
+ latestVersion: string;
72
+ hasDefault: boolean;
73
+ }
74
+ interface BuildTimeSeriesEntry {
75
+ period: string;
76
+ succeeded: number;
77
+ failed: number;
78
+ successPct: number;
79
+ }
80
+ interface BuildDuration {
81
+ pluginName: string;
82
+ avgMs: number;
83
+ maxMs: number;
84
+ builds: number;
85
+ }
86
+ interface BuildFailure {
87
+ pluginName: string;
88
+ errorMessage: string;
89
+ occurrences: number;
90
+ lastSeen: string;
91
+ }
92
+ /**
93
+ * Read-only reporting service for pipeline execution and plugin inventory aggregations.
94
+ * Does not extend CrudService — reports are aggregate queries, not entity CRUD.
95
+ *
96
+ * All queries are cached in-memory to avoid repeated expensive SQL aggregations:
97
+ * - Inventory queries (plugin summary/distribution/versions): 5 min TTL
98
+ * - Timeseries queries (execution/build metrics with date ranges): 2 min TTL
99
+ */
100
+ export declare class ReportingService {
101
+ /** Invalidate all cached reports for an org (call after event ingest). */
102
+ invalidateOrg(orgId: string): Promise<void>;
103
+ /** 1.1 Execution count per pipeline with status breakdown. */
104
+ getExecutionCount(orgId: string): Promise<ExecutionCount[]>;
105
+ /** 1.2 Success rate over time for an org. */
106
+ getSuccessRate(orgId: string, interval: string, from: string, to: string): Promise<TimeSeriesEntry[]>;
107
+ /** 1.3 Average duration per pipeline. */
108
+ getAverageDuration(orgId: string, from: string, to: string): Promise<DurationStats[]>;
109
+ /** 1.5 Stage failure heatmap — which stages fail most. */
110
+ getStageFailures(orgId: string, from: string, to: string): Promise<StageFailure[]>;
111
+ /** 1.6 Stage bottlenecks — slowest stages per pipeline. */
112
+ getStageBottlenecks(orgId: string, from: string, to: string): Promise<StageBottleneck[]>;
113
+ /** 1.7 Action failure rate — which plugin steps fail most. */
114
+ getActionFailures(orgId: string, from: string, to: string): Promise<ActionFailure[]>;
115
+ /** 1.8 Error categorization — group failure messages. */
116
+ getErrors(orgId: string, from: string, to: string, limit?: number): Promise<ErrorEntry[]>;
117
+ /** 2.1 Plugin summary — counts and breakdowns. */
118
+ getPluginSummary(orgId: string): Promise<PluginSummary>;
119
+ /** 2.2 Type & compute distribution. */
120
+ getPluginDistribution(orgId: string): Promise<TypeComputeDistribution[]>;
121
+ /** 2.3 Version counts per plugin name. */
122
+ getPluginVersions(orgId: string): Promise<VersionCount[]>;
123
+ /** 2.4 Build success rate over time. */
124
+ getBuildSuccessRate(orgId: string, interval: string, from: string, to: string): Promise<BuildTimeSeriesEntry[]>;
125
+ /** 2.5 Build duration per plugin. */
126
+ getBuildDuration(orgId: string, from: string, to: string): Promise<BuildDuration[]>;
127
+ /** 2.6 Build failures — top error messages. */
128
+ getBuildFailures(orgId: string, from: string, to: string, limit?: number): Promise<BuildFailure[]>;
129
+ }
130
+ export declare const reportingService: ReportingService;
131
+ export {};