Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat(lambda): add ipv6AllowedForDualStack for lambda function #28059

Closed
wants to merge 23 commits into from
Closed
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
23 commits
Select commit Hold shift + click to select a range
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
import * as ec2 from 'aws-cdk-lib/aws-ec2';
import * as cdk from 'aws-cdk-lib';
import * as lambda from 'aws-cdk-lib/aws-lambda';
import * as integ from '@aws-cdk/integ-tests-alpha';

const app = new cdk.App();

Expand All @@ -14,4 +15,14 @@ new lambda.Function(stack, 'MyLambda', {
vpc,
});

app.synth();
new lambda.Function(stack, 'IPv6EnabledLambda', {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I tried the existing PR and its integration tests were failing, here's my fork with changes to integration tests and almost similar changes for the feature implementation that works: Vandita2020@e2c7753

vpc,
code: new lambda.InlineCode('def main(event, context): pass'),
handler: 'index.main',
runtime: lambda.Runtime.PYTHON_3_9,
ipv6AllowedForDualStack: true,
});

new integ.IntegTest(app, 'VpcLambdaTest', {
testCases: [stack],
});
14 changes: 14 additions & 0 deletions packages/aws-cdk-lib/aws-lambda/lib/function.ts
Original file line number Diff line number Diff line change
Expand Up @@ -264,6 +264,13 @@ export interface FunctionOptions extends EventInvokeConfigOptions {
*/
readonly allowAllOutbound?: boolean;

/**
* Indicates whether IPv6 protocols will be allowed for dual stack subnets.
*
* @default false
*/
readonly ipv6AllowedForDualStack?: boolean;

/**
* Enabled DLQ. If `deadLetterQueue` is undefined,
* an SQS queue with default options will be defined for your Function.
Expand Down Expand Up @@ -1377,6 +1384,9 @@ Environment variables can be marked for removal when used in Lambda@Edge by sett
if (props.vpcSubnets) {
throw new Error('Cannot configure \'vpcSubnets\' without configuring a VPC');
}
if (props.ipv6AllowedForDualStack) {
throw new Error('Cannot configure \'ipv6AllowedForDualStack\' without configuring a VPC');
}
return undefined;
}

Expand Down Expand Up @@ -1419,6 +1429,9 @@ Environment variables can be marked for removal when used in Lambda@Edge by sett
'If you are aware of this limitation and would still like to place the function in a public subnet, set `allowPublicSubnet` to true');
}
}

const ipv6AllowedForDualStack = props.ipv6AllowedForDualStack ?? false;

this.node.addDependency(selectedSubnets.internetConnectivityEstablished);

// List can't be empty here, if we got this far you intended to put your Lambda
Expand All @@ -1428,6 +1441,7 @@ Environment variables can be marked for removal when used in Lambda@Edge by sett
return {
subnetIds: selectedSubnets.subnetIds,
securityGroupIds: securityGroups.map(sg => sg.securityGroupId),
ipv6AllowedForDualStack,
};
}

Expand Down
40 changes: 39 additions & 1 deletion packages/aws-cdk-lib/aws-lambda/test/vpc-lambda.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -334,10 +334,48 @@ describe('lambda + vpc', () => {
code: new lambda.InlineCode('foo'),
handler: 'index.handler',
runtime: lambda.Runtime.NODEJS_LATEST,
vpcSubnets: { subnetType: ec2.SubnetType.PRIVATE },
vpcSubnets: { subnetType: ec2.SubnetType.PRIVATE_ISOLATED },
});
}).toThrow('Cannot configure \'vpcSubnets\' without configuring a VPC');
});

test('specifying ipv6AllowedForDualStack without a vpc throws an Error', () => {
// GIVEN
const stack = new cdk.Stack();

// WHEN
expect(() => new lambda.Function(stack, 'MyLambda', {
code: new lambda.InlineCode('foo'),
handler: 'index.handler',
runtime: lambda.Runtime.NODEJS_LATEST,
ipv6AllowedForDualStack: true,
})).toThrow(/Cannot configure 'ipv6AllowedForDualStack' without configuring a VPC/);
});

test('can specify ipv6AllowedForDualStack for Lambda', () => {
// GIVEN
const stack = new cdk.Stack();
const vpc = new ec2.Vpc(stack, 'Vpc', {
maxAzs: 3,
natGateways: 1,
});

// WHEN
new lambda.Function(stack, 'MyLambda', {
vpc,
code: new lambda.InlineCode('foo'),
handler: 'index.handler',
runtime: lambda.Runtime.NODEJS_LATEST,
ipv6AllowedForDualStack: true,
});

// THEN
Template.fromStack(stack).hasResourceProperties('AWS::Lambda::Function', {
VpcConfig: {
Ipv6AllowedForDualStack: true,
},
});
});
});

class SomethingConnectable implements ec2.IConnectable {
Expand Down
Loading