@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.
- package/LICENSE +202 -0
- package/README.md +34 -0
- package/drizzle.config.ts +17 -0
- package/lib/api/access-control-builder.d.ts +109 -0
- package/lib/api/access-control-builder.js +181 -0
- package/lib/api/crud-service.d.ts +170 -0
- package/lib/api/crud-service.js +387 -0
- package/lib/api/query-builders.d.ts +74 -0
- package/lib/api/query-builders.js +336 -0
- package/lib/api/reporting-service.d.ts +131 -0
- package/lib/api/reporting-service.js +248 -0
- package/lib/core/query-filters.d.ts +235 -0
- package/lib/core/query-filters.js +23 -0
- package/lib/database/drizzle-schema.d.ts +10043 -0
- package/lib/database/drizzle-schema.js +715 -0
- package/lib/database/index.d.ts +3 -0
- package/lib/database/index.js +22 -0
- package/lib/database/postgres-connection.d.ts +232 -0
- package/lib/database/postgres-connection.js +456 -0
- package/lib/database/retry-strategy.d.ts +68 -0
- package/lib/database/retry-strategy.js +126 -0
- package/lib/index.d.ts +30 -0
- package/lib/index.js +52 -0
- package/package.json +125 -0
|
@@ -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 {};
|