@cdklabs/cdk-appmod-catalog-blueprints 1.0.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 +8644 -0
- package/LICENSE +202 -0
- package/README.md +212 -0
- package/lib/document-processing/agentic-document-processing.d.ts +16 -0
- package/lib/document-processing/agentic-document-processing.js +90 -0
- package/lib/document-processing/base-document-processing.d.ts +189 -0
- package/lib/document-processing/base-document-processing.js +509 -0
- package/lib/document-processing/bedrock-document-processing.d.ts +167 -0
- package/lib/document-processing/bedrock-document-processing.js +297 -0
- package/lib/document-processing/index.d.ts +3 -0
- package/lib/document-processing/index.js +20 -0
- package/lib/document-processing/resources/default-bedrock-invoke/index.py +63 -0
- package/lib/document-processing/resources/default-bedrock-invoke/requirements.txt +4 -0
- package/lib/document-processing/resources/default-doc-retrieval-lambda/index.mjs +92 -0
- package/lib/document-processing/resources/default-doc-retrieval-lambda/package.json +10 -0
- package/lib/document-processing/resources/default-error-handler/index.js +46 -0
- package/lib/document-processing/resources/default-error-handler/package.json +4 -0
- package/lib/document-processing/resources/default-image-processor/classifier.mjs +665 -0
- package/lib/document-processing/resources/default-image-processor/extractors.mjs +465 -0
- package/lib/document-processing/resources/default-image-processor/index.mjs +143 -0
- package/lib/document-processing/resources/default-image-processor/package-lock.json +12 -0
- package/lib/document-processing/resources/default-image-processor/package.json +4 -0
- package/lib/document-processing/resources/default-image-validator/index.mjs +76 -0
- package/lib/document-processing/resources/default-image-validator/package-lock.json +154 -0
- package/lib/document-processing/resources/default-image-validator/package.json +7 -0
- package/lib/document-processing/resources/default-pdf-processor/index.js +46 -0
- package/lib/document-processing/resources/default-pdf-validator/index.js +36 -0
- package/lib/document-processing/resources/default-sqs-consumer/index.py +111 -0
- package/lib/document-processing/resources/default-sqs-consumer/requirements.txt +4 -0
- package/lib/document-processing/resources/default-sqs-consumer/sample_payload.json +20 -0
- package/lib/document-processing/resources/default-sqs-consumer/sample_payload_multi.json +24 -0
- package/lib/document-processing/resources/default-strands-agent/index.py +111 -0
- package/lib/document-processing/resources/default-strands-agent/requirements.txt +6 -0
- package/lib/document-processing/tests/agentic-document-processing-nag.test.d.ts +1 -0
- package/lib/document-processing/tests/agentic-document-processing-nag.test.js +107 -0
- package/lib/document-processing/tests/agentic-document-processing.test.d.ts +1 -0
- package/lib/document-processing/tests/agentic-document-processing.test.js +125 -0
- package/lib/document-processing/tests/bedrock-document-processing-nag.test.d.ts +1 -0
- package/lib/document-processing/tests/bedrock-document-processing-nag.test.js +101 -0
- package/lib/document-processing/tests/bedrock-document-processing.test.d.ts +1 -0
- package/lib/document-processing/tests/bedrock-document-processing.test.js +79 -0
- package/lib/framework/custom-resource/default-runtimes.d.ts +21 -0
- package/lib/framework/custom-resource/default-runtimes.js +34 -0
- package/lib/framework/custom-resource/index.d.ts +1 -0
- package/lib/framework/custom-resource/index.js +18 -0
- package/lib/framework/foundation/access-log.d.ts +69 -0
- package/lib/framework/foundation/access-log.js +121 -0
- package/lib/framework/foundation/eventbridge-broker.d.ts +18 -0
- package/lib/framework/foundation/eventbridge-broker.js +42 -0
- package/lib/framework/foundation/index.d.ts +3 -0
- package/lib/framework/foundation/index.js +20 -0
- package/lib/framework/foundation/network.d.ts +19 -0
- package/lib/framework/foundation/network.js +83 -0
- package/lib/framework/index.d.ts +2 -0
- package/lib/framework/index.js +19 -0
- package/lib/framework/quickstart/base-quickstart.d.ts +30 -0
- package/lib/framework/quickstart/base-quickstart.js +30 -0
- package/lib/index.d.ts +4 -0
- package/lib/index.js +21 -0
- package/lib/tsconfig.tsbuildinfo +1 -0
- package/lib/utilities/cdk-nag-config.d.ts +42 -0
- package/lib/utilities/cdk-nag-config.js +194 -0
- package/lib/utilities/data-loader-lambda/index.py +282 -0
- package/lib/utilities/data-loader-lambda/requirements.txt +3 -0
- package/lib/utilities/data-loader.d.ts +173 -0
- package/lib/utilities/data-loader.js +447 -0
- package/lib/utilities/index.d.ts +3 -0
- package/lib/utilities/index.js +20 -0
- package/lib/utilities/lambda-iam-utils.d.ts +145 -0
- package/lib/utilities/lambda-iam-utils.js +235 -0
- package/lib/utilities/lambda_layers/data-masking/layer-construct.d.ts +42 -0
- package/lib/utilities/lambda_layers/data-masking/layer-construct.js +53 -0
- package/lib/utilities/lambda_layers/data-masking/layer-construct.ts +88 -0
- package/lib/utilities/observability/bedrock-observability.d.ts +18 -0
- package/lib/utilities/observability/bedrock-observability.js +131 -0
- package/lib/utilities/observability/cloudfront-distribution-observability-property-injector.d.ts +6 -0
- package/lib/utilities/observability/cloudfront-distribution-observability-property-injector.js +22 -0
- package/lib/utilities/observability/index.d.ts +6 -0
- package/lib/utilities/observability/index.js +25 -0
- package/lib/utilities/observability/lambda-observability-property-injector.d.ts +8 -0
- package/lib/utilities/observability/lambda-observability-property-injector.js +43 -0
- package/lib/utilities/observability/log-group-data-protection-props.d.ts +19 -0
- package/lib/utilities/observability/log-group-data-protection-props.js +5 -0
- package/lib/utilities/observability/observability.d.ts +83 -0
- package/lib/utilities/observability/observability.js +278 -0
- package/lib/utilities/observability/observable.d.ts +32 -0
- package/lib/utilities/observability/observable.js +3 -0
- package/lib/utilities/observability/powertools-config.d.ts +3 -0
- package/lib/utilities/observability/powertools-config.js +25 -0
- package/lib/utilities/observability/resources/bedrock-manage-logging-configuration/index.py +27 -0
- package/lib/utilities/observability/state-machine-observability-property-injector.d.ts +8 -0
- package/lib/utilities/observability/state-machine-observability-property-injector.js +49 -0
- package/lib/utilities/tests/data-loader-nag.test.d.ts +1 -0
- package/lib/utilities/tests/data-loader-nag.test.js +432 -0
- package/lib/utilities/tests/data-loader.test.d.ts +1 -0
- package/lib/utilities/tests/data-loader.test.js +284 -0
- package/lib/webapp/frontend-construct.d.ts +136 -0
- package/lib/webapp/frontend-construct.js +253 -0
- package/lib/webapp/index.d.ts +1 -0
- package/lib/webapp/index.js +18 -0
- package/lib/webapp/tests/frontend-construct-nag.test.d.ts +1 -0
- package/lib/webapp/tests/frontend-construct-nag.test.js +266 -0
- package/lib/webapp/tests/frontend-construct.test.d.ts +1 -0
- package/lib/webapp/tests/frontend-construct.test.js +385 -0
- package/package.json +183 -0
|
@@ -0,0 +1,125 @@
|
|
|
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 agentic_document_processing_1 = require("../agentic-document-processing");
|
|
6
|
+
describe('AgenticDocumentProcessing', () => {
|
|
7
|
+
let basicStack;
|
|
8
|
+
let crossRegionStack;
|
|
9
|
+
let defaultModelStack;
|
|
10
|
+
let basicTemplate;
|
|
11
|
+
let crossRegionTemplate;
|
|
12
|
+
let defaultModelTemplate;
|
|
13
|
+
beforeAll(() => {
|
|
14
|
+
// Create all stacks and constructs first
|
|
15
|
+
basicStack = new aws_cdk_lib_1.Stack();
|
|
16
|
+
new agentic_document_processing_1.AgenticDocumentProcessing(basicStack, 'BasicTest', {
|
|
17
|
+
processingPrompt: 'Custom processing prompt',
|
|
18
|
+
processingAgentParameters: {
|
|
19
|
+
agentSystemPrompt: 'Test system prompt',
|
|
20
|
+
toolsLocation: ['tool1', 'tool2'],
|
|
21
|
+
},
|
|
22
|
+
});
|
|
23
|
+
crossRegionStack = new aws_cdk_lib_1.Stack();
|
|
24
|
+
new agentic_document_processing_1.AgenticDocumentProcessing(crossRegionStack, 'CrossRegionTest', {
|
|
25
|
+
useCrossRegionInference: true,
|
|
26
|
+
});
|
|
27
|
+
defaultModelStack = new aws_cdk_lib_1.Stack();
|
|
28
|
+
new agentic_document_processing_1.AgenticDocumentProcessing(defaultModelStack, 'DefaultModelTest', {
|
|
29
|
+
useCrossRegionInference: false,
|
|
30
|
+
});
|
|
31
|
+
// Generate templates once after all constructs are created
|
|
32
|
+
basicTemplate = assertions_1.Template.fromStack(basicStack);
|
|
33
|
+
crossRegionTemplate = assertions_1.Template.fromStack(crossRegionStack);
|
|
34
|
+
defaultModelTemplate = assertions_1.Template.fromStack(defaultModelStack);
|
|
35
|
+
});
|
|
36
|
+
test('creates basic infrastructure', () => {
|
|
37
|
+
basicTemplate.hasResourceProperties('AWS::S3::Bucket', {});
|
|
38
|
+
basicTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
39
|
+
Runtime: 'python3.13',
|
|
40
|
+
});
|
|
41
|
+
basicTemplate.resourceCountIs('AWS::Lambda::Function', 5);
|
|
42
|
+
});
|
|
43
|
+
test('configures all agent parameters', () => {
|
|
44
|
+
basicTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
45
|
+
Environment: {
|
|
46
|
+
Variables: {
|
|
47
|
+
SYSTEM_PROMPT: 'Test system prompt',
|
|
48
|
+
TOOLS_CONFIG: '["tool1","tool2"]',
|
|
49
|
+
PROMPT: 'Custom processing prompt',
|
|
50
|
+
},
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
test('inherits bedrock document processing functionality', () => {
|
|
55
|
+
basicTemplate.hasResourceProperties('AWS::S3::Bucket', {});
|
|
56
|
+
basicTemplate.hasResourceProperties('AWS::DynamoDB::Table', {});
|
|
57
|
+
basicTemplate.hasResourceProperties('AWS::SQS::Queue', {});
|
|
58
|
+
basicTemplate.hasResourceProperties('AWS::StepFunctions::StateMachine', {});
|
|
59
|
+
});
|
|
60
|
+
test('creates IAM role with correct permissions', () => {
|
|
61
|
+
basicTemplate.hasResourceProperties('AWS::IAM::Role', {
|
|
62
|
+
AssumeRolePolicyDocument: {
|
|
63
|
+
Statement: [{
|
|
64
|
+
Action: 'sts:AssumeRole',
|
|
65
|
+
Effect: 'Allow',
|
|
66
|
+
Principal: {
|
|
67
|
+
Service: 'lambda.amazonaws.com',
|
|
68
|
+
},
|
|
69
|
+
}],
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
basicTemplate.hasResourceProperties('AWS::IAM::Role', {
|
|
73
|
+
Policies: [{
|
|
74
|
+
PolicyDocument: {
|
|
75
|
+
Statement: [
|
|
76
|
+
{
|
|
77
|
+
Effect: 'Allow',
|
|
78
|
+
Action: 's3:GetObject',
|
|
79
|
+
Resource: {
|
|
80
|
+
'Fn::Join': [
|
|
81
|
+
'',
|
|
82
|
+
[
|
|
83
|
+
{ 'Fn::GetAtt': [assertions_1.Match.anyValue(), 'Arn'] },
|
|
84
|
+
'/*',
|
|
85
|
+
],
|
|
86
|
+
],
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
{
|
|
90
|
+
Effect: 'Allow',
|
|
91
|
+
Action: ['bedrock:InvokeModel', 'bedrock:InvokeModelWithResponseStream'],
|
|
92
|
+
Resource: assertions_1.Match.anyValue(),
|
|
93
|
+
},
|
|
94
|
+
],
|
|
95
|
+
},
|
|
96
|
+
PolicyName: 'BedrockInvokePolicy',
|
|
97
|
+
}],
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
test('configures timeout and memory for processing function', () => {
|
|
101
|
+
basicTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
102
|
+
Timeout: 300,
|
|
103
|
+
MemorySize: 1024,
|
|
104
|
+
});
|
|
105
|
+
});
|
|
106
|
+
test('uses cross-region inference when enabled', () => {
|
|
107
|
+
crossRegionTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
108
|
+
Environment: {
|
|
109
|
+
Variables: {
|
|
110
|
+
MODEL_ID: 'us.anthropic.claude-3-7-sonnet-20250219-v1:0',
|
|
111
|
+
},
|
|
112
|
+
},
|
|
113
|
+
});
|
|
114
|
+
});
|
|
115
|
+
test('uses default model when cross-region inference is disabled', () => {
|
|
116
|
+
defaultModelTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
117
|
+
Environment: {
|
|
118
|
+
Variables: {
|
|
119
|
+
MODEL_ID: 'anthropic.claude-3-7-sonnet-20250219-v1:0',
|
|
120
|
+
},
|
|
121
|
+
},
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
});
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"agentic-document-processing.test.js","sourceRoot":"","sources":["../../../use-cases/document-processing/tests/agentic-document-processing.test.ts"],"names":[],"mappings":";;AAAA,6CAAoC;AACpC,uDAAyD;AACzD,gFAA2E;AAE3E,QAAQ,CAAC,2BAA2B,EAAE,GAAG,EAAE;IACzC,IAAI,UAAiB,CAAC;IACtB,IAAI,gBAAuB,CAAC;IAC5B,IAAI,iBAAwB,CAAC;IAC7B,IAAI,aAAuB,CAAC;IAC5B,IAAI,mBAA6B,CAAC;IAClC,IAAI,oBAA8B,CAAC;IAEnC,SAAS,CAAC,GAAG,EAAE;QACb,yCAAyC;QACzC,UAAU,GAAG,IAAI,mBAAK,EAAE,CAAC;QACzB,IAAI,uDAAyB,CAAC,UAAU,EAAE,WAAW,EAAE;YACrD,gBAAgB,EAAE,0BAA0B;YAC5C,yBAAyB,EAAE;gBACzB,iBAAiB,EAAE,oBAAoB;gBACvC,aAAa,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;aAClC;SACF,CAAC,CAAC;QAEH,gBAAgB,GAAG,IAAI,mBAAK,EAAE,CAAC;QAC/B,IAAI,uDAAyB,CAAC,gBAAgB,EAAE,iBAAiB,EAAE;YACjE,uBAAuB,EAAE,IAAI;SAC9B,CAAC,CAAC;QAEH,iBAAiB,GAAG,IAAI,mBAAK,EAAE,CAAC;QAChC,IAAI,uDAAyB,CAAC,iBAAiB,EAAE,kBAAkB,EAAE;YACnE,uBAAuB,EAAE,KAAK;SAC/B,CAAC,CAAC;QAEH,2DAA2D;QAC3D,aAAa,GAAG,qBAAQ,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;QAC/C,mBAAmB,GAAG,qBAAQ,CAAC,SAAS,CAAC,gBAAgB,CAAC,CAAC;QAC3D,oBAAoB,GAAG,qBAAQ,CAAC,SAAS,CAAC,iBAAiB,CAAC,CAAC;IAC/D,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,8BAA8B,EAAE,GAAG,EAAE;QACxC,aAAa,CAAC,qBAAqB,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAC3D,aAAa,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;YAC3D,OAAO,EAAE,YAAY;SACtB,CAAC,CAAC;QACH,aAAa,CAAC,eAAe,CAAC,uBAAuB,EAAE,CAAC,CAAC,CAAC;IAC5D,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,iCAAiC,EAAE,GAAG,EAAE;QAC3C,aAAa,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;YAC3D,WAAW,EAAE;gBACX,SAAS,EAAE;oBACT,aAAa,EAAE,oBAAoB;oBACnC,YAAY,EAAE,mBAAmB;oBACjC,MAAM,EAAE,0BAA0B;iBACnC;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;QAC9D,aAAa,CAAC,qBAAqB,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAC3D,aAAa,CAAC,qBAAqB,CAAC,sBAAsB,EAAE,EAAE,CAAC,CAAC;QAChE,aAAa,CAAC,qBAAqB,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;QAC3D,aAAa,CAAC,qBAAqB,CAAC,kCAAkC,EAAE,EAAE,CAAC,CAAC;IAC9E,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACrD,aAAa,CAAC,qBAAqB,CAAC,gBAAgB,EAAE;YACpD,wBAAwB,EAAE;gBACxB,SAAS,EAAE,CAAC;wBACV,MAAM,EAAE,gBAAgB;wBACxB,MAAM,EAAE,OAAO;wBACf,SAAS,EAAE;4BACT,OAAO,EAAE,sBAAsB;yBAChC;qBACF,CAAC;aACH;SACF,CAAC,CAAC;QAEH,aAAa,CAAC,qBAAqB,CAAC,gBAAgB,EAAE;YACpD,QAAQ,EAAE,CAAC;oBACT,cAAc,EAAE;wBACd,SAAS,EAAE;4BACT;gCACE,MAAM,EAAE,OAAO;gCACf,MAAM,EAAE,cAAc;gCACtB,QAAQ,EAAE;oCACR,UAAU,EAAE;wCACV,EAAE;wCACF;4CACE,EAAE,YAAY,EAAE,CAAC,kBAAK,CAAC,QAAQ,EAAE,EAAE,KAAK,CAAC,EAAE;4CAC3C,IAAI;yCACL;qCACF;iCACF;6BACF;4BACD;gCACE,MAAM,EAAE,OAAO;gCACf,MAAM,EAAE,CAAC,qBAAqB,EAAE,uCAAuC,CAAC;gCACxE,QAAQ,EAAE,kBAAK,CAAC,QAAQ,EAAE;6BAC3B;yBACF;qBACF;oBACD,UAAU,EAAE,qBAAqB;iBAClC,CAAC;SACH,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,uDAAuD,EAAE,GAAG,EAAE;QACjE,aAAa,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;YAC3D,OAAO,EAAE,GAAG;YACZ,UAAU,EAAE,IAAI;SACjB,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,0CAA0C,EAAE,GAAG,EAAE;QACpD,mBAAmB,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;YACjE,WAAW,EAAE;gBACX,SAAS,EAAE;oBACT,QAAQ,EAAE,8CAA8C;iBACzD;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,IAAI,CAAC,4DAA4D,EAAE,GAAG,EAAE;QACtE,oBAAoB,CAAC,qBAAqB,CAAC,uBAAuB,EAAE;YAClE,WAAW,EAAE;gBACX,SAAS,EAAE;oBACT,QAAQ,EAAE,2CAA2C;iBACtD;aACF;SACF,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC","sourcesContent":["import { Stack } from 'aws-cdk-lib';\nimport { Template, Match } from 'aws-cdk-lib/assertions';\nimport { AgenticDocumentProcessing } from '../agentic-document-processing';\n\ndescribe('AgenticDocumentProcessing', () => {\n  let basicStack: Stack;\n  let crossRegionStack: Stack;\n  let defaultModelStack: Stack;\n  let basicTemplate: Template;\n  let crossRegionTemplate: Template;\n  let defaultModelTemplate: Template;\n\n  beforeAll(() => {\n    // Create all stacks and constructs first\n    basicStack = new Stack();\n    new AgenticDocumentProcessing(basicStack, 'BasicTest', {\n      processingPrompt: 'Custom processing prompt',\n      processingAgentParameters: {\n        agentSystemPrompt: 'Test system prompt',\n        toolsLocation: ['tool1', 'tool2'],\n      },\n    });\n\n    crossRegionStack = new Stack();\n    new AgenticDocumentProcessing(crossRegionStack, 'CrossRegionTest', {\n      useCrossRegionInference: true,\n    });\n\n    defaultModelStack = new Stack();\n    new AgenticDocumentProcessing(defaultModelStack, 'DefaultModelTest', {\n      useCrossRegionInference: false,\n    });\n\n    // Generate templates once after all constructs are created\n    basicTemplate = Template.fromStack(basicStack);\n    crossRegionTemplate = Template.fromStack(crossRegionStack);\n    defaultModelTemplate = Template.fromStack(defaultModelStack);\n  });\n\n  test('creates basic infrastructure', () => {\n    basicTemplate.hasResourceProperties('AWS::S3::Bucket', {});\n    basicTemplate.hasResourceProperties('AWS::Lambda::Function', {\n      Runtime: 'python3.13',\n    });\n    basicTemplate.resourceCountIs('AWS::Lambda::Function', 5);\n  });\n\n  test('configures all agent parameters', () => {\n    basicTemplate.hasResourceProperties('AWS::Lambda::Function', {\n      Environment: {\n        Variables: {\n          SYSTEM_PROMPT: 'Test system prompt',\n          TOOLS_CONFIG: '[\"tool1\",\"tool2\"]',\n          PROMPT: 'Custom processing prompt',\n        },\n      },\n    });\n  });\n\n  test('inherits bedrock document processing functionality', () => {\n    basicTemplate.hasResourceProperties('AWS::S3::Bucket', {});\n    basicTemplate.hasResourceProperties('AWS::DynamoDB::Table', {});\n    basicTemplate.hasResourceProperties('AWS::SQS::Queue', {});\n    basicTemplate.hasResourceProperties('AWS::StepFunctions::StateMachine', {});\n  });\n\n  test('creates IAM role with correct permissions', () => {\n    basicTemplate.hasResourceProperties('AWS::IAM::Role', {\n      AssumeRolePolicyDocument: {\n        Statement: [{\n          Action: 'sts:AssumeRole',\n          Effect: 'Allow',\n          Principal: {\n            Service: 'lambda.amazonaws.com',\n          },\n        }],\n      },\n    });\n\n    basicTemplate.hasResourceProperties('AWS::IAM::Role', {\n      Policies: [{\n        PolicyDocument: {\n          Statement: [\n            {\n              Effect: 'Allow',\n              Action: 's3:GetObject',\n              Resource: {\n                'Fn::Join': [\n                  '',\n                  [\n                    { 'Fn::GetAtt': [Match.anyValue(), 'Arn'] },\n                    '/*',\n                  ],\n                ],\n              },\n            },\n            {\n              Effect: 'Allow',\n              Action: ['bedrock:InvokeModel', 'bedrock:InvokeModelWithResponseStream'],\n              Resource: Match.anyValue(),\n            },\n          ],\n        },\n        PolicyName: 'BedrockInvokePolicy',\n      }],\n    });\n  });\n\n  test('configures timeout and memory for processing function', () => {\n    basicTemplate.hasResourceProperties('AWS::Lambda::Function', {\n      Timeout: 300,\n      MemorySize: 1024,\n    });\n  });\n\n  test('uses cross-region inference when enabled', () => {\n    crossRegionTemplate.hasResourceProperties('AWS::Lambda::Function', {\n      Environment: {\n        Variables: {\n          MODEL_ID: 'us.anthropic.claude-3-7-sonnet-20250219-v1:0',\n        },\n      },\n    });\n  });\n\n  test('uses default model when cross-region inference is disabled', () => {\n    defaultModelTemplate.hasResourceProperties('AWS::Lambda::Function', {\n      Environment: {\n        Variables: {\n          MODEL_ID: 'anthropic.claude-3-7-sonnet-20250219-v1:0',\n        },\n      },\n    });\n  });\n});\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,101 @@
|
|
|
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 bedrock_document_processing_1 = require("../bedrock-document-processing");
|
|
10
|
+
// Create app and stack
|
|
11
|
+
const app = new aws_cdk_lib_1.App();
|
|
12
|
+
const stack = new aws_cdk_lib_1.Stack(app, 'TestStack', {
|
|
13
|
+
env: {
|
|
14
|
+
account: '123456789012',
|
|
15
|
+
region: 'us-east-1',
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
// Create EventBridge broker
|
|
19
|
+
const broker = new eventbridge_broker_1.EventbridgeBroker(stack, 'IDPBroker', {
|
|
20
|
+
name: 'idp-broker',
|
|
21
|
+
eventSource: 'intelligent-document-processing',
|
|
22
|
+
});
|
|
23
|
+
const accessLog = new framework_1.AccessLog(stack, 'AccessLog');
|
|
24
|
+
// Create S3 bucket for agentic tools
|
|
25
|
+
const bucket = new aws_s3_1.Bucket(stack, 'BedrockDocumentProcessingBucket', {
|
|
26
|
+
serverAccessLogsBucket: accessLog.bucket,
|
|
27
|
+
serverAccessLogsPrefix: accessLog.bucketPrefix,
|
|
28
|
+
enforceSSL: true,
|
|
29
|
+
});
|
|
30
|
+
// Create the main BedrockDocumentProcessing construct
|
|
31
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {
|
|
32
|
+
bucket,
|
|
33
|
+
useCrossRegionInference: true,
|
|
34
|
+
eventbridgeBroker: broker,
|
|
35
|
+
enableObservability: true,
|
|
36
|
+
});
|
|
37
|
+
// Suppress CDK-managed BucketNotificationsHandler AWS managed policy
|
|
38
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(stack, '/TestStack/BucketNotificationsHandler050a0587b7544547bf325f094a3db834/Role', [
|
|
39
|
+
{
|
|
40
|
+
id: 'AwsSolutions-IAM4',
|
|
41
|
+
reason: 'CDK-managed BucketNotificationsHandler requires AWSLambdaBasicExecutionRole for S3 event processing',
|
|
42
|
+
appliesTo: ['Policy::arn:<AWS::Partition>:iam::aws:policy/service-role/AWSLambdaBasicExecutionRole'],
|
|
43
|
+
},
|
|
44
|
+
]);
|
|
45
|
+
// Suppress S3 bucket wildcard permissions for Lambda roles
|
|
46
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
47
|
+
{
|
|
48
|
+
id: 'AwsSolutions-IAM5',
|
|
49
|
+
reason: 'Lambda functions require wildcard access to S3 bucket objects for document processing',
|
|
50
|
+
appliesTo: ['Resource::<BedrockDocumentProcessingBucketA06CA1E2.Arn>/*'],
|
|
51
|
+
},
|
|
52
|
+
], true);
|
|
53
|
+
// Suppress Bedrock foundation model wildcard permissions
|
|
54
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
55
|
+
{
|
|
56
|
+
id: 'AwsSolutions-IAM5',
|
|
57
|
+
reason: 'Cross-region inference requires wildcard region access to Bedrock foundation models',
|
|
58
|
+
appliesTo: ['Resource::arn:aws:bedrock:*::foundation-model/anthropic.claude-3-7-sonnet-20250219-v1:0'],
|
|
59
|
+
},
|
|
60
|
+
], true);
|
|
61
|
+
// Suppress SQSConsumerRole wildcard permissions for Lambda log streams
|
|
62
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
63
|
+
{
|
|
64
|
+
id: 'AwsSolutions-IAM5',
|
|
65
|
+
reason: 'Lambda log stream ARN is only known at runtime, wildcard required for CloudWatch Logs access',
|
|
66
|
+
},
|
|
67
|
+
], true);
|
|
68
|
+
// Suppress StateMachineRole wildcard permissions for Lambda invocation
|
|
69
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressionsByPath(stack, '/TestStack/BedrockDocumentProcessing/StateMachineRole/DefaultPolicy', [
|
|
70
|
+
{
|
|
71
|
+
id: 'AwsSolutions-IAM5',
|
|
72
|
+
reason: 'Step Functions requires wildcard permissions to invoke Lambda functions with version-specific ARNs',
|
|
73
|
+
},
|
|
74
|
+
]);
|
|
75
|
+
// Suppress Lambda log group wildcard permissions
|
|
76
|
+
cdk_nag_1.NagSuppressions.addResourceSuppressions(stack, [
|
|
77
|
+
{
|
|
78
|
+
id: 'AwsSolutions-IAM5',
|
|
79
|
+
reason: 'Lambda log stream names are generated at runtime, wildcard required for CloudWatch Logs access',
|
|
80
|
+
},
|
|
81
|
+
], true);
|
|
82
|
+
// Apply CDK Nag checks
|
|
83
|
+
aws_cdk_lib_1.Aspects.of(app).add(new cdk_nag_1.AwsSolutionsChecks({ verbose: true }));
|
|
84
|
+
// Synthesize the stack and check for unsuppressed warnings and errors
|
|
85
|
+
const warnings = assertions_1.Annotations.fromStack(stack).findWarning('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
86
|
+
const errors = assertions_1.Annotations.fromStack(stack).findError('*', assertions_1.Match.stringLikeRegexp('AwsSolutions-.*'));
|
|
87
|
+
// Test: No unsuppressed warnings
|
|
88
|
+
test('No unsuppressed warnings', () => {
|
|
89
|
+
if (warnings.length > 0) {
|
|
90
|
+
console.log('CDK Nag Warnings:', JSON.stringify(warnings, null, 2));
|
|
91
|
+
}
|
|
92
|
+
expect(warnings).toHaveLength(0);
|
|
93
|
+
});
|
|
94
|
+
// Test: No unsuppressed errors
|
|
95
|
+
test('No unsuppressed errors', () => {
|
|
96
|
+
if (errors.length > 0) {
|
|
97
|
+
console.log('CDK Nag Errors:', JSON.stringify(errors, null, 2));
|
|
98
|
+
}
|
|
99
|
+
expect(errors).toHaveLength(0);
|
|
100
|
+
});
|
|
101
|
+
//# 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 { 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\n// Create the main BedrockDocumentProcessing construct\nnew BedrockDocumentProcessing(stack, 'BedrockDocumentProcessing', {\n  bucket,\n  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 {};
|
|
@@ -0,0 +1,79 @@
|
|
|
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_bedrock_1 = require("aws-cdk-lib/aws-bedrock");
|
|
6
|
+
const bedrock_document_processing_1 = require("../bedrock-document-processing");
|
|
7
|
+
describe('BedrockDocumentProcessing', () => {
|
|
8
|
+
let defaultStack;
|
|
9
|
+
let customStack;
|
|
10
|
+
let crossRegionStack;
|
|
11
|
+
let defaultTemplate;
|
|
12
|
+
let customTemplate;
|
|
13
|
+
let crossRegionTemplate;
|
|
14
|
+
beforeAll(() => {
|
|
15
|
+
// Create all stacks and constructs first
|
|
16
|
+
defaultStack = new aws_cdk_lib_1.Stack();
|
|
17
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(defaultStack, 'DefaultTest', {});
|
|
18
|
+
customStack = new aws_cdk_lib_1.Stack();
|
|
19
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(customStack, 'CustomTest', {
|
|
20
|
+
classificationModelId: aws_bedrock_1.FoundationModelIdentifier.ANTHROPIC_CLAUDE_3_HAIKU_20240307_V1_0,
|
|
21
|
+
useCrossRegionInference: false,
|
|
22
|
+
});
|
|
23
|
+
crossRegionStack = new aws_cdk_lib_1.Stack();
|
|
24
|
+
new bedrock_document_processing_1.BedrockDocumentProcessing(crossRegionStack, 'CrossRegionTest', {
|
|
25
|
+
useCrossRegionInference: true,
|
|
26
|
+
crossRegionInferencePrefix: bedrock_document_processing_1.BedrockCrossRegionInferencePrefix.EU,
|
|
27
|
+
});
|
|
28
|
+
// Generate templates once after all constructs are created
|
|
29
|
+
defaultTemplate = assertions_1.Template.fromStack(defaultStack);
|
|
30
|
+
customTemplate = assertions_1.Template.fromStack(customStack);
|
|
31
|
+
crossRegionTemplate = assertions_1.Template.fromStack(crossRegionStack);
|
|
32
|
+
});
|
|
33
|
+
test('creates basic infrastructure', () => {
|
|
34
|
+
defaultTemplate.hasResourceProperties('AWS::S3::Bucket', {});
|
|
35
|
+
defaultTemplate.hasResourceProperties('AWS::SQS::Queue', {});
|
|
36
|
+
defaultTemplate.hasResourceProperties('AWS::DynamoDB::Table', { BillingMode: 'PAY_PER_REQUEST' });
|
|
37
|
+
defaultTemplate.hasResourceProperties('AWS::StepFunctions::StateMachine', {});
|
|
38
|
+
defaultTemplate.resourceCountIs('AWS::Lambda::Function', 5);
|
|
39
|
+
});
|
|
40
|
+
test('uses default model with cross-region prefix disabled', () => {
|
|
41
|
+
defaultTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
42
|
+
Environment: {
|
|
43
|
+
Variables: {
|
|
44
|
+
MODEL_ID: 'anthropic.claude-3-7-sonnet-20250219-v1:0',
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
});
|
|
48
|
+
});
|
|
49
|
+
test('uses custom model without cross-region prefix', () => {
|
|
50
|
+
customTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
51
|
+
Environment: {
|
|
52
|
+
Variables: {
|
|
53
|
+
MODEL_ID: 'anthropic.claude-3-haiku-20240307-v1:0',
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
});
|
|
57
|
+
});
|
|
58
|
+
test('configures custom cross-region prefix', () => {
|
|
59
|
+
crossRegionTemplate.hasResourceProperties('AWS::Lambda::Function', {
|
|
60
|
+
Environment: {
|
|
61
|
+
Variables: {
|
|
62
|
+
MODEL_ID: 'eu.anthropic.claude-3-7-sonnet-20250219-v1:0',
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
});
|
|
66
|
+
});
|
|
67
|
+
test('creates bedrock permissions', () => {
|
|
68
|
+
defaultTemplate.hasResourceProperties('AWS::IAM::Role', {
|
|
69
|
+
AssumeRolePolicyDocument: {
|
|
70
|
+
Statement: [{
|
|
71
|
+
Action: 'sts:AssumeRole',
|
|
72
|
+
Effect: 'Allow',
|
|
73
|
+
Principal: { Service: 'lambda.amazonaws.com' },
|
|
74
|
+
}],
|
|
75
|
+
},
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
});
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmVkcm9jay1kb2N1bWVudC1wcm9jZXNzaW5nLnRlc3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi91c2UtY2FzZXMvZG9jdW1lbnQtcHJvY2Vzc2luZy90ZXN0cy9iZWRyb2NrLWRvY3VtZW50LXByb2Nlc3NpbmcudGVzdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLDZDQUFvQztBQUNwQyx1REFBa0Q7QUFDbEQseURBQW9FO0FBQ3BFLGdGQUE4RztBQUU5RyxRQUFRLENBQUMsMkJBQTJCLEVBQUUsR0FBRyxFQUFFO0lBQ3pDLElBQUksWUFBbUIsQ0FBQztJQUN4QixJQUFJLFdBQWtCLENBQUM7SUFDdkIsSUFBSSxnQkFBdUIsQ0FBQztJQUM1QixJQUFJLGVBQXlCLENBQUM7SUFDOUIsSUFBSSxjQUF3QixDQUFDO0lBQzdCLElBQUksbUJBQTZCLENBQUM7SUFFbEMsU0FBUyxDQUFDLEdBQUcsRUFBRTtRQUNiLHlDQUF5QztRQUN6QyxZQUFZLEdBQUcsSUFBSSxtQkFBSyxFQUFFLENBQUM7UUFDM0IsSUFBSSx1REFBeUIsQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRS9ELFdBQVcsR0FBRyxJQUFJLG1CQUFLLEVBQUUsQ0FBQztRQUMxQixJQUFJLHVEQUF5QixDQUFDLFdBQVcsRUFBRSxZQUFZLEVBQUU7WUFDdkQscUJBQXFCLEVBQUUsdUNBQXlCLENBQUMsc0NBQXNDO1lBQ3ZGLHVCQUF1QixFQUFFLEtBQUs7U0FDL0IsQ0FBQyxDQUFDO1FBRUgsZ0JBQWdCLEdBQUcsSUFBSSxtQkFBSyxFQUFFLENBQUM7UUFDL0IsSUFBSSx1REFBeUIsQ0FBQyxnQkFBZ0IsRUFBRSxpQkFBaUIsRUFBRTtZQUNqRSx1QkFBdUIsRUFBRSxJQUFJO1lBQzdCLDBCQUEwQixFQUFFLCtEQUFpQyxDQUFDLEVBQUU7U0FDakUsQ0FBQyxDQUFDO1FBRUgsMkRBQTJEO1FBQzNELGVBQWUsR0FBRyxxQkFBUSxDQUFDLFNBQVMsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUNuRCxjQUFjLEdBQUcscUJBQVEsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLENBQUM7UUFDakQsbUJBQW1CLEdBQUcscUJBQVEsQ0FBQyxTQUFTLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUM3RCxDQUFDLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQyw4QkFBOEIsRUFBRSxHQUFHLEVBQUU7UUFDeEMsZUFBZSxDQUFDLHFCQUFxQixDQUFDLGlCQUFpQixFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBQzdELGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxpQkFBaUIsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM3RCxlQUFlLENBQUMscUJBQXFCLENBQUMsc0JBQXNCLEVBQUUsRUFBRSxXQUFXLEVBQUUsaUJBQWlCLEVBQUUsQ0FBQyxDQUFDO1FBQ2xHLGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxrQ0FBa0MsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUM5RSxlQUFlLENBQUMsZUFBZSxDQUFDLHVCQUF1QixFQUFFLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUMsQ0FBQyxDQUFDO0lBRUgsSUFBSSxDQUFDLHNEQUFzRCxFQUFFLEdBQUcsRUFBRTtRQUNoRSxlQUFlLENBQUMscUJBQXFCLENBQUMsdUJBQXVCLEVBQUU7WUFDN0QsV0FBVyxFQUFFO2dCQUNYLFNBQVMsRUFBRTtvQkFDVCxRQUFRLEVBQUUsMkNBQTJDO2lCQUN0RDthQUNGO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFJLENBQUMsK0NBQStDLEVBQUUsR0FBRyxFQUFFO1FBQ3pELGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyx1QkFBdUIsRUFBRTtZQUM1RCxXQUFXLEVBQUU7Z0JBQ1gsU0FBUyxFQUFFO29CQUNULFFBQVEsRUFBRSx3Q0FBd0M7aUJBQ25EO2FBQ0Y7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztJQUVILElBQUksQ0FBQyx1Q0FBdUMsRUFBRSxHQUFHLEVBQUU7UUFDakQsbUJBQW1CLENBQUMscUJBQXFCLENBQUMsdUJBQXVCLEVBQUU7WUFDakUsV0FBVyxFQUFFO2dCQUNYLFNBQVMsRUFBRTtvQkFDVCxRQUFRLEVBQUUsOENBQThDO2lCQUN6RDthQUNGO1NBQ0YsQ0FBQyxDQUFDO0lBQ0wsQ0FBQyxDQUFDLENBQUM7SUFFSCxJQUFJLENBQUMsNkJBQTZCLEVBQUUsR0FBRyxFQUFFO1FBQ3ZDLGVBQWUsQ0FBQyxxQkFBcUIsQ0FBQyxnQkFBZ0IsRUFBRTtZQUN0RCx3QkFBd0IsRUFBRTtnQkFDeEIsU0FBUyxFQUFFLENBQUM7d0JBQ1YsTUFBTSxFQUFFLGdCQUFnQjt3QkFDeEIsTUFBTSxFQUFFLE9BQU87d0JBQ2YsU0FBUyxFQUFFLEVBQUUsT0FBTyxFQUFFLHNCQUFzQixFQUFFO3FCQUMvQyxDQUFDO2FBQ0g7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgU3RhY2sgfSBmcm9tICdhd3MtY2RrLWxpYic7XG5pbXBvcnQgeyBUZW1wbGF0ZSB9IGZyb20gJ2F3cy1jZGstbGliL2Fzc2VydGlvbnMnO1xuaW1wb3J0IHsgRm91bmRhdGlvbk1vZGVsSWRlbnRpZmllciB9IGZyb20gJ2F3cy1jZGstbGliL2F3cy1iZWRyb2NrJztcbmltcG9ydCB7IEJlZHJvY2tDcm9zc1JlZ2lvbkluZmVyZW5jZVByZWZpeCwgQmVkcm9ja0RvY3VtZW50UHJvY2Vzc2luZyB9IGZyb20gJy4uL2JlZHJvY2stZG9jdW1lbnQtcHJvY2Vzc2luZyc7XG5cbmRlc2NyaWJlKCdCZWRyb2NrRG9jdW1lbnRQcm9jZXNzaW5nJywgKCkgPT4ge1xuICBsZXQgZGVmYXVsdFN0YWNrOiBTdGFjaztcbiAgbGV0IGN1c3RvbVN0YWNrOiBTdGFjaztcbiAgbGV0IGNyb3NzUmVnaW9uU3RhY2s6IFN0YWNrO1xuICBsZXQgZGVmYXVsdFRlbXBsYXRlOiBUZW1wbGF0ZTtcbiAgbGV0IGN1c3RvbVRlbXBsYXRlOiBUZW1wbGF0ZTtcbiAgbGV0IGNyb3NzUmVnaW9uVGVtcGxhdGU6IFRlbXBsYXRlO1xuXG4gIGJlZm9yZUFsbCgoKSA9PiB7XG4gICAgLy8gQ3JlYXRlIGFsbCBzdGFja3MgYW5kIGNvbnN0cnVjdHMgZmlyc3RcbiAgICBkZWZhdWx0U3RhY2sgPSBuZXcgU3RhY2soKTtcbiAgICBuZXcgQmVkcm9ja0RvY3VtZW50UHJvY2Vzc2luZyhkZWZhdWx0U3RhY2ssICdEZWZhdWx0VGVzdCcsIHt9KTtcblxuICAgIGN1c3RvbVN0YWNrID0gbmV3IFN0YWNrKCk7XG4gICAgbmV3IEJlZHJvY2tEb2N1bWVudFByb2Nlc3NpbmcoY3VzdG9tU3RhY2ssICdDdXN0b21UZXN0Jywge1xuICAgICAgY2xhc3NpZmljYXRpb25Nb2RlbElkOiBGb3VuZGF0aW9uTW9kZWxJZGVudGlmaWVyLkFOVEhST1BJQ19DTEFVREVfM19IQUlLVV8yMDI0MDMwN19WMV8wLFxuICAgICAgdXNlQ3Jvc3NSZWdpb25JbmZlcmVuY2U6IGZhbHNlLFxuICAgIH0pO1xuXG4gICAgY3Jvc3NSZWdpb25TdGFjayA9IG5ldyBTdGFjaygpO1xuICAgIG5ldyBCZWRyb2NrRG9jdW1lbnRQcm9jZXNzaW5nKGNyb3NzUmVnaW9uU3RhY2ssICdDcm9zc1JlZ2lvblRlc3QnLCB7XG4gICAgICB1c2VDcm9zc1JlZ2lvbkluZmVyZW5jZTogdHJ1ZSxcbiAgICAgIGNyb3NzUmVnaW9uSW5mZXJlbmNlUHJlZml4OiBCZWRyb2NrQ3Jvc3NSZWdpb25JbmZlcmVuY2VQcmVmaXguRVUsXG4gICAgfSk7XG5cbiAgICAvLyBHZW5lcmF0ZSB0ZW1wbGF0ZXMgb25jZSBhZnRlciBhbGwgY29uc3RydWN0cyBhcmUgY3JlYXRlZFxuICAgIGRlZmF1bHRUZW1wbGF0ZSA9IFRlbXBsYXRlLmZyb21TdGFjayhkZWZhdWx0U3RhY2spO1xuICAgIGN1c3RvbVRlbXBsYXRlID0gVGVtcGxhdGUuZnJvbVN0YWNrKGN1c3RvbVN0YWNrKTtcbiAgICBjcm9zc1JlZ2lvblRlbXBsYXRlID0gVGVtcGxhdGUuZnJvbVN0YWNrKGNyb3NzUmVnaW9uU3RhY2spO1xuICB9KTtcblxuICB0ZXN0KCdjcmVhdGVzIGJhc2ljIGluZnJhc3RydWN0dXJlJywgKCkgPT4ge1xuICAgIGRlZmF1bHRUZW1wbGF0ZS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6UzM6OkJ1Y2tldCcsIHt9KTtcbiAgICBkZWZhdWx0VGVtcGxhdGUuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OlNRUzo6UXVldWUnLCB7fSk7XG4gICAgZGVmYXVsdFRlbXBsYXRlLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpEeW5hbW9EQjo6VGFibGUnLCB7IEJpbGxpbmdNb2RlOiAnUEFZX1BFUl9SRVFVRVNUJyB9KTtcbiAgICBkZWZhdWx0VGVtcGxhdGUuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OlN0ZXBGdW5jdGlvbnM6OlN0YXRlTWFjaGluZScsIHt9KTtcbiAgICBkZWZhdWx0VGVtcGxhdGUucmVzb3VyY2VDb3VudElzKCdBV1M6OkxhbWJkYTo6RnVuY3Rpb24nLCA1KTtcbiAgfSk7XG5cbiAgdGVzdCgndXNlcyBkZWZhdWx0IG1vZGVsIHdpdGggY3Jvc3MtcmVnaW9uIHByZWZpeCBkaXNhYmxlZCcsICgpID0+IHtcbiAgICBkZWZhdWx0VGVtcGxhdGUuaGFzUmVzb3VyY2VQcm9wZXJ0aWVzKCdBV1M6OkxhbWJkYTo6RnVuY3Rpb24nLCB7XG4gICAgICBFbnZpcm9ubWVudDoge1xuICAgICAgICBWYXJpYWJsZXM6IHtcbiAgICAgICAgICBNT0RFTF9JRDogJ2FudGhyb3BpYy5jbGF1ZGUtMy03LXNvbm5ldC0yMDI1MDIxOS12MTowJyxcbiAgICAgICAgfSxcbiAgICAgIH0sXG4gICAgfSk7XG4gIH0pO1xuXG4gIHRlc3QoJ3VzZXMgY3VzdG9tIG1vZGVsIHdpdGhvdXQgY3Jvc3MtcmVnaW9uIHByZWZpeCcsICgpID0+IHtcbiAgICBjdXN0b21UZW1wbGF0ZS5oYXNSZXNvdXJjZVByb3BlcnRpZXMoJ0FXUzo6TGFtYmRhOjpGdW5jdGlvbicsIHtcbiAgICAgIEVudmlyb25tZW50OiB7XG4gICAgICAgIFZhcmlhYmxlczoge1xuICAgICAgICAgIE1PREVMX0lEOiAnYW50aHJvcGljLmNsYXVkZS0zLWhhaWt1LTIwMjQwMzA3LXYxOjAnLFxuICAgICAgICB9LFxuICAgICAgfSxcbiAgICB9KTtcbiAgfSk7XG5cbiAgdGVzdCgnY29uZmlndXJlcyBjdXN0b20gY3Jvc3MtcmVnaW9uIHByZWZpeCcsICgpID0+IHtcbiAgICBjcm9zc1JlZ2lvblRlbXBsYXRlLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpMYW1iZGE6OkZ1bmN0aW9uJywge1xuICAgICAgRW52aXJvbm1lbnQ6IHtcbiAgICAgICAgVmFyaWFibGVzOiB7XG4gICAgICAgICAgTU9ERUxfSUQ6ICdldS5hbnRocm9waWMuY2xhdWRlLTMtNy1zb25uZXQtMjAyNTAyMTktdjE6MCcsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9KTtcblxuICB0ZXN0KCdjcmVhdGVzIGJlZHJvY2sgcGVybWlzc2lvbnMnLCAoKSA9PiB7XG4gICAgZGVmYXVsdFRlbXBsYXRlLmhhc1Jlc291cmNlUHJvcGVydGllcygnQVdTOjpJQU06OlJvbGUnLCB7XG4gICAgICBBc3N1bWVSb2xlUG9saWN5RG9jdW1lbnQ6IHtcbiAgICAgICAgU3RhdGVtZW50OiBbe1xuICAgICAgICAgIEFjdGlvbjogJ3N0czpBc3N1bWVSb2xlJyxcbiAgICAgICAgICBFZmZlY3Q6ICdBbGxvdycsXG4gICAgICAgICAgUHJpbmNpcGFsOiB7IFNlcnZpY2U6ICdsYW1iZGEuYW1hem9uYXdzLmNvbScgfSxcbiAgICAgICAgfV0sXG4gICAgICB9LFxuICAgIH0pO1xuICB9KTtcbn0pO1xuIl19
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { BundlingOptions } from '@aws-cdk/aws-lambda-python-alpha';
|
|
2
|
+
import { Runtime } from 'aws-cdk-lib/aws-lambda';
|
|
3
|
+
/**
|
|
4
|
+
* Contains default runtimes that would be referenced
|
|
5
|
+
* by Lambda functions in the various use cases. Updating of
|
|
6
|
+
* Runtime versions should be done here.
|
|
7
|
+
*/
|
|
8
|
+
export declare class DefaultRuntimes {
|
|
9
|
+
/**
|
|
10
|
+
* Default runtime for all Lambda functions in the use cases.
|
|
11
|
+
*/
|
|
12
|
+
static readonly NODEJS: Runtime;
|
|
13
|
+
/**
|
|
14
|
+
* Default runtime for Python based Lambda functions.
|
|
15
|
+
*/
|
|
16
|
+
static readonly PYTHON: Runtime;
|
|
17
|
+
/**
|
|
18
|
+
* Default bundling arguments for Python function
|
|
19
|
+
*/
|
|
20
|
+
static readonly PYTHON_FUNCTION_BUNDLING: BundlingOptions;
|
|
21
|
+
}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a, _b;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.DefaultRuntimes = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
const aws_lambda_1 = require("aws-cdk-lib/aws-lambda");
|
|
7
|
+
/**
|
|
8
|
+
* Contains default runtimes that would be referenced
|
|
9
|
+
* by Lambda functions in the various use cases. Updating of
|
|
10
|
+
* Runtime versions should be done here.
|
|
11
|
+
*/
|
|
12
|
+
class DefaultRuntimes {
|
|
13
|
+
}
|
|
14
|
+
exports.DefaultRuntimes = DefaultRuntimes;
|
|
15
|
+
_a = DefaultRuntimes, _b = JSII_RTTI_SYMBOL_1;
|
|
16
|
+
DefaultRuntimes[_b] = { fqn: "@cdklabs/cdk-appmod-catalog-blueprints.DefaultRuntimes", version: "1.0.0" };
|
|
17
|
+
/**
|
|
18
|
+
* Default runtime for all Lambda functions in the use cases.
|
|
19
|
+
*/
|
|
20
|
+
DefaultRuntimes.NODEJS = aws_lambda_1.Runtime.NODEJS_22_X;
|
|
21
|
+
/**
|
|
22
|
+
* Default runtime for Python based Lambda functions.
|
|
23
|
+
*/
|
|
24
|
+
DefaultRuntimes.PYTHON = aws_lambda_1.Runtime.PYTHON_3_13;
|
|
25
|
+
/**
|
|
26
|
+
* Default bundling arguments for Python function
|
|
27
|
+
*/
|
|
28
|
+
DefaultRuntimes.PYTHON_FUNCTION_BUNDLING = {
|
|
29
|
+
buildArgs: {
|
|
30
|
+
'--platform': 'linux/amd64',
|
|
31
|
+
},
|
|
32
|
+
image: _a.PYTHON.bundlingImage,
|
|
33
|
+
};
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdC1ydW50aW1lcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3VzZS1jYXNlcy9mcmFtZXdvcmsvY3VzdG9tLXJlc291cmNlL2RlZmF1bHQtcnVudGltZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFHQSx1REFBaUQ7QUFFakQ7Ozs7R0FJRztBQUNILE1BQWEsZUFBZTs7QUFBNUIsMENBcUJDOzs7QUFuQkM7O0tBRUs7QUFDa0Isc0JBQU0sR0FBRyxvQkFBTyxDQUFDLFdBQVcsQUFBdEIsQ0FBdUI7QUFFcEQ7O0dBRUc7QUFDb0Isc0JBQU0sR0FBRyxvQkFBTyxDQUFDLFdBQVcsQUFBdEIsQ0FBdUI7QUFFcEQ7O0dBRUc7QUFDb0Isd0NBQXdCLEdBQW9CO0lBQ2pFLFNBQVMsRUFBRTtRQUNULFlBQVksRUFBRSxhQUFhO0tBQzVCO0lBQ0QsS0FBSyxFQUFFLEVBQUksQ0FBQyxNQUFNLENBQUMsYUFBYTtDQUNqQyxBQUw4QyxDQUs3QyIsInNvdXJjZXNDb250ZW50IjpbIi8vIENvcHlyaWdodCBBbWF6b24uY29tLCBJbmMuIG9yIGl0cyBhZmZpbGlhdGVzLiBBbGwgUmlnaHRzIFJlc2VydmVkLlxuLy8gU1BEWC1MaWNlbnNlLUlkZW50aWZpZXI6IEFwYWNoZS0yLjBcbmltcG9ydCB7IEJ1bmRsaW5nT3B0aW9ucyB9IGZyb20gJ0Bhd3MtY2RrL2F3cy1sYW1iZGEtcHl0aG9uLWFscGhhJztcbmltcG9ydCB7IFJ1bnRpbWUgfSBmcm9tICdhd3MtY2RrLWxpYi9hd3MtbGFtYmRhJztcblxuLyoqXG4gKiBDb250YWlucyBkZWZhdWx0IHJ1bnRpbWVzIHRoYXQgd291bGQgYmUgcmVmZXJlbmNlZFxuICogYnkgTGFtYmRhIGZ1bmN0aW9ucyBpbiB0aGUgdmFyaW91cyB1c2UgY2FzZXMuIFVwZGF0aW5nIG9mXG4gKiBSdW50aW1lIHZlcnNpb25zIHNob3VsZCBiZSBkb25lIGhlcmUuXG4gKi9cbmV4cG9ydCBjbGFzcyBEZWZhdWx0UnVudGltZXMge1xuXG4gIC8qKlxuICAgICAqIERlZmF1bHQgcnVudGltZSBmb3IgYWxsIExhbWJkYSBmdW5jdGlvbnMgaW4gdGhlIHVzZSBjYXNlcy5cbiAgICAgKi9cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBOT0RFSlMgPSBSdW50aW1lLk5PREVKU18yMl9YO1xuXG4gIC8qKlxuICAgKiBEZWZhdWx0IHJ1bnRpbWUgZm9yIFB5dGhvbiBiYXNlZCBMYW1iZGEgZnVuY3Rpb25zLlxuICAgKi9cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBQWVRIT04gPSBSdW50aW1lLlBZVEhPTl8zXzEzO1xuXG4gIC8qKlxuICAgKiBEZWZhdWx0IGJ1bmRsaW5nIGFyZ3VtZW50cyBmb3IgUHl0aG9uIGZ1bmN0aW9uXG4gICAqL1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IFBZVEhPTl9GVU5DVElPTl9CVU5ETElORzogQnVuZGxpbmdPcHRpb25zID0ge1xuICAgIGJ1aWxkQXJnczoge1xuICAgICAgJy0tcGxhdGZvcm0nOiAnbGludXgvYW1kNjQnLFxuICAgIH0sXG4gICAgaW1hZ2U6IHRoaXMuUFlUSE9OLmJ1bmRsaW5nSW1hZ2UsXG4gIH07XG59Il19
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './default-runtimes';
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./default-runtimes"), exports);
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi91c2UtY2FzZXMvZnJhbWV3b3JrL2N1c3RvbS1yZXNvdXJjZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7O0FBQUEscURBQW1DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kZWZhdWx0LXJ1bnRpbWVzJzsiXX0=
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import * as s3 from 'aws-cdk-lib/aws-s3';
|
|
2
|
+
import { Construct } from 'constructs';
|
|
3
|
+
/**
|
|
4
|
+
* Configuration options for the AccessLog construct
|
|
5
|
+
*/
|
|
6
|
+
export interface AccessLogProps {
|
|
7
|
+
/**
|
|
8
|
+
* The name of the S3 bucket for access logs
|
|
9
|
+
* @default 'access-logs'
|
|
10
|
+
*/
|
|
11
|
+
readonly bucketName?: string;
|
|
12
|
+
/**
|
|
13
|
+
* Lifecycle rules for the access logs
|
|
14
|
+
* @default Transition to IA after 30 days, delete after 90 days
|
|
15
|
+
*/
|
|
16
|
+
readonly lifecycleRules?: s3.LifecycleRule[];
|
|
17
|
+
/**
|
|
18
|
+
* Whether to enable versioning on the access logs bucket
|
|
19
|
+
* @default false
|
|
20
|
+
*/
|
|
21
|
+
readonly versioned?: boolean;
|
|
22
|
+
/**
|
|
23
|
+
* Custom bucket prefix for organizing access logs
|
|
24
|
+
* @default 'access-logs'
|
|
25
|
+
*/
|
|
26
|
+
readonly bucketPrefix?: string;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* AccessLog construct that provides a centralized S3 bucket for storing access logs.
|
|
30
|
+
* This construct creates a secure S3 bucket with appropriate policies for AWS services
|
|
31
|
+
* to deliver access logs.
|
|
32
|
+
*
|
|
33
|
+
* Usage:
|
|
34
|
+
*
|
|
35
|
+
* const accessLog = new AccessLog(this, 'AccessLog');
|
|
36
|
+
* const bucket = accessLog.bucket;
|
|
37
|
+
* const bucketName = accessLog.bucketName;
|
|
38
|
+
*/
|
|
39
|
+
export declare class AccessLog extends Construct {
|
|
40
|
+
/**
|
|
41
|
+
* The S3 bucket for storing access logs
|
|
42
|
+
*/
|
|
43
|
+
readonly bucket: s3.Bucket;
|
|
44
|
+
/**
|
|
45
|
+
* The name of the S3 bucket
|
|
46
|
+
*/
|
|
47
|
+
readonly bucketName: string;
|
|
48
|
+
/**
|
|
49
|
+
* The bucket prefix used for organizing access logs
|
|
50
|
+
*/
|
|
51
|
+
readonly bucketPrefix: string;
|
|
52
|
+
constructor(scope: Construct, id: string, props?: AccessLogProps);
|
|
53
|
+
/**
|
|
54
|
+
* Get the S3 bucket path for a specific service's access logs
|
|
55
|
+
*
|
|
56
|
+
* @param serviceName The name of the service (e.g., 'alb', 'cloudfront', 's3')
|
|
57
|
+
* @param resourceName Optional resource name for further organization
|
|
58
|
+
* @returns The S3 path for the service's access logs
|
|
59
|
+
*/
|
|
60
|
+
getLogPath(serviceName: string, resourceName?: string): string;
|
|
61
|
+
/**
|
|
62
|
+
* Get the S3 URI for a specific service's access logs
|
|
63
|
+
*
|
|
64
|
+
* @param serviceName The name of the service (e.g., 'alb', 'cloudfront', 's3')
|
|
65
|
+
* @param resourceName Optional resource name for further organization
|
|
66
|
+
* @returns The S3 URI for the service's access logs
|
|
67
|
+
*/
|
|
68
|
+
getLogUri(serviceName: string, resourceName?: string): string;
|
|
69
|
+
}
|