From 5e168d69f9fe4230b24b61bef58e689e825aa1a9 Mon Sep 17 00:00:00 2001 From: FUJIWARA Shunichiro Date: Fri, 17 Dec 2021 22:58:44 +0900 Subject: [PATCH 1/2] add const packageTypeImage --- create.go | 2 +- lambroll.go | 5 +++-- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/create.go b/create.go index 27b9b4a..a94e257 100644 --- a/create.go +++ b/create.go @@ -20,7 +20,7 @@ func (app *App) prepareFunctionCodeForDeploy(opt DeployOption, fn *Function) err info os.FileInfo ) - if aws.StringValue(fn.PackageType) == "Image" { + if aws.StringValue(fn.PackageType) == packageTypeImage { if fn.Code == nil || fn.Code.ImageUri == nil { return errors.New("PackageType=Image requires Code.ImageUri in function definition") } diff --git a/lambroll.go b/lambroll.go index 75fa20d..02634bd 100644 --- a/lambroll.go +++ b/lambroll.go @@ -21,6 +21,7 @@ import ( ) const versionLatest = "$LATEST" +const packageTypeImage = "Image" var retryPolicy = retry.Policy{ MinDelay: time.Second, @@ -244,9 +245,9 @@ func newFunctionFrom(c *lambda.FunctionConfiguration, code *lambda.FunctionCodeL } } - if aws.StringValue(code.RepositoryType) == "ECR" || aws.StringValue(fn.PackageType) == "Image" { + if aws.StringValue(code.RepositoryType) == "ECR" || aws.StringValue(fn.PackageType) == packageTypeImage { log.Printf("[debug] Image URL=%s", *code.ImageUri) - fn.PackageType = aws.String("Image") + fn.PackageType = aws.String(packageTypeImage) fn.Code = &lambda.FunctionCode{ ImageUri: code.ImageUri, } From 4001a7eaef9243ee6c7726d1e3e8db086351abf4 Mon Sep 17 00:00:00 2001 From: FUJIWARA Shunichiro Date: Fri, 17 Dec 2021 22:59:13 +0900 Subject: [PATCH 2/2] add validate function before deploy. --- deploy.go | 4 +++- diff.go | 4 ++++ lambroll.go | 24 ++++++++++++++++++++++++ 3 files changed, 31 insertions(+), 1 deletion(-) diff --git a/deploy.go b/deploy.go index 3b636f0..f7b6cad 100644 --- a/deploy.go +++ b/deploy.go @@ -83,7 +83,7 @@ func (app *App) Deploy(opt DeployOption) error { } log.Printf("[info] starting deploy function %s", *fn.FunctionName) - if _, err := app.lambda.GetFunction(&lambda.GetFunctionInput{ + if current, err := app.lambda.GetFunction(&lambda.GetFunctionInput{ FunctionName: fn.FunctionName, }); err != nil { if aerr, ok := err.(awserr.Error); ok { @@ -93,6 +93,8 @@ func (app *App) Deploy(opt DeployOption) error { } } return err + } else if err := validateUpdateFunction(current.Configuration, current.Code, fn); err != nil { + return err } if err := app.prepareFunctionCodeForDeploy(opt, fn); err != nil { diff --git a/diff.go b/diff.go index 364597e..e64e74a 100644 --- a/diff.go +++ b/diff.go @@ -47,6 +47,10 @@ func (app *App) Diff(opt DiffOption) error { fmt.Println(color.GreenString("+++" + *opt.FunctionFilePath)) fmt.Println(coloredDiff(ds)) } + + if err := validateUpdateFunction(latest, code, newFunc); err != nil { + return err + } return nil } diff --git a/lambroll.go b/lambroll.go index 02634bd..a7bac54 100644 --- a/lambroll.go +++ b/lambroll.go @@ -278,3 +278,27 @@ func exportEnvFile(file string) error { } return nil } + +var errCannotUpdateImageAndZip = errors.New("cannot update function code between Image and Zip") + +func validateUpdateFunction(currentConf *lambda.FunctionConfiguration, currentCode *lambda.FunctionCodeLocation, newFn *lambda.CreateFunctionInput) error { + newCode := newFn.Code + + // new=Image + if newCode != nil && newCode.ImageUri != nil || aws.StringValue(newFn.PackageType) == packageTypeImage { + // current=Zip + if currentCode == nil || currentCode.ImageUri == nil { + return errCannotUpdateImageAndZip + } + } + + // current=Image + if currentCode != nil && currentCode.ImageUri != nil || aws.StringValue(currentConf.PackageType) == packageTypeImage { + // new=Zip + if newCode == nil || newCode.ImageUri == nil { + return errCannotUpdateImageAndZip + } + } + + return nil +}