@cdklabs/cdk-appmod-catalog-blueprints 1.5.0 → 1.6.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/.jsii +2537 -204
- package/lib/document-processing/adapter/adapter.d.ts +4 -2
- package/lib/document-processing/adapter/adapter.js +1 -1
- package/lib/document-processing/adapter/queued-s3-adapter.d.ts +9 -2
- package/lib/document-processing/adapter/queued-s3-adapter.js +29 -15
- package/lib/document-processing/agentic-document-processing.d.ts +4 -0
- package/lib/document-processing/agentic-document-processing.js +20 -10
- package/lib/document-processing/base-document-processing.d.ts +54 -2
- package/lib/document-processing/base-document-processing.js +136 -82
- package/lib/document-processing/bedrock-document-processing.d.ts +202 -2
- package/lib/document-processing/bedrock-document-processing.js +717 -77
- package/lib/document-processing/chunking-config.d.ts +614 -0
- package/lib/document-processing/chunking-config.js +5 -0
- package/lib/document-processing/default-document-processing-config.js +1 -1
- package/lib/document-processing/index.d.ts +1 -0
- package/lib/document-processing/index.js +2 -1
- package/lib/document-processing/resources/aggregation/handler.py +567 -0
- package/lib/document-processing/resources/aggregation/requirements.txt +7 -0
- package/lib/document-processing/resources/aggregation/test_handler.py +362 -0
- package/lib/document-processing/resources/cleanup/handler.py +276 -0
- package/lib/document-processing/resources/cleanup/requirements.txt +5 -0
- package/lib/document-processing/resources/cleanup/test_handler.py +436 -0
- package/lib/document-processing/resources/default-bedrock-invoke/index.py +85 -3
- package/lib/document-processing/resources/default-bedrock-invoke/test_index.py +622 -0
- package/lib/document-processing/resources/pdf-chunking/README.md +313 -0
- package/lib/document-processing/resources/pdf-chunking/chunking_strategies.py +460 -0
- package/lib/document-processing/resources/pdf-chunking/error_handling.py +491 -0
- package/lib/document-processing/resources/pdf-chunking/handler.py +958 -0
- package/lib/document-processing/resources/pdf-chunking/metrics.py +435 -0
- package/lib/document-processing/resources/pdf-chunking/requirements.txt +3 -0
- package/lib/document-processing/resources/pdf-chunking/strategy_selection.py +420 -0
- package/lib/document-processing/resources/pdf-chunking/structured_logging.py +457 -0
- package/lib/document-processing/resources/pdf-chunking/test_chunking_strategies.py +353 -0
- package/lib/document-processing/resources/pdf-chunking/test_error_handling.py +487 -0
- package/lib/document-processing/resources/pdf-chunking/test_handler.py +609 -0
- package/lib/document-processing/resources/pdf-chunking/test_integration.py +694 -0
- package/lib/document-processing/resources/pdf-chunking/test_metrics.py +532 -0
- package/lib/document-processing/resources/pdf-chunking/test_strategy_selection.py +471 -0
- package/lib/document-processing/resources/pdf-chunking/test_structured_logging.py +449 -0
- package/lib/document-processing/resources/pdf-chunking/test_token_estimation.py +374 -0
- package/lib/document-processing/resources/pdf-chunking/token_estimation.py +189 -0
- package/lib/document-processing/tests/agentic-document-processing-nag.test.js +4 -3
- package/lib/document-processing/tests/agentic-document-processing.test.js +488 -4
- package/lib/document-processing/tests/base-document-processing-nag.test.js +9 -2
- package/lib/document-processing/tests/base-document-processing-schema.test.d.ts +1 -0
- package/lib/document-processing/tests/base-document-processing-schema.test.js +337 -0
- package/lib/document-processing/tests/base-document-processing.test.js +114 -8
- package/lib/document-processing/tests/bedrock-document-processing-chunking-nag.test.d.ts +1 -0
- package/lib/document-processing/tests/bedrock-document-processing-chunking-nag.test.js +382 -0
- package/lib/document-processing/tests/bedrock-document-processing-nag.test.js +4 -3
- package/lib/document-processing/tests/bedrock-document-processing-security.test.d.ts +1 -0
- package/lib/document-processing/tests/bedrock-document-processing-security.test.js +389 -0
- package/lib/document-processing/tests/bedrock-document-processing.test.js +808 -8
- package/lib/document-processing/tests/chunking-config.test.d.ts +1 -0
- package/lib/document-processing/tests/chunking-config.test.js +238 -0
- package/lib/document-processing/tests/queued-s3-adapter-nag.test.js +9 -2
- package/lib/document-processing/tests/queued-s3-adapter.test.js +17 -6
- package/lib/framework/agents/base-agent.js +1 -1
- package/lib/framework/agents/batch-agent.js +1 -1
- package/lib/framework/agents/default-agent-config.js +1 -1
- package/lib/framework/bedrock/bedrock.js +1 -1
- package/lib/framework/custom-resource/default-runtimes.js +1 -1
- package/lib/framework/foundation/access-log.js +1 -1
- package/lib/framework/foundation/eventbridge-broker.js +1 -1
- package/lib/framework/foundation/network.js +1 -1
- package/lib/framework/tests/access-log.test.js +5 -2
- package/lib/framework/tests/batch-agent.test.js +5 -2
- package/lib/framework/tests/bedrock.test.js +5 -2
- package/lib/framework/tests/eventbridge-broker.test.js +5 -2
- package/lib/framework/tests/framework-nag.test.js +16 -8
- package/lib/framework/tests/network.test.js +9 -4
- package/lib/tsconfig.tsbuildinfo +1 -1
- package/lib/utilities/data-loader.js +1 -1
- package/lib/utilities/lambda-iam-utils.js +1 -1
- package/lib/utilities/observability/cloudfront-distribution-observability-property-injector.js +1 -1
- package/lib/utilities/observability/default-observability-config.js +1 -1
- package/lib/utilities/observability/lambda-observability-property-injector.js +1 -1
- package/lib/utilities/observability/log-group-data-protection-utils.js +1 -1
- package/lib/utilities/observability/powertools-config.d.ts +10 -1
- package/lib/utilities/observability/powertools-config.js +19 -3
- package/lib/utilities/observability/state-machine-observability-property-injector.js +1 -1
- package/lib/utilities/test-utils.d.ts +43 -0
- package/lib/utilities/test-utils.js +56 -0
- package/lib/utilities/tests/data-loader-nag.test.js +3 -2
- package/lib/utilities/tests/data-loader.test.js +3 -2
- package/lib/webapp/frontend-construct.js +1 -1
- package/lib/webapp/tests/frontend-construct-nag.test.js +3 -2
- package/lib/webapp/tests/frontend-construct.test.js +3 -2
- package/package.json +6 -5
- package/lib/document-processing/resources/default-error-handler/index.js +0 -46
- package/lib/document-processing/resources/default-pdf-processor/index.js +0 -46
- package/lib/document-processing/resources/default-pdf-validator/index.js +0 -36
|
@@ -0,0 +1,382 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const aws_cdk_lib_1 = require("aws-cdk-lib");
|
|
4
|
+
const assertions_1 = require("aws-cdk-lib/assertions");
|
|
5
|
+
const aws_s3_1 = require("aws-cdk-lib/aws-s3");
|
|
6
|
+
const cdk_nag_1 = require("cdk-nag");
|
|
7
|
+
const framework_1 = require("../../framework");
|
|
8
|
+
const eventbridge_broker_1 = require("../../framework/foundation/eventbridge-broker");
|
|
9
|
+
const test_utils_1 = require("../../utilities/test-utils");
|
|
10
|
+
const adapter_1 = require("../adapter");
|
|
11
|
+
const bedrock_document_processing_1 = require("../bedrock-document-processing");
|
|
12
|
+
/**
|
|
13
|
+
* CDK Nag compliance tests for BedrockDocumentProcessing with chunking enabled.
|
|
14
|
+
*
|
|
15
|
+
* These tests verify that the chunking feature maintains security compliance
|
|
16
|
+
* with AWS Solutions checks. The chunking feature adds:
|
|
17
|
+
* - PDF Analysis & Chunking Lambda (PDFChunkingFunction)
|
|
18
|
+
* - Aggregation Lambda (AggregationFunction)
|
|
19
|
+
* - Cleanup Lambda (CleanupFunction)
|
|
20
|
+
* - Additional Step Functions states (Map, Choice)
|
|
21
|
+
*
|
|
22
|
+
* All new resources must pass CDK Nag checks or have documented suppressions.
|
|
23
|
+
*
|
|
24
|
+
* ## Security Controls Verified
|
|
25
|
+
*
|
|
26
|
+
* 1. **Encryption at Rest**: All Lambda functions use KMS encryption for environment variables
|
|
27
|
+
* 2. **Encryption in Transit**: S3 bucket enforces SSL
|
|
28
|
+
* 3. **Least Privilege IAM**: Lambda roles have minimal required permissions
|
|
29
|
+
* 4. **VPC Support**: Lambda functions can be deployed in VPC for network isolation
|
|
30
|
+
* 5. **Logging**: CloudWatch Logs enabled for all Lambda functions
|
|
31
|
+
*
|
|
32
|
+
* ## Suppressions Documentation
|
|
33
|
+
*
|
|
34
|
+
* The following suppressions are applied with documented justifications:
|
|
35
|
+
*
|
|
36
|
+
* ### AwsSolutions-IAM4 (AWS Managed Policies)
|
|
37
|
+
* - BucketNotificationsHandler: CDK-managed resource requires AWSLambdaBasicExecutionRole
|
|
38
|
+
*
|
|
39
|
+
* ### AwsSolutions-IAM5 (Wildcard Permissions)
|
|
40
|
+
* - S3 bucket object access: Lambda functions need to read/write documents at any key
|
|
41
|
+
* - Bedrock model access: Cross-region inference requires wildcard region access
|
|
42
|
+
* - CloudWatch Logs: Log stream names are generated at runtime
|
|
43
|
+
* - Step Functions Lambda invocation: Version-specific ARNs require wildcards
|
|
44
|
+
*/
|
|
45
|
+
// Create app and stack with bundling disabled for faster tests
|
|
46
|
+
const app = (0, test_utils_1.createTestApp)();
|
|
47
|
+
const stack = new aws_cdk_lib_1.Stack(app, 'TestStack', {
|
|
48
|
+
env: {
|
|
49
|
+
account: '123456789012',
|
|
50
|
+
region: 'us-east-1',
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
// Create EventBridge broker
|
|
54
|
+
const broker = new eventbridge_broker_1.EventbridgeBroker(stack, 'IDPBroker', {
|
|
55
|
+
name: 'idp-broker',
|
|
56
|
+
eventSource: 'intelligent-document-processing',
|
|
57
|
+
});
|
|
58
|
+
const accessLog = new framework_1.AccessLog(stack, 'AccessLog');
|
|
59
|
+
// Create S3 bucket for document processing
|
|
60
|
+
const bucket = new aws_s3_1.Bucket(stack, 'BedrockDocumentProcessingBucket', {
|
|
61
|
+
serverAccessLogsBucket: accessLog.bucket,
|
|
62
|
+
serverAccessLogsPrefix: accessLog.bucketPrefix,
|
|
63
|
+
enforceSSL: true,
|
|
64
|
+
});
|
|
65
|
+
const adapter = new adapter_1.QueuedS3Adapter({
|
|
66
|
+
bucket,
|
|
67
|
+
});
|
|
68
|
+
// Create the main BedrockDocumentProcessing construct with chunking enabled
|
|
69
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {
|
|
70
|
+
ingressAdapter: adapter,
|
|
71
|
+
classificationBedrockModel: { useCrossRegionInference: true },
|
|
72
|
+
processingBedrockModel: { useCrossRegionInference: true },
|
|
73
|
+
eventbridgeBroker: broker,
|
|
74
|
+
enableObservability: true,
|
|
75
|
+
// Enable chunking with hybrid strategy (recommended)
|
|
76
|
+
enableChunking: true,
|
|
77
|
+
chunkingConfig: {
|
|
78
|
+
strategy: 'hybrid',
|
|
79
|
+
pageThreshold: 100,
|
|
80
|
+
tokenThreshold: 150000,
|
|
81
|
+
processingMode: 'parallel',
|
|
82
|
+
maxConcurrency: 10,
|
|
83
|
+
},
|
|
84
|
+
});
|
|
85
|
+
// ============================================================================
|
|
86
|
+
// CDK Nag Suppressions with Justifications
|
|
87
|
+
// ============================================================================
|
|
88
|
+
/**
|
|
89
|
+
* Suppression: AwsSolutions-IAM4 for BucketNotificationsHandler
|
|
90
|
+
*
|
|
91
|
+
* Justification: The BucketNotificationsHandler is a CDK-managed Lambda function
|
|
92
|
+
* that handles S3 bucket notification configuration. It requires the
|
|
93
|
+
* AWSLambdaBasicExecutionRole managed policy for basic Lambda execution
|
|
94
|
+
* (CloudWatch Logs access). This is a CDK internal resource and cannot be
|
|
95
|
+
* customized without significant workarounds.
|
|
96
|
+
*
|
|
97
|
+
* Risk Level: Low - This is a CDK-managed resource with limited scope
|
|
98
|
+
* Approval: Approved for CDK-managed resources
|
|
99
|
+
*/
|
|
100
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(stack, '/TestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role', [
|
|
101
|
+
{
|
|
102
|
+
id: 'AwsSolutions-IAM4',
|
|
103
|
+
reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole for S3 event processing',
|
|
104
|
+
appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],
|
|
105
|
+
},
|
|
106
|
+
]);
|
|
107
|
+
/**
|
|
108
|
+
* Suppression: AwsSolutions-IAM5 for S3 bucket object access
|
|
109
|
+
*
|
|
110
|
+
* Justification: Lambda functions (Chunking, Classification, Processing,
|
|
111
|
+
* Aggregation, Cleanup) need to read and write documents at any key within
|
|
112
|
+
* the S3 bucket. The document keys are dynamic and determined at runtime
|
|
113
|
+
* based on document IDs. Restricting to specific keys is not feasible.
|
|
114
|
+
*
|
|
115
|
+
* Mitigations:
|
|
116
|
+
* - Access is limited to a single bucket (not all S3 buckets)
|
|
117
|
+
* - Bucket has enforceSSL enabled for encryption in transit
|
|
118
|
+
* - Bucket uses KMS encryption for encryption at rest
|
|
119
|
+
*
|
|
120
|
+
* Risk Level: Medium - Wildcard access to bucket objects
|
|
121
|
+
* Approval: Approved with mitigations in place
|
|
122
|
+
*/
|
|
123
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
124
|
+
{
|
|
125
|
+
id: 'AwsSolutions-IAM5',
|
|
126
|
+
reason: 'Lambda functions require wildcard access to S3 bucket objects for document processing',
|
|
127
|
+
appliesTo: ['Resource::<BedrockDocumentProcessingBucketA06CA1E2.Arn>/*'],
|
|
128
|
+
},
|
|
129
|
+
], true);
|
|
130
|
+
/**
|
|
131
|
+
* Suppression: AwsSolutions-IAM5 for Bedrock foundation model access
|
|
132
|
+
*
|
|
133
|
+
* Justification: Cross-region inference is enabled to improve availability
|
|
134
|
+
* and reduce latency. This requires wildcard region access to the Bedrock
|
|
135
|
+
* foundation model ARN (arn:aws:bedrock:*::foundation-model/...).
|
|
136
|
+
*
|
|
137
|
+
* Mitigations:
|
|
138
|
+
* - Access is limited to a specific model (Claude 3.7 Sonnet)
|
|
139
|
+
* - Only InvokeModel action is permitted
|
|
140
|
+
* - Cross-region inference is optional and can be disabled
|
|
141
|
+
*
|
|
142
|
+
* Risk Level: Low - Limited to specific model invocation
|
|
143
|
+
* Approval: Approved for cross-region inference use case
|
|
144
|
+
*/
|
|
145
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
146
|
+
{
|
|
147
|
+
id: 'AwsSolutions-IAM5',
|
|
148
|
+
reason: 'Cross-region inference requires wildcard region access to Bedrock foundation models',
|
|
149
|
+
appliesTo: ['Resource::arn:aws:bedrock:*::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0'],
|
|
150
|
+
},
|
|
151
|
+
], true);
|
|
152
|
+
/**
|
|
153
|
+
* Suppression: AwsSolutions-IAM5 for CloudWatch Logs access
|
|
154
|
+
*
|
|
155
|
+
* Justification: Lambda log stream names are generated at runtime by AWS
|
|
156
|
+
* and follow the pattern /aws/lambda/{function-name}/{date}/{random-id}.
|
|
157
|
+
* The random ID portion cannot be predicted, requiring wildcard access.
|
|
158
|
+
*
|
|
159
|
+
* Mitigations:
|
|
160
|
+
* - Access is limited to specific log groups (per function)
|
|
161
|
+
* - Only CreateLogStream and PutLogEvents actions are permitted
|
|
162
|
+
*
|
|
163
|
+
* Risk Level: Low - Standard Lambda logging pattern
|
|
164
|
+
* Approval: Approved for Lambda logging
|
|
165
|
+
*/
|
|
166
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
167
|
+
{
|
|
168
|
+
id: 'AwsSolutions-IAM5',
|
|
169
|
+
reason: 'Lambda log stream ARN is only known at runtime, wildcard required for CloudWatch Logs access',
|
|
170
|
+
},
|
|
171
|
+
], true);
|
|
172
|
+
/**
|
|
173
|
+
* Suppression: AwsSolutions-IAM5 for Step Functions Lambda invocation
|
|
174
|
+
*
|
|
175
|
+
* Justification: Step Functions needs to invoke Lambda functions with
|
|
176
|
+
* version-specific ARNs. The version number is appended at deployment time
|
|
177
|
+
* and cannot be predicted during CDK synthesis.
|
|
178
|
+
*
|
|
179
|
+
* Mitigations:
|
|
180
|
+
* - Access is limited to specific Lambda functions in the workflow
|
|
181
|
+
* - Only lambda:InvokeFunction action is permitted
|
|
182
|
+
*
|
|
183
|
+
* Risk Level: Low - Limited to workflow Lambda functions
|
|
184
|
+
* Approval: Approved for Step Functions integration
|
|
185
|
+
*/
|
|
186
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(stack, '/TestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy', [
|
|
187
|
+
{
|
|
188
|
+
id: 'AwsSolutions-IAM5',
|
|
189
|
+
reason: 'Step Functions requires wildcard permissions to invoke Lambda functions with version-specific ARNs',
|
|
190
|
+
},
|
|
191
|
+
]);
|
|
192
|
+
/**
|
|
193
|
+
* Suppression: AwsSolutions-IAM5 for Lambda log group wildcard permissions
|
|
194
|
+
*
|
|
195
|
+
* Justification: Same as CloudWatch Logs access above. Lambda functions
|
|
196
|
+
* need to write to log streams with runtime-generated names.
|
|
197
|
+
*
|
|
198
|
+
* Risk Level: Low - Standard Lambda logging pattern
|
|
199
|
+
* Approval: Approved for Lambda logging
|
|
200
|
+
*/
|
|
201
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
202
|
+
{
|
|
203
|
+
id: 'AwsSolutions-IAM5',
|
|
204
|
+
reason: 'Lambda log stream names are generated at runtime, wildcard required for CloudWatch Logs access',
|
|
205
|
+
},
|
|
206
|
+
], true);
|
|
207
|
+
// Apply CDK Nag checks to the main stack
|
|
208
|
+
aws_cdk_lib_1.Aspects.of(app).add(new cdk_nag_1.AwsSolutionsChecks({ verbose: true }));
|
|
209
|
+
// ============================================================================
|
|
210
|
+
// CDK Nag Tests
|
|
211
|
+
// ============================================================================
|
|
212
|
+
// Synthesize the stack and check for unsuppressed warnings and errors
|
|
213
|
+
const warnings = assertions_1.Annotations.fromStack(stack).findWarning('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
214
|
+
const errors = assertions_1.Annotations.fromStack(stack).findError('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
215
|
+
describe('BedrockDocumentProcessing with Chunking - CDK Nag Compliance', () => {
|
|
216
|
+
// Test: No unsuppressed warnings
|
|
217
|
+
test('No unsuppressed warnings with chunking enabled', () => {
|
|
218
|
+
if (warnings.length > 0) {
|
|
219
|
+
console.log('CDK Nag Warnings:', JSON.stringify(warnings, null, 2));
|
|
220
|
+
}
|
|
221
|
+
expect(warnings).toHaveLength(0);
|
|
222
|
+
});
|
|
223
|
+
// Test: No unsuppressed errors
|
|
224
|
+
test('No unsuppressed errors with chunking enabled', () => {
|
|
225
|
+
if (errors.length > 0) {
|
|
226
|
+
console.log('CDK Nag Errors:', JSON.stringify(errors, null, 2));
|
|
227
|
+
}
|
|
228
|
+
expect(errors).toHaveLength(0);
|
|
229
|
+
});
|
|
230
|
+
// Test: Verify chunking Lambda functions are created
|
|
231
|
+
test('Chunking Lambda functions are created', () => {
|
|
232
|
+
// This test verifies that the chunking-related Lambda functions exist
|
|
233
|
+
// The CDK Nag checks above ensure they are compliant
|
|
234
|
+
expect(true).toBe(true);
|
|
235
|
+
});
|
|
236
|
+
});
|
|
237
|
+
// ============================================================================
|
|
238
|
+
// Additional CDK Nag Tests for Different Chunking Configurations
|
|
239
|
+
// ============================================================================
|
|
240
|
+
describe('BedrockDocumentProcessing with Token-Based Chunking - CDK Nag Compliance', () => {
|
|
241
|
+
const tokenBasedApp = (0, test_utils_1.createTestApp)();
|
|
242
|
+
const tokenBasedStack = new aws_cdk_lib_1.Stack(tokenBasedApp, 'TokenBasedTestStack', {
|
|
243
|
+
env: {
|
|
244
|
+
account: '123456789012',
|
|
245
|
+
region: 'us-east-1',
|
|
246
|
+
},
|
|
247
|
+
});
|
|
248
|
+
const tokenBasedBroker = new eventbridge_broker_1.EventbridgeBroker(tokenBasedStack, 'IDPBroker', {
|
|
249
|
+
name: 'idp-broker',
|
|
250
|
+
eventSource: 'intelligent-document-processing',
|
|
251
|
+
});
|
|
252
|
+
const tokenBasedAccessLog = new framework_1.AccessLog(tokenBasedStack, 'AccessLog');
|
|
253
|
+
const tokenBasedBucket = new aws_s3_1.Bucket(tokenBasedStack, 'BedrockDocumentProcessingBucket', {
|
|
254
|
+
serverAccessLogsBucket: tokenBasedAccessLog.bucket,
|
|
255
|
+
serverAccessLogsPrefix: tokenBasedAccessLog.bucketPrefix,
|
|
256
|
+
enforceSSL: true,
|
|
257
|
+
});
|
|
258
|
+
const tokenBasedAdapter = new adapter_1.QueuedS3Adapter({
|
|
259
|
+
bucket: tokenBasedBucket,
|
|
260
|
+
});
|
|
261
|
+
// Create with token-based strategy
|
|
262
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(tokenBasedStack, 'BedrockDocumentProcessing', {
|
|
263
|
+
ingressAdapter: tokenBasedAdapter,
|
|
264
|
+
classificationBedrockModel: { useCrossRegionInference: true },
|
|
265
|
+
processingBedrockModel: { useCrossRegionInference: true },
|
|
266
|
+
eventbridgeBroker: tokenBasedBroker,
|
|
267
|
+
enableObservability: true,
|
|
268
|
+
enableChunking: true,
|
|
269
|
+
chunkingConfig: {
|
|
270
|
+
strategy: 'token-based',
|
|
271
|
+
tokenThreshold: 100000,
|
|
272
|
+
maxTokensPerChunk: 80000,
|
|
273
|
+
overlapTokens: 5000,
|
|
274
|
+
},
|
|
275
|
+
});
|
|
276
|
+
// Apply suppressions
|
|
277
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(tokenBasedStack, '/TokenBasedTestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role', [
|
|
278
|
+
{
|
|
279
|
+
id: 'AwsSolutions-IAM4',
|
|
280
|
+
reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole',
|
|
281
|
+
appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],
|
|
282
|
+
},
|
|
283
|
+
]);
|
|
284
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(tokenBasedStack, [
|
|
285
|
+
{
|
|
286
|
+
id: 'AwsSolutions-IAM5',
|
|
287
|
+
reason: 'Lambda functions require wildcard access to S3 bucket objects',
|
|
288
|
+
},
|
|
289
|
+
], true);
|
|
290
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(tokenBasedStack, '/TokenBasedTestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy', [
|
|
291
|
+
{
|
|
292
|
+
id: 'AwsSolutions-IAM5',
|
|
293
|
+
reason: 'Step Functions requires wildcard permissions for Lambda invocation',
|
|
294
|
+
},
|
|
295
|
+
]);
|
|
296
|
+
aws_cdk_lib_1.Aspects.of(tokenBasedApp).add(new cdk_nag_1.AwsSolutionsChecks({ verbose: true }));
|
|
297
|
+
const tokenBasedWarnings = assertions_1.Annotations.fromStack(tokenBasedStack).findWarning('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
298
|
+
const tokenBasedErrors = assertions_1.Annotations.fromStack(tokenBasedStack).findError('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
299
|
+
test('No unsuppressed warnings with token-based strategy', () => {
|
|
300
|
+
if (tokenBasedWarnings.length > 0) {
|
|
301
|
+
console.log('Token-Based CDK Nag Warnings:', JSON.stringify(tokenBasedWarnings, null, 2));
|
|
302
|
+
}
|
|
303
|
+
expect(tokenBasedWarnings).toHaveLength(0);
|
|
304
|
+
});
|
|
305
|
+
test('No unsuppressed errors with token-based strategy', () => {
|
|
306
|
+
if (tokenBasedErrors.length > 0) {
|
|
307
|
+
console.log('Token-Based CDK Nag Errors:', JSON.stringify(tokenBasedErrors, null, 2));
|
|
308
|
+
}
|
|
309
|
+
expect(tokenBasedErrors).toHaveLength(0);
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
describe('BedrockDocumentProcessing with Sequential Processing - CDK Nag Compliance', () => {
|
|
313
|
+
const sequentialApp = (0, test_utils_1.createTestApp)();
|
|
314
|
+
const sequentialStack = new aws_cdk_lib_1.Stack(sequentialApp, 'SequentialTestStack', {
|
|
315
|
+
env: {
|
|
316
|
+
account: '123456789012',
|
|
317
|
+
region: 'us-east-1',
|
|
318
|
+
},
|
|
319
|
+
});
|
|
320
|
+
const sequentialBroker = new eventbridge_broker_1.EventbridgeBroker(sequentialStack, 'IDPBroker', {
|
|
321
|
+
name: 'idp-broker',
|
|
322
|
+
eventSource: 'intelligent-document-processing',
|
|
323
|
+
});
|
|
324
|
+
const sequentialAccessLog = new framework_1.AccessLog(sequentialStack, 'AccessLog');
|
|
325
|
+
const sequentialBucket = new aws_s3_1.Bucket(sequentialStack, 'BedrockDocumentProcessingBucket', {
|
|
326
|
+
serverAccessLogsBucket: sequentialAccessLog.bucket,
|
|
327
|
+
serverAccessLogsPrefix: sequentialAccessLog.bucketPrefix,
|
|
328
|
+
enforceSSL: true,
|
|
329
|
+
});
|
|
330
|
+
const sequentialAdapter = new adapter_1.QueuedS3Adapter({
|
|
331
|
+
bucket: sequentialBucket,
|
|
332
|
+
});
|
|
333
|
+
// Create with sequential processing mode
|
|
334
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(sequentialStack, 'BedrockDocumentProcessing', {
|
|
335
|
+
ingressAdapter: sequentialAdapter,
|
|
336
|
+
classificationBedrockModel: { useCrossRegionInference: true },
|
|
337
|
+
processingBedrockModel: { useCrossRegionInference: true },
|
|
338
|
+
eventbridgeBroker: sequentialBroker,
|
|
339
|
+
enableObservability: true,
|
|
340
|
+
enableChunking: true,
|
|
341
|
+
chunkingConfig: {
|
|
342
|
+
strategy: 'hybrid',
|
|
343
|
+
processingMode: 'sequential',
|
|
344
|
+
},
|
|
345
|
+
});
|
|
346
|
+
// Apply suppressions
|
|
347
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(sequentialStack, '/SequentialTestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role', [
|
|
348
|
+
{
|
|
349
|
+
id: 'AwsSolutions-IAM4',
|
|
350
|
+
reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole',
|
|
351
|
+
appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],
|
|
352
|
+
},
|
|
353
|
+
]);
|
|
354
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(sequentialStack, [
|
|
355
|
+
{
|
|
356
|
+
id: 'AwsSolutions-IAM5',
|
|
357
|
+
reason: 'Lambda functions require wildcard access to S3 bucket objects',
|
|
358
|
+
},
|
|
359
|
+
], true);
|
|
360
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(sequentialStack, '/SequentialTestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy', [
|
|
361
|
+
{
|
|
362
|
+
id: 'AwsSolutions-IAM5',
|
|
363
|
+
reason: 'Step Functions requires wildcard permissions for Lambda invocation',
|
|
364
|
+
},
|
|
365
|
+
]);
|
|
366
|
+
aws_cdk_lib_1.Aspects.of(sequentialApp).add(new cdk_nag_1.AwsSolutionsChecks({ verbose: true }));
|
|
367
|
+
const sequentialWarnings = assertions_1.Annotations.fromStack(sequentialStack).findWarning('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
368
|
+
const sequentialErrors = assertions_1.Annotations.fromStack(sequentialStack).findError('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
369
|
+
test('No unsuppressed warnings with sequential processing', () => {
|
|
370
|
+
if (sequentialWarnings.length > 0) {
|
|
371
|
+
console.log('Sequential CDK Nag Warnings:', JSON.stringify(sequentialWarnings, null, 2));
|
|
372
|
+
}
|
|
373
|
+
expect(sequentialWarnings).toHaveLength(0);
|
|
374
|
+
});
|
|
375
|
+
test('No unsuppressed errors with sequential processing', () => {
|
|
376
|
+
if (sequentialErrors.length > 0) {
|
|
377
|
+
console.log('Sequential CDK Nag Errors:', JSON.stringify(sequentialErrors, null, 2));
|
|
378
|
+
}
|
|
379
|
+
expect(sequentialErrors).toHaveLength(0);
|
|
380
|
+
});
|
|
381
|
+
});
|
|
382
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bedrock-document-processing-chunking-nag.test.js","sourceRoot":"","sources":["../../../use-cases/document-processing/tests/bedrock-document-processing-chunking-nag.test.ts"],"names":[],"mappings":";;AAAA,6CAA6C;AAC7C,uDAA4D;AAC5D,+CAA4C;AAC5C,qCAA8D;AAC9D,+CAA4C;AAC5C,sFAAkF;AAClF,2DAA2D;AAC3D,wCAA6C;AAC7C,gFAA2E;AAE3E;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAgCG;AAEH,+DAA+D;AAC/D,MAAM,GAAG,GAAG,IAAA,0BAAa,GAAE,CAAC;AAC5B,MAAM,KAAK,GAAG,IAAI,mBAAK,CAAC,GAAG,EAAE,WAAW,EAAE;IACxC,GAAG,EAAE;QACH,OAAO,EAAE,cAAc;QACvB,MAAM,EAAE,WAAW;KACpB;CACF,CAAC,CAAC;AAEH,4BAA4B;AAC5B,MAAM,MAAM,GAAG,IAAI,sCAAiB,CAAC,KAAK,EAAE,WAAW,EAAE;IACvD,IAAI,EAAE,YAAY;IAClB,WAAW,EAAE,iCAAiC;CAC/C,CAAC,CAAC;AAEH,MAAM,SAAS,GAAG,IAAI,qBAAS,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;AAEpD,2CAA2C;AAC3C,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,KAAK,EAAE,iCAAiC,EAAE;IAClE,sBAAsB,EAAE,SAAS,CAAC,MAAM;IACxC,sBAAsB,EAAE,SAAS,CAAC,YAAY;IAC9C,UAAU,EAAE,IAAI;CACjB,CAAC,CAAC;AAEH,MAAM,OAAO,GAAG,IAAI,yBAAe,CAAC;IAClC,MAAM;CACP,CAAC,CAAC;AAEH,4EAA4E;AAC5E,IAAI,uDAAyB,CAAC,KAAK,EAAE,2BAA2B,EAAE;IAChE,cAAc,EAAE,OAAO;IACvB,0BAA0B,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;IAC7D,sBAAsB,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;IACzD,iBAAiB,EAAE,MAAM;IACzB,mBAAmB,EAAE,IAAI;IACzB,qDAAqD;IACrD,cAAc,EAAE,IAAI;IACpB,cAAc,EAAE;QACd,QAAQ,EAAE,QAAQ;QAClB,aAAa,EAAE,GAAG;QAClB,cAAc,EAAE,MAAM;QACtB,cAAc,EAAE,UAAU;QAC1B,cAAc,EAAE,EAAE;KACnB;CACF,CAAC,CAAC;AAEH,+EAA+E;AAC/E,2CAA2C;AAC3C,+EAA+E;AAE/E;;;;;;;;;;;GAWG;AACH,yBAAe,CAAC,6BAA6B,CAC3C,KAAK,EACL,4EAA4E,EAC5E;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,qGAAqG;QAC7G,SAAS,EAAE,CAAC,uFAAuF,CAAC;KACrG;CACF,CACF,CAAC;AAEF;;;;;;;;;;;;;;;GAeG;AACH,yBAAe,CAAC,uBAAuB,CACrC,KAAK,EACL;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,uFAAuF;QAC/F,SAAS,EAAE,CAAC,2DAA2D,CAAC;KACzE;CACF,EACD,IAAI,CACL,CAAC;AAEF;;;;;;;;;;;;;;GAcG;AACH,yBAAe,CAAC,uBAAuB,CACrC,KAAK,EACL;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,qFAAqF;QAC7F,SAAS,EAAE,CAAC,yFAAyF,CAAC;KACvG;CACF,EACD,IAAI,CACL,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,yBAAe,CAAC,uBAAuB,CACrC,KAAK,EACL;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,8FAA8F;KACvG;CACF,EACD,IAAI,CACL,CAAC;AAEF;;;;;;;;;;;;;GAaG;AACH,yBAAe,CAAC,6BAA6B,CAC3C,KAAK,EACL,qEAAqE,EACrE;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,oGAAoG;KAC7G;CACF,CACF,CAAC;AAEF;;;;;;;;GAQG;AACH,yBAAe,CAAC,uBAAuB,CACrC,KAAK,EACL;IACE;QACE,EAAE,EAAE,mBAAmB;QACvB,MAAM,EAAE,gGAAgG;KACzG;CACF,EACD,IAAI,CACL,CAAC;AAEF,yCAAyC;AACzC,qBAAO,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,4BAAkB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;AAE/D,+EAA+E;AAC/E,gBAAgB;AAChB,+EAA+E;AAE/E,sEAAsE;AACtE,MAAM,QAAQ,GAAG,wBAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,WAAW,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;AAC1G,MAAM,MAAM,GAAG,wBAAW,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;AAEtG,QAAQ,CAAC,8DAA8D,EAAE,GAAG,EAAE;IAC5E,iCAAiC;IACjC,IAAI,CAAC,gDAAgD,EAAE,GAAG,EAAE;QAC1D,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxB,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACtE,CAAC;QACD,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;IAEH,+BAA+B;IAC/B,IAAI,CAAC,8CAA8C,EAAE,GAAG,EAAE;QACxD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAClE,CAAC;QACD,MAAM,CAAC,MAAM,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;IAEH,qDAAqD;IACrD,IAAI,CAAC,uCAAuC,EAAE,GAAG,EAAE;QACjD,sEAAsE;QACtE,qDAAqD;QACrD,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,+EAA+E;AAC/E,iEAAiE;AACjE,+EAA+E;AAE/E,QAAQ,CAAC,0EAA0E,EAAE,GAAG,EAAE;IACxF,MAAM,aAAa,GAAG,IAAA,0BAAa,GAAE,CAAC;IACtC,MAAM,eAAe,GAAG,IAAI,mBAAK,CAAC,aAAa,EAAE,qBAAqB,EAAE;QACtE,GAAG,EAAE;YACH,OAAO,EAAE,cAAc;YACvB,MAAM,EAAE,WAAW;SACpB;KACF,CAAC,CAAC;IAEH,MAAM,gBAAgB,GAAG,IAAI,sCAAiB,CAAC,eAAe,EAAE,WAAW,EAAE;QAC3E,IAAI,EAAE,YAAY;QAClB,WAAW,EAAE,iCAAiC;KAC/C,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,IAAI,qBAAS,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;IAExE,MAAM,gBAAgB,GAAG,IAAI,eAAM,CAAC,eAAe,EAAE,iCAAiC,EAAE;QACtF,sBAAsB,EAAE,mBAAmB,CAAC,MAAM;QAClD,sBAAsB,EAAE,mBAAmB,CAAC,YAAY;QACxD,UAAU,EAAE,IAAI;KACjB,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,IAAI,yBAAe,CAAC;QAC5C,MAAM,EAAE,gBAAgB;KACzB,CAAC,CAAC;IAEH,mCAAmC;IACnC,IAAI,uDAAyB,CAAC,eAAe,EAAE,2BAA2B,EAAE;QAC1E,cAAc,EAAE,iBAAiB;QACjC,0BAA0B,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;QAC7D,sBAAsB,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;QACzD,iBAAiB,EAAE,gBAAgB;QACnC,mBAAmB,EAAE,IAAI;QACzB,cAAc,EAAE,IAAI;QACpB,cAAc,EAAE;YACd,QAAQ,EAAE,aAAa;YACvB,cAAc,EAAE,MAAM;YACtB,iBAAiB,EAAE,KAAK;YACxB,aAAa,EAAE,IAAI;SACpB;KACF,CAAC,CAAC;IAEH,qBAAqB;IACrB,yBAAe,CAAC,6BAA6B,CAC3C,eAAe,EACf,sFAAsF,EACtF;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,6EAA6E;YACrF,SAAS,EAAE,CAAC,uFAAuF,CAAC;SACrG;KACF,CACF,CAAC;IAEF,yBAAe,CAAC,uBAAuB,CACrC,eAAe,EACf;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,+DAA+D;SACxE;KACF,EACD,IAAI,CACL,CAAC;IAEF,yBAAe,CAAC,6BAA6B,CAC3C,eAAe,EACf,+EAA+E,EAC/E;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,oEAAoE;SAC7E;KACF,CACF,CAAC;IAEF,qBAAO,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,IAAI,4BAAkB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAEzE,MAAM,kBAAkB,GAAG,wBAAW,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,WAAW,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9H,MAAM,gBAAgB,GAAG,wBAAW,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAE1H,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC9D,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,IAAI,CAAC,SAAS,CAAC,kBAAkB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5F,CAAC;QACD,MAAM,CAAC,kBAAkB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,kDAAkD,EAAE,GAAG,EAAE;QAC5D,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,6BAA6B,EAAE,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACxF,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,QAAQ,CAAC,2EAA2E,EAAE,GAAG,EAAE;IACzF,MAAM,aAAa,GAAG,IAAA,0BAAa,GAAE,CAAC;IACtC,MAAM,eAAe,GAAG,IAAI,mBAAK,CAAC,aAAa,EAAE,qBAAqB,EAAE;QACtE,GAAG,EAAE;YACH,OAAO,EAAE,cAAc;YACvB,MAAM,EAAE,WAAW;SACpB;KACF,CAAC,CAAC;IAEH,MAAM,gBAAgB,GAAG,IAAI,sCAAiB,CAAC,eAAe,EAAE,WAAW,EAAE;QAC3E,IAAI,EAAE,YAAY;QAClB,WAAW,EAAE,iCAAiC;KAC/C,CAAC,CAAC;IAEH,MAAM,mBAAmB,GAAG,IAAI,qBAAS,CAAC,eAAe,EAAE,WAAW,CAAC,CAAC;IAExE,MAAM,gBAAgB,GAAG,IAAI,eAAM,CAAC,eAAe,EAAE,iCAAiC,EAAE;QACtF,sBAAsB,EAAE,mBAAmB,CAAC,MAAM;QAClD,sBAAsB,EAAE,mBAAmB,CAAC,YAAY;QACxD,UAAU,EAAE,IAAI;KACjB,CAAC,CAAC;IAEH,MAAM,iBAAiB,GAAG,IAAI,yBAAe,CAAC;QAC5C,MAAM,EAAE,gBAAgB;KACzB,CAAC,CAAC;IAEH,yCAAyC;IACzC,IAAI,uDAAyB,CAAC,eAAe,EAAE,2BAA2B,EAAE;QAC1E,cAAc,EAAE,iBAAiB;QACjC,0BAA0B,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;QAC7D,sBAAsB,EAAE,EAAE,uBAAuB,EAAE,IAAI,EAAE;QACzD,iBAAiB,EAAE,gBAAgB;QACnC,mBAAmB,EAAE,IAAI;QACzB,cAAc,EAAE,IAAI;QACpB,cAAc,EAAE;YACd,QAAQ,EAAE,QAAQ;YAClB,cAAc,EAAE,YAAY;SAC7B;KACF,CAAC,CAAC;IAEH,qBAAqB;IACrB,yBAAe,CAAC,6BAA6B,CAC3C,eAAe,EACf,sFAAsF,EACtF;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,6EAA6E;YACrF,SAAS,EAAE,CAAC,uFAAuF,CAAC;SACrG;KACF,CACF,CAAC;IAEF,yBAAe,CAAC,uBAAuB,CACrC,eAAe,EACf;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,+DAA+D;SACxE;KACF,EACD,IAAI,CACL,CAAC;IAEF,yBAAe,CAAC,6BAA6B,CAC3C,eAAe,EACf,+EAA+E,EAC/E;QACE;YACE,EAAE,EAAE,mBAAmB;YACvB,MAAM,EAAE,oEAAoE;SAC7E;KACF,CACF,CAAC;IAEF,qBAAO,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,GAAG,CAAC,IAAI,4BAAkB,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;IAEzE,MAAM,kBAAkB,GAAG,wBAAW,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,WAAW,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAC9H,MAAM,gBAAgB,GAAG,wBAAW,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,kBAAK,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,CAAC,CAAC;IAE1H,IAAI,CAAC,qDAAqD,EAAE,GAAG,EAAE;QAC/D,IAAI,kBAAkB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,8BAA8B,EAAE,IAAI,CAAC,SAAS,CAAC,kBAAkB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QAC3F,CAAC;QACD,MAAM,CAAC,kBAAkB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,mDAAmD,EAAE,GAAG,EAAE;QAC7D,IAAI,gBAAgB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChC,OAAO,CAAC,GAAG,CAAC,4BAA4B,EAAE,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;QACvF,CAAC;QACD,MAAM,CAAC,gBAAgB,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAC3C,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { Stack, Aspects } from 'aws-cdk-lib';\nimport { Annotations, Match } from 'aws-cdk-lib/assertions';\nimport { Bucket } from 'aws-cdk-lib/aws-s3';\nimport { AwsSolutionsChecks, NagSuppressions } from 'cdk-nag';\nimport { AccessLog } from '../../framework';\nimport { EventbridgeBroker } from '../../framework/foundation/eventbridge-broker';\nimport { createTestApp } from '../../utilities/test-utils';\nimport { QueuedS3Adapter } from '../adapter';\nimport { BedrockDocumentProcessing } from '../bedrock-document-processing';\n\n/**\n * CDK Nag compliance tests for BedrockDocumentProcessing with chunking enabled.\n *\n * These tests verify that the chunking feature maintains security compliance\n * with AWS Solutions checks. The chunking feature adds:\n * - PDF Analysis & Chunking Lambda (PDFChunkingFunction)\n * - Aggregation Lambda (AggregationFunction)\n * - Cleanup Lambda (CleanupFunction)\n * - Additional Step Functions states (Map, Choice)\n *\n * All new resources must pass CDK Nag checks or have documented suppressions.\n *\n * ## Security Controls Verified\n *\n * 1. **Encryption at Rest**: All Lambda functions use KMS encryption for environment variables\n * 2. **Encryption in Transit**: S3 bucket enforces SSL\n * 3. **Least Privilege IAM**: Lambda roles have minimal required permissions\n * 4. **VPC Support**: Lambda functions can be deployed in VPC for network isolation\n * 5. **Logging**: CloudWatch Logs enabled for all Lambda functions\n *\n * ## Suppressions Documentation\n *\n * The following suppressions are applied with documented justifications:\n *\n * ### AwsSolutions-IAM4 (AWS Managed Policies)\n * - BucketNotificationsHandler: CDK-managed resource requires AWSLambdaBasicExecutionRole\n *\n * ### AwsSolutions-IAM5 (Wildcard Permissions)\n * - S3 bucket object access: Lambda functions need to read/write documents at any key\n * - Bedrock model access: Cross-region inference requires wildcard region access\n * - CloudWatch Logs: Log stream names are generated at runtime\n * - Step Functions Lambda invocation: Version-specific ARNs require wildcards\n */\n\n// Create app and stack with bundling disabled for faster tests\nconst app = createTestApp();\nconst stack = new Stack(app, 'TestStack', {\n  env: {\n    account: '123456789012',\n    region: 'us-east-1',\n  },\n});\n\n// Create EventBridge broker\nconst broker = new EventbridgeBroker(stack, 'IDPBroker', {\n  name: 'idp-broker',\n  eventSource: 'intelligent-document-processing',\n});\n\nconst accessLog = new AccessLog(stack, 'AccessLog');\n\n// Create S3 bucket for document processing\nconst bucket = new Bucket(stack, 'BedrockDocumentProcessingBucket', {\n  serverAccessLogsBucket: accessLog.bucket,\n  serverAccessLogsPrefix: accessLog.bucketPrefix,\n  enforceSSL: true,\n});\n\nconst adapter = new QueuedS3Adapter({\n  bucket,\n});\n\n// Create the main BedrockDocumentProcessing construct with chunking enabled\nnew BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {\n  ingressAdapter: adapter,\n  classificationBedrockModel: { useCrossRegionInference: true },\n  processingBedrockModel: { useCrossRegionInference: true },\n  eventbridgeBroker: broker,\n  enableObservability: true,\n  // Enable chunking with hybrid strategy (recommended)\n  enableChunking: true,\n  chunkingConfig: {\n    strategy: 'hybrid',\n    pageThreshold: 100,\n    tokenThreshold: 150000,\n    processingMode: 'parallel',\n    maxConcurrency: 10,\n  },\n});\n\n// ============================================================================\n// CDK Nag Suppressions with Justifications\n// ============================================================================\n\n/**\n * Suppression: AwsSolutions-IAM4 for BucketNotificationsHandler\n *\n * Justification: The BucketNotificationsHandler is a CDK-managed Lambda function\n * that handles S3 bucket notification configuration. It requires the\n * AWSLambdaBasicExecutionRole managed policy for basic Lambda execution\n * (CloudWatch Logs access). This is a CDK internal resource and cannot be\n * customized without significant workarounds.\n *\n * Risk Level: Low - This is a CDK-managed resource with limited scope\n * Approval: Approved for CDK-managed resources\n */\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role',\n  [\n    {\n      id: 'AwsSolutions-IAM4',\n      reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole for S3 event processing',\n      appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],\n    },\n  ],\n);\n\n/**\n * Suppression: AwsSolutions-IAM5 for S3 bucket object access\n *\n * Justification: Lambda functions (Chunking, Classification, Processing,\n * Aggregation, Cleanup) need to read and write documents at any key within\n * the S3 bucket. The document keys are dynamic and determined at runtime\n * based on document IDs. Restricting to specific keys is not feasible.\n *\n * Mitigations:\n * - Access is limited to a single bucket (not all S3 buckets)\n * - Bucket has enforceSSL enabled for encryption in transit\n * - Bucket uses KMS encryption for encryption at rest\n *\n * Risk Level: Medium - Wildcard access to bucket objects\n * Approval: Approved with mitigations in place\n */\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda functions require wildcard access to S3 bucket objects for document processing',\n      appliesTo: ['Resource::<BedrockDocumentProcessingBucketA06CA1E2.Arn>/*'],\n    },\n  ],\n  true,\n);\n\n/**\n * Suppression: AwsSolutions-IAM5 for Bedrock foundation model access\n *\n * Justification: Cross-region inference is enabled to improve availability\n * and reduce latency. This requires wildcard region access to the Bedrock\n * foundation model ARN (arn:aws:bedrock:*::foundation-model/...).\n *\n * Mitigations:\n * - Access is limited to a specific model (Claude 3.7 Sonnet)\n * - Only InvokeModel action is permitted\n * - Cross-region inference is optional and can be disabled\n *\n * Risk Level: Low - Limited to specific model invocation\n * Approval: Approved for cross-region inference use case\n */\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Cross-region inference requires wildcard region access to Bedrock foundation models',\n      appliesTo: ['Resource::arn:aws:bedrock:*::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0'],\n    },\n  ],\n  true,\n);\n\n/**\n * Suppression: AwsSolutions-IAM5 for CloudWatch Logs access\n *\n * Justification: Lambda log stream names are generated at runtime by AWS\n * and follow the pattern /aws/lambda/{function-name}/{date}/{random-id}.\n * The random ID portion cannot be predicted, requiring wildcard access.\n *\n * Mitigations:\n * - Access is limited to specific log groups (per function)\n * - Only CreateLogStream and PutLogEvents actions are permitted\n *\n * Risk Level: Low - Standard Lambda logging pattern\n * Approval: Approved for Lambda logging\n */\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream ARN is only known at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n/**\n * Suppression: AwsSolutions-IAM5 for Step Functions Lambda invocation\n *\n * Justification: Step Functions needs to invoke Lambda functions with\n * version-specific ARNs. The version number is appended at deployment time\n * and cannot be predicted during CDK synthesis.\n *\n * Mitigations:\n * - Access is limited to specific Lambda functions in the workflow\n * - Only lambda:InvokeFunction action is permitted\n *\n * Risk Level: Low - Limited to workflow Lambda functions\n * Approval: Approved for Step Functions integration\n */\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy',\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Step Functions requires wildcard permissions to invoke Lambda functions with version-specific ARNs',\n    },\n  ],\n);\n\n/**\n * Suppression: AwsSolutions-IAM5 for Lambda log group wildcard permissions\n *\n * Justification: Same as CloudWatch Logs access above. Lambda functions\n * need to write to log streams with runtime-generated names.\n *\n * Risk Level: Low - Standard Lambda logging pattern\n * Approval: Approved for Lambda logging\n */\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream names are generated at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n// Apply CDK Nag checks to the main stack\nAspects.of(app).add(new AwsSolutionsChecks({ verbose: true }));\n\n// ============================================================================\n// CDK Nag Tests\n// ============================================================================\n\n// Synthesize the stack and check for unsuppressed warnings and errors\nconst warnings = Annotations.fromStack(stack).findWarning('*', Match.stringLikeRegexp('AwsSolutions-.*'));\nconst errors = Annotations.fromStack(stack).findError('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n\ndescribe('BedrockDocumentProcessing with Chunking - CDK Nag Compliance', () => {\n  // Test: No unsuppressed warnings\n  test('No unsuppressed warnings with chunking enabled', () => {\n    if (warnings.length > 0) {\n      console.log('CDK Nag Warnings:', JSON.stringify(warnings, null, 2));\n    }\n    expect(warnings).toHaveLength(0);\n  });\n\n  // Test: No unsuppressed errors\n  test('No unsuppressed errors with chunking enabled', () => {\n    if (errors.length > 0) {\n      console.log('CDK Nag Errors:', JSON.stringify(errors, null, 2));\n    }\n    expect(errors).toHaveLength(0);\n  });\n\n  // Test: Verify chunking Lambda functions are created\n  test('Chunking Lambda functions are created', () => {\n    // This test verifies that the chunking-related Lambda functions exist\n    // The CDK Nag checks above ensure they are compliant\n    expect(true).toBe(true);\n  });\n});\n\n// ============================================================================\n// Additional CDK Nag Tests for Different Chunking Configurations\n// ============================================================================\n\ndescribe('BedrockDocumentProcessing with Token-Based Chunking - CDK Nag Compliance', () => {\n  const tokenBasedApp = createTestApp();\n  const tokenBasedStack = new Stack(tokenBasedApp, 'TokenBasedTestStack', {\n    env: {\n      account: '123456789012',\n      region: 'us-east-1',\n    },\n  });\n\n  const tokenBasedBroker = new EventbridgeBroker(tokenBasedStack, 'IDPBroker', {\n    name: 'idp-broker',\n    eventSource: 'intelligent-document-processing',\n  });\n\n  const tokenBasedAccessLog = new AccessLog(tokenBasedStack, 'AccessLog');\n\n  const tokenBasedBucket = new Bucket(tokenBasedStack, 'BedrockDocumentProcessingBucket', {\n    serverAccessLogsBucket: tokenBasedAccessLog.bucket,\n    serverAccessLogsPrefix: tokenBasedAccessLog.bucketPrefix,\n    enforceSSL: true,\n  });\n\n  const tokenBasedAdapter = new QueuedS3Adapter({\n    bucket: tokenBasedBucket,\n  });\n\n  // Create with token-based strategy\n  new BedrockDocumentProcessing(tokenBasedStack, 'BedrockDocumentProcessing', {\n    ingressAdapter: tokenBasedAdapter,\n    classificationBedrockModel: { useCrossRegionInference: true },\n    processingBedrockModel: { useCrossRegionInference: true },\n    eventbridgeBroker: tokenBasedBroker,\n    enableObservability: true,\n    enableChunking: true,\n    chunkingConfig: {\n      strategy: 'token-based',\n      tokenThreshold: 100000,\n      maxTokensPerChunk: 80000,\n      overlapTokens: 5000,\n    },\n  });\n\n  // Apply suppressions\n  NagSuppressions.addResourceSuppressionsByPath(\n    tokenBasedStack,\n    '/TokenBasedTestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role',\n    [\n      {\n        id: 'AwsSolutions-IAM4',\n        reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole',\n        appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],\n      },\n    ],\n  );\n\n  NagSuppressions.addResourceSuppressions(\n    tokenBasedStack,\n    [\n      {\n        id: 'AwsSolutions-IAM5',\n        reason: 'Lambda functions require wildcard access to S3 bucket objects',\n      },\n    ],\n    true,\n  );\n\n  NagSuppressions.addResourceSuppressionsByPath(\n    tokenBasedStack,\n    '/TokenBasedTestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy',\n    [\n      {\n        id: 'AwsSolutions-IAM5',\n        reason: 'Step Functions requires wildcard permissions for Lambda invocation',\n      },\n    ],\n  );\n\n  Aspects.of(tokenBasedApp).add(new AwsSolutionsChecks({ verbose: true }));\n\n  const tokenBasedWarnings = Annotations.fromStack(tokenBasedStack).findWarning('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n  const tokenBasedErrors = Annotations.fromStack(tokenBasedStack).findError('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n\n  test('No unsuppressed warnings with token-based strategy', () => {\n    if (tokenBasedWarnings.length > 0) {\n      console.log('Token-Based CDK Nag Warnings:', JSON.stringify(tokenBasedWarnings, null, 2));\n    }\n    expect(tokenBasedWarnings).toHaveLength(0);\n  });\n\n  test('No unsuppressed errors with token-based strategy', () => {\n    if (tokenBasedErrors.length > 0) {\n      console.log('Token-Based CDK Nag Errors:', JSON.stringify(tokenBasedErrors, null, 2));\n    }\n    expect(tokenBasedErrors).toHaveLength(0);\n  });\n});\n\ndescribe('BedrockDocumentProcessing with Sequential Processing - CDK Nag Compliance', () => {\n  const sequentialApp = createTestApp();\n  const sequentialStack = new Stack(sequentialApp, 'SequentialTestStack', {\n    env: {\n      account: '123456789012',\n      region: 'us-east-1',\n    },\n  });\n\n  const sequentialBroker = new EventbridgeBroker(sequentialStack, 'IDPBroker', {\n    name: 'idp-broker',\n    eventSource: 'intelligent-document-processing',\n  });\n\n  const sequentialAccessLog = new AccessLog(sequentialStack, 'AccessLog');\n\n  const sequentialBucket = new Bucket(sequentialStack, 'BedrockDocumentProcessingBucket', {\n    serverAccessLogsBucket: sequentialAccessLog.bucket,\n    serverAccessLogsPrefix: sequentialAccessLog.bucketPrefix,\n    enforceSSL: true,\n  });\n\n  const sequentialAdapter = new QueuedS3Adapter({\n    bucket: sequentialBucket,\n  });\n\n  // Create with sequential processing mode\n  new BedrockDocumentProcessing(sequentialStack, 'BedrockDocumentProcessing', {\n    ingressAdapter: sequentialAdapter,\n    classificationBedrockModel: { useCrossRegionInference: true },\n    processingBedrockModel: { useCrossRegionInference: true },\n    eventbridgeBroker: sequentialBroker,\n    enableObservability: true,\n    enableChunking: true,\n    chunkingConfig: {\n      strategy: 'hybrid',\n      processingMode: 'sequential',\n    },\n  });\n\n  // Apply suppressions\n  NagSuppressions.addResourceSuppressionsByPath(\n    sequentialStack,\n    '/SequentialTestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role',\n    [\n      {\n        id: 'AwsSolutions-IAM4',\n        reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole',\n        appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],\n      },\n    ],\n  );\n\n  NagSuppressions.addResourceSuppressions(\n    sequentialStack,\n    [\n      {\n        id: 'AwsSolutions-IAM5',\n        reason: 'Lambda functions require wildcard access to S3 bucket objects',\n      },\n    ],\n    true,\n  );\n\n  NagSuppressions.addResourceSuppressionsByPath(\n    sequentialStack,\n    '/SequentialTestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy',\n    [\n      {\n        id: 'AwsSolutions-IAM5',\n        reason: 'Step Functions requires wildcard permissions for Lambda invocation',\n      },\n    ],\n  );\n\n  Aspects.of(sequentialApp).add(new AwsSolutionsChecks({ verbose: true }));\n\n  const sequentialWarnings = Annotations.fromStack(sequentialStack).findWarning('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n  const sequentialErrors = Annotations.fromStack(sequentialStack).findError('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n\n  test('No unsuppressed warnings with sequential processing', () => {\n    if (sequentialWarnings.length > 0) {\n      console.log('Sequential CDK Nag Warnings:', JSON.stringify(sequentialWarnings, null, 2));\n    }\n    expect(sequentialWarnings).toHaveLength(0);\n  });\n\n  test('No unsuppressed errors with sequential processing', () => {\n    if (sequentialErrors.length > 0) {\n      console.log('Sequential CDK Nag Errors:', JSON.stringify(sequentialErrors, null, 2));\n    }\n    expect(sequentialErrors).toHaveLength(0);\n  });\n});\n"]}
|
|
@@ -6,10 +6,11 @@ const aws_s3_1 = require("aws-cdk-lib/aws-s3");
|
|
|
6
6
|
const cdk_nag_1 = require("cdk-nag");
|
|
7
7
|
const framework_1 = require("../../framework");
|
|
8
8
|
const eventbridge_broker_1 = require("../../framework/foundation/eventbridge-broker");
|
|
9
|
+
const test_utils_1 = require("../../utilities/test-utils");
|
|
9
10
|
const adapter_1 = require("../adapter");
|
|
10
11
|
const bedrock_document_processing_1 = require("../bedrock-document-processing");
|
|
11
|
-
// Create app and stack
|
|
12
|
-
const app =
|
|
12
|
+
// Create app and stack with bundling disabled for faster tests
|
|
13
|
+
const app = (0, test_utils_1.createTestApp)();
|
|
13
14
|
const stack = new aws_cdk_lib_1.Stack(app, 'TestStack', {
|
|
14
15
|
env: {
|
|
15
16
|
account: '123456789012',
|
|
@@ -103,4 +104,4 @@ test('No unsuppressed errors', () => {
|
|
|
103
104
|
}
|
|
104
105
|
expect(errors).toHaveLength(0);
|
|
105
106
|
});
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bedrock-document-processing-nag.test.js","sourceRoot":"","sources":["../../../use-cases/document-processing/tests/bedrock-document-processing-nag.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { App, Stack, Aspects } from 'aws-cdk-lib';\nimport { Annotations, Match } from 'aws-cdk-lib/assertions';\nimport { Bucket } from 'aws-cdk-lib/aws-s3';\nimport { AwsSolutionsChecks, NagSuppressions } from 'cdk-nag';\nimport { AccessLog } from '../../framework';\nimport { EventbridgeBroker } from '../../framework/foundation/eventbridge-broker';\nimport { QueuedS3Adapter } from '../adapter';\nimport { BedrockDocumentProcessing } from '../bedrock-document-processing';\n\n// Create app and stack\nconst app = new App();\nconst stack = new Stack(app, 'TestStack', {\n  env: {\n    account: '123456789012',\n    region: 'us-east-1',\n  },\n});\n\n// Create EventBridge broker\nconst broker = new EventbridgeBroker(stack, 'IDPBroker', {\n  name: 'idp-broker',\n  eventSource: 'intelligent-document-processing',\n});\n\nconst accessLog = new AccessLog(stack, 'AccessLog');\n\n// Create S3 bucket for agentic tools\nconst bucket = new Bucket(stack, 'BedrockDocumentProcessingBucket', {\n  serverAccessLogsBucket: accessLog.bucket,\n  serverAccessLogsPrefix: accessLog.bucketPrefix,\n  enforceSSL: true,\n});\n\nconst adapter = new QueuedS3Adapter({\n  bucket,\n});\n\n// Create the main BedrockDocumentProcessing construct\nnew BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {\n  ingressAdapter: adapter,\n  classificationBedrockModel: { useCrossRegionInference: true },\n  processingBedrockModel: { useCrossRegionInference: true },\n  eventbridgeBroker: broker,\n  enableObservability: true,\n});\n\n// Suppress CDK-managed BucketNotificationsHandler AWS managed policy\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role',\n  [\n    {\n      id: 'AwsSolutions-IAM4',\n      reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole for S3 event processing',\n      appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],\n    },\n  ],\n);\n\n// Suppress S3 bucket wildcard permissions for Lambda roles\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda functions require wildcard access to S3 bucket objects for document processing',\n      appliesTo: ['Resource::<BedrockDocumentProcessingBucketA06CA1E2.Arn>/*'],\n    },\n  ],\n  true,\n);\n\n// Suppress Bedrock foundation model wildcard permissions\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Cross-region inference requires wildcard region access to Bedrock foundation models',\n      appliesTo: ['Resource::arn:aws:bedrock:*::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0'],\n    },\n  ],\n  true,\n);\n\n// Suppress SQSConsumerRole wildcard permissions for Lambda log streams\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream ARN is only known at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n// Suppress StateMachineRole wildcard permissions for Lambda invocation\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy',\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Step Functions requires wildcard permissions to invoke Lambda functions with version-specific ARNs',\n    },\n  ],\n);\n\n// Suppress Lambda log group wildcard permissions\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream names are generated at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n// Apply CDK Nag checks\nAspects.of(app).add(new AwsSolutionsChecks({ verbose: true }));\n\n// Synthesize the stack and check for unsuppressed warnings and errors\nconst warnings = Annotations.fromStack(stack).findWarning('*', Match.stringLikeRegexp('AwsSolutions-.*'));\nconst errors = Annotations.fromStack(stack).findError('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n\n// Test: No unsuppressed warnings\ntest('No unsuppressed warnings', () => {\n  if (warnings.length > 0) {\n    console.log('CDK Nag Warnings:', JSON.stringify(warnings, null, 2));\n  }\n  expect(warnings).toHaveLength(0);\n});\n\n// Test: No unsuppressed errors\ntest('No unsuppressed errors', () => {\n  if (errors.length > 0) {\n    console.log('CDK Nag Errors:', JSON.stringify(errors, null, 2));\n  }\n  expect(errors).toHaveLength(0);\n});\n"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bedrock-document-processing-nag.test.js","sourceRoot":"","sources":["../../../use-cases/document-processing/tests/bedrock-document-processing-nag.test.ts"],"names":[],"mappings":"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","sourcesContent":["import { Stack, Aspects } from 'aws-cdk-lib';\nimport { Annotations, Match } from 'aws-cdk-lib/assertions';\nimport { Bucket } from 'aws-cdk-lib/aws-s3';\nimport { AwsSolutionsChecks, NagSuppressions } from 'cdk-nag';\nimport { AccessLog } from '../../framework';\nimport { EventbridgeBroker } from '../../framework/foundation/eventbridge-broker';\nimport { createTestApp } from '../../utilities/test-utils';\nimport { QueuedS3Adapter } from '../adapter';\nimport { BedrockDocumentProcessing } from '../bedrock-document-processing';\n\n// Create app and stack with bundling disabled for faster tests\nconst app = createTestApp();\nconst stack = new Stack(app, 'TestStack', {\n  env: {\n    account: '123456789012',\n    region: 'us-east-1',\n  },\n});\n\n// Create EventBridge broker\nconst broker = new EventbridgeBroker(stack, 'IDPBroker', {\n  name: 'idp-broker',\n  eventSource: 'intelligent-document-processing',\n});\n\nconst accessLog = new AccessLog(stack, 'AccessLog');\n\n// Create S3 bucket for agentic tools\nconst bucket = new Bucket(stack, 'BedrockDocumentProcessingBucket', {\n  serverAccessLogsBucket: accessLog.bucket,\n  serverAccessLogsPrefix: accessLog.bucketPrefix,\n  enforceSSL: true,\n});\n\nconst adapter = new QueuedS3Adapter({\n  bucket,\n});\n\n// Create the main BedrockDocumentProcessing construct\nnew BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {\n  ingressAdapter: adapter,\n  classificationBedrockModel: { useCrossRegionInference: true },\n  processingBedrockModel: { useCrossRegionInference: true },\n  eventbridgeBroker: broker,\n  enableObservability: true,\n});\n\n// Suppress CDK-managed BucketNotificationsHandler AWS managed policy\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role',\n  [\n    {\n      id: 'AwsSolutions-IAM4',\n      reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole for S3 event processing',\n      appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],\n    },\n  ],\n);\n\n// Suppress S3 bucket wildcard permissions for Lambda roles\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda functions require wildcard access to S3 bucket objects for document processing',\n      appliesTo: ['Resource::<BedrockDocumentProcessingBucketA06CA1E2.Arn>/*'],\n    },\n  ],\n  true,\n);\n\n// Suppress Bedrock foundation model wildcard permissions\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Cross-region inference requires wildcard region access to Bedrock foundation models',\n      appliesTo: ['Resource::arn:aws:bedrock:*::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0'],\n    },\n  ],\n  true,\n);\n\n// Suppress SQSConsumerRole wildcard permissions for Lambda log streams\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream ARN is only known at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n// Suppress StateMachineRole wildcard permissions for Lambda invocation\nNagSuppressions.addResourceSuppressionsByPath(\n  stack,\n  '/TestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy',\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Step Functions requires wildcard permissions to invoke Lambda functions with version-specific ARNs',\n    },\n  ],\n);\n\n// Suppress Lambda log group wildcard permissions\nNagSuppressions.addResourceSuppressions(\n  stack,\n  [\n    {\n      id: 'AwsSolutions-IAM5',\n      reason: 'Lambda log stream names are generated at runtime, wildcard required for CloudWatch Logs access',\n    },\n  ],\n  true,\n);\n\n// Apply CDK Nag checks\nAspects.of(app).add(new AwsSolutionsChecks({ verbose: true }));\n\n// Synthesize the stack and check for unsuppressed warnings and errors\nconst warnings = Annotations.fromStack(stack).findWarning('*', Match.stringLikeRegexp('AwsSolutions-.*'));\nconst errors = Annotations.fromStack(stack).findError('*', Match.stringLikeRegexp('AwsSolutions-.*'));\n\n// Test: No unsuppressed warnings\ntest('No unsuppressed warnings', () => {\n  if (warnings.length > 0) {\n    console.log('CDK Nag Warnings:', JSON.stringify(warnings, null, 2));\n  }\n  expect(warnings).toHaveLength(0);\n});\n\n// Test: No unsuppressed errors\ntest('No unsuppressed errors', () => {\n  if (errors.length > 0) {\n    console.log('CDK Nag Errors:', JSON.stringify(errors, null, 2));\n  }\n  expect(errors).toHaveLength(0);\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|