From 0026792d2f60f03abc04239640065e967581310c Mon Sep 17 00:00:00 2001 From: Megan Marsh Date: Thu, 3 Oct 2019 15:48:17 -0700 Subject: [PATCH 1/3] remove clean_ami_name and clean_image_name; complete the deprecation for these functions in favor of clean_resource_name --- builder/amazon/common/template_funcs.go | 1 - builder/azure/common/template_funcs.go | 1 - builder/googlecompute/template_funcs.go | 1 - website/source/docs/templates/engine.html.md | 17 ++++++++++------- 4 files changed, 10 insertions(+), 10 deletions(-) diff --git a/builder/amazon/common/template_funcs.go b/builder/amazon/common/template_funcs.go index 246a288e0..eee77dca2 100644 --- a/builder/amazon/common/template_funcs.go +++ b/builder/amazon/common/template_funcs.go @@ -39,5 +39,4 @@ func templateCleanAMIName(s string) string { var TemplateFuncs = template.FuncMap{ "clean_resource_name": templateCleanAMIName, - "clean_ami_name": packertpl.DeprecatedTemplateFunc("clean_ami_name", "clean_resource_name", templateCleanAMIName), } diff --git a/builder/azure/common/template_funcs.go b/builder/azure/common/template_funcs.go index 1a399b53f..b9b8fe1cb 100644 --- a/builder/azure/common/template_funcs.go +++ b/builder/azure/common/template_funcs.go @@ -39,5 +39,4 @@ func templateCleanImageName(s string) string { var TemplateFuncs = template.FuncMap{ "clean_resource_name": templateCleanImageName, - "clean_image_name": packertpl.DeprecatedTemplateFunc("clean_image_name", "clean_resource_name", templateCleanImageName), } diff --git a/builder/googlecompute/template_funcs.go b/builder/googlecompute/template_funcs.go index bf57f3d96..3b8129861 100644 --- a/builder/googlecompute/template_funcs.go +++ b/builder/googlecompute/template_funcs.go @@ -37,5 +37,4 @@ func templateCleanImageName(s string) string { var TemplateFuncs = template.FuncMap{ "clean_resource_name": templateCleanImageName, - "clean_image_name": packertpl.DeprecatedTemplateFunc("clean_image_name", "clean_resource_name", templateCleanImageName), } diff --git a/website/source/docs/templates/engine.html.md b/website/source/docs/templates/engine.html.md index 821799193..06681e921 100644 --- a/website/source/docs/templates/engine.html.md +++ b/website/source/docs/templates/engine.html.md @@ -41,7 +41,7 @@ Here is a full list of the available functions for reference. will convert upper cases to lower cases and replace illegal characters with a "-" character. Example: - `"mybuild-{{isotime | clean_image_name}}"` will become + `"mybuild-{{isotime | clean_resource_name}}"` will become `mybuild-2017-10-18t02-06-30z`. Note: Valid Azure image names must match the regex @@ -57,6 +57,9 @@ Here is a full list of the available functions for reference. clean_resource_name}}"` will cause your build to fail because the image name will start with a number, which is why in the above example we prepend the isotime with "mybuild". + Exact behavior of `clean_resource_name` will depend on which builder it is + being applied to; refer to build-specific docs below for more detail on how + each function will behave. - `env` - Returns environment variables. See example in [using home variable](/docs/templates/user-variables.html#using-home-variable) - `isotime [FORMAT]` - UTC time, which can be @@ -80,19 +83,19 @@ Here is a full list of the available functions for reference. #### Specific to Amazon builders: -- `clean_ami_name` - DEPRECATED use `clean_resource_name` instead - AMI names +- `clean_resource_name` - AMI names can only contain certain characters. This function will replace illegal characters with a '-" character. Example usage since ":" is not a legal AMI - name is: `{{isotime | clean_ami_name}}`. + name is: `{{isotime | clean_resource_name}}`. #### Specific to Google Compute builders: -- `clean_image_name` - DEPRECATED use `clean_resource_name` instead - GCE +- `clean_resource_name` - GCE image names can only contain certain characters and the maximum length is 63. This function will convert upper cases to lower cases and replace illegal characters with a "-" character. Example: - `"mybuild-{{isotime | clean_image_name}}"` will become + `"mybuild-{{isotime | clean_resource_name}}"` will become `mybuild-2017-10-18t02-06-30z`. Note: Valid GCE image names must match the regex @@ -107,12 +110,12 @@ Here is a full list of the available functions for reference. #### Specific to Azure builders: -- `clean_image_name` - DEPRECATED use `clean_resource_name` instead - Azure +- `clean_resource_name` - Azure managed image names can only contain certain characters and the maximum length is 80. This function will replace illegal characters with a "-" character. Example: - `"mybuild-{{isotime | clean_image_name}}"` will become + `"mybuild-{{isotime | clean_resource_name}}"` will become `mybuild-2017-10-18t02-06-30z`. Note: Valid Azure image names must match the regex From d4600a7716cd729c6b246745aae7c279691e947c Mon Sep 17 00:00:00 2001 From: Adrien Delorme Date: Fri, 4 Oct 2019 11:19:45 +0200 Subject: [PATCH 2/3] fix go imports --- builder/amazon/common/template_funcs.go | 2 -- builder/azure/common/template_funcs.go | 2 -- builder/googlecompute/template_funcs.go | 2 -- 3 files changed, 6 deletions(-) diff --git a/builder/amazon/common/template_funcs.go b/builder/amazon/common/template_funcs.go index eee77dca2..14dd65d83 100644 --- a/builder/amazon/common/template_funcs.go +++ b/builder/amazon/common/template_funcs.go @@ -3,8 +3,6 @@ package common import ( "bytes" "text/template" - - packertpl "github.com/hashicorp/packer/common/template" ) func isalphanumeric(b byte) bool { diff --git a/builder/azure/common/template_funcs.go b/builder/azure/common/template_funcs.go index b9b8fe1cb..faccd4f07 100644 --- a/builder/azure/common/template_funcs.go +++ b/builder/azure/common/template_funcs.go @@ -3,8 +3,6 @@ package common import ( "bytes" "text/template" - - packertpl "github.com/hashicorp/packer/common/template" ) func isValidByteValue(b byte) bool { diff --git a/builder/googlecompute/template_funcs.go b/builder/googlecompute/template_funcs.go index 3b8129861..37557180f 100644 --- a/builder/googlecompute/template_funcs.go +++ b/builder/googlecompute/template_funcs.go @@ -3,8 +3,6 @@ package googlecompute import ( "strings" "text/template" - - packertpl "github.com/hashicorp/packer/common/template" ) func isalphanumeric(b byte) bool { From 3a4079f97adc1435bc2ab0001794f778c14860b2 Mon Sep 17 00:00:00 2001 From: Adrien Delorme Date: Fri, 4 Oct 2019 11:31:33 +0200 Subject: [PATCH 3/3] yandex: use clean_resource_name too --- builder/yandex/template_func.go | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/builder/yandex/template_func.go b/builder/yandex/template_func.go index 91f83a9d5..144ed14e3 100644 --- a/builder/yandex/template_func.go +++ b/builder/yandex/template_func.go @@ -1,7 +1,9 @@ package yandex -import "strings" -import "text/template" +import ( + "strings" + "text/template" +) func isalphanumeric(b byte) bool { if '0' <= b && b <= '9' { @@ -13,9 +15,9 @@ func isalphanumeric(b byte) bool { return false } -// Clean up image name by replacing invalid characters with "-" +// Clean up resource name by replacing invalid characters with "-" // and converting upper cases to lower cases -func templateCleanImageName(s string) string { +func templateCleanResourceName(s string) string { if reImageFamily.MatchString(s) { return s } @@ -32,5 +34,5 @@ func templateCleanImageName(s string) string { } var TemplateFuncs = template.FuncMap{ - "clean_image_name": templateCleanImageName, + "clean_resource_name": templateCleanResourceName, }