package awslambda import ( _init_ "github.com/aws/aws-cdk-go/awscdk/v2/jsii" _jsii_ "github.com/aws/jsii-runtime-go/runtime" "github.com/aws/aws-cdk-go/awscdk/v2" "github.com/aws/aws-cdk-go/awscdk/v2/awsecr" "github.com/aws/aws-cdk-go/awscdk/v2/awss3" "github.com/aws/aws-cdk-go/awscdk/v2/awss3assets" "github.com/aws/constructs-go/constructs/v10" ) // Represents a Docker image in ECR that can be bound as Lambda Code. // // Example: // // The code below shows an example of how to instantiate this type. // // The values are placeholders you should change. // import "github.com/aws/aws-cdk-go/awscdk" // import "github.com/aws/aws-cdk-go/awscdk" // // var repository repository // // ecrImageCode := awscdk.Aws_lambda.NewEcrImageCode(repository, &EcrImageCodeProps{ // Cmd: []*string{ // jsii.String("cmd"), // }, // Entrypoint: []*string{ // jsii.String("entrypoint"), // }, // Tag: jsii.String("tag"), // TagOrDigest: jsii.String("tagOrDigest"), // WorkingDirectory: jsii.String("workingDirectory"), // }) // type EcrImageCode interface { Code // Determines whether this Code is inline code or not. IsInline() *bool // Called when the lambda or layer is initialized to allow this object to bind to the stack, add resources and have fun. Bind(_scope constructs.Construct) *CodeConfig // Called after the CFN function resource has been created to allow the code class to bind to it. // // Specifically it's required to allow assets to add // metadata for tooling like SAM CLI to be able to find their origins. BindToResource(_resource awscdk.CfnResource, _options *ResourceBindOptions) } // The jsii proxy struct for EcrImageCode type jsiiProxy_EcrImageCode struct { jsiiProxy_Code } func (j *jsiiProxy_EcrImageCode) IsInline() *bool { var returns *bool _jsii_.Get( j, "isInline", &returns, ) return returns } func NewEcrImageCode(repository awsecr.IRepository, props *EcrImageCodeProps) EcrImageCode { _init_.Initialize() if err := validateNewEcrImageCodeParameters(repository, props); err != nil { panic(err) } j := jsiiProxy_EcrImageCode{} _jsii_.Create( "aws-cdk-lib.aws_lambda.EcrImageCode", []interface{}{repository, props}, &j, ) return &j } func NewEcrImageCode_Override(e EcrImageCode, repository awsecr.IRepository, props *EcrImageCodeProps) { _init_.Initialize() _jsii_.Create( "aws-cdk-lib.aws_lambda.EcrImageCode", []interface{}{repository, props}, e, ) } // Loads the function code from a local disk path. func EcrImageCode_FromAsset(path *string, options *awss3assets.AssetOptions) AssetCode { _init_.Initialize() if err := validateEcrImageCode_FromAssetParameters(path, options); err != nil { panic(err) } var returns AssetCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromAsset", []interface{}{path, options}, &returns, ) return returns } // Create an ECR image from the specified asset and bind it as the Lambda code. func EcrImageCode_FromAssetImage(directory *string, props *AssetImageCodeProps) AssetImageCode { _init_.Initialize() if err := validateEcrImageCode_FromAssetImageParameters(directory, props); err != nil { panic(err) } var returns AssetImageCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromAssetImage", []interface{}{directory, props}, &returns, ) return returns } // Lambda handler code as an S3 object. func EcrImageCode_FromBucket(bucket awss3.IBucket, key *string, objectVersion *string) S3Code { _init_.Initialize() if err := validateEcrImageCode_FromBucketParameters(bucket, key); err != nil { panic(err) } var returns S3Code _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromBucket", []interface{}{bucket, key, objectVersion}, &returns, ) return returns } // Creates a new Lambda source defined using CloudFormation parameters. // // Returns: a new instance of `CfnParametersCode`. func EcrImageCode_FromCfnParameters(props *CfnParametersCodeProps) CfnParametersCode { _init_.Initialize() if err := validateEcrImageCode_FromCfnParametersParameters(props); err != nil { panic(err) } var returns CfnParametersCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromCfnParameters", []interface{}{props}, &returns, ) return returns } // Loads the function code from an asset created by a Docker build. // // By default, the asset is expected to be located at `/asset` in the // image. func EcrImageCode_FromDockerBuild(path *string, options *DockerBuildAssetOptions) AssetCode { _init_.Initialize() if err := validateEcrImageCode_FromDockerBuildParameters(path, options); err != nil { panic(err) } var returns AssetCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromDockerBuild", []interface{}{path, options}, &returns, ) return returns } // Use an existing ECR image as the Lambda code. func EcrImageCode_FromEcrImage(repository awsecr.IRepository, props *EcrImageCodeProps) EcrImageCode { _init_.Initialize() if err := validateEcrImageCode_FromEcrImageParameters(repository, props); err != nil { panic(err) } var returns EcrImageCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromEcrImage", []interface{}{repository, props}, &returns, ) return returns } // Inline code for Lambda handler. // // Returns: `LambdaInlineCode` with inline code. func EcrImageCode_FromInline(code *string) InlineCode { _init_.Initialize() if err := validateEcrImageCode_FromInlineParameters(code); err != nil { panic(err) } var returns InlineCode _jsii_.StaticInvoke( "aws-cdk-lib.aws_lambda.EcrImageCode", "fromInline", []interface{}{code}, &returns, ) return returns } func (e *jsiiProxy_EcrImageCode) Bind(_scope constructs.Construct) *CodeConfig { if err := e.validateBindParameters(_scope); err != nil { panic(err) } var returns *CodeConfig _jsii_.Invoke( e, "bind", []interface{}{_scope}, &returns, ) return returns } func (e *jsiiProxy_EcrImageCode) BindToResource(_resource awscdk.CfnResource, _options *ResourceBindOptions) { if err := e.validateBindToResourceParameters(_resource, _options); err != nil { panic(err) } _jsii_.InvokeVoid( e, "bindToResource", []interface{}{_resource, _options}, ) }