|
|
|
|
@ -1,7 +1,9 @@
|
|
|
|
|
package hcl2template
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
|
|
|
|
"github.com/hashicorp/hcl/v2"
|
|
|
|
|
"github.com/hashicorp/packer/helper/common"
|
|
|
|
|
"github.com/hashicorp/packer/packer"
|
|
|
|
|
"github.com/zclconf/go-cty/cty"
|
|
|
|
|
)
|
|
|
|
|
@ -42,7 +44,7 @@ func (cfg *PackerConfig) EvalContext() *hcl.EvalContext {
|
|
|
|
|
|
|
|
|
|
// getCoreBuildProvisioners takes a list of provisioner block, starts according
|
|
|
|
|
// provisioners and sends parsed HCL2 over to it.
|
|
|
|
|
func (p *Parser) getCoreBuildProvisioners(blocks []*ProvisionerBlock, ectx *hcl.EvalContext, generatedVars []string) ([]packer.CoreBuildProvisioner, hcl.Diagnostics) {
|
|
|
|
|
func (p *Parser) getCoreBuildProvisioners(blocks []*ProvisionerBlock, ectx *hcl.EvalContext, generatedVars map[string]string) ([]packer.CoreBuildProvisioner, hcl.Diagnostics) {
|
|
|
|
|
var diags hcl.Diagnostics
|
|
|
|
|
res := []packer.CoreBuildProvisioner{}
|
|
|
|
|
for _, pb := range blocks {
|
|
|
|
|
@ -62,11 +64,11 @@ func (p *Parser) getCoreBuildProvisioners(blocks []*ProvisionerBlock, ectx *hcl.
|
|
|
|
|
|
|
|
|
|
// getCoreBuildProvisioners takes a list of post processor block, starts
|
|
|
|
|
// according provisioners and sends parsed HCL2 over to it.
|
|
|
|
|
func (p *Parser) getCoreBuildPostProcessors(blocks []*PostProcessorBlock, ectx *hcl.EvalContext) ([]packer.CoreBuildPostProcessor, hcl.Diagnostics) {
|
|
|
|
|
func (p *Parser) getCoreBuildPostProcessors(blocks []*PostProcessorBlock, ectx *hcl.EvalContext, generatedVars map[string]string) ([]packer.CoreBuildPostProcessor, hcl.Diagnostics) {
|
|
|
|
|
var diags hcl.Diagnostics
|
|
|
|
|
res := []packer.CoreBuildPostProcessor{}
|
|
|
|
|
for _, ppb := range blocks {
|
|
|
|
|
postProcessor, moreDiags := p.startPostProcessor(ppb, ectx)
|
|
|
|
|
postProcessor, moreDiags := p.startPostProcessor(ppb, ectx, generatedVars)
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
@ -104,12 +106,26 @@ func (p *Parser) getBuilds(cfg *PackerConfig) ([]packer.Build, hcl.Diagnostics)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
provisioners, moreDiags := p.getCoreBuildProvisioners(build.ProvisionerBlocks, cfg.EvalContext(), generatedVars)
|
|
|
|
|
|
|
|
|
|
// If the builder has provided a list of to-be-generated variables that
|
|
|
|
|
// should be made accessible to provisioners, pass that list into
|
|
|
|
|
// the provisioner prepare() so that the provisioner can appropriately
|
|
|
|
|
// validate user input against what will become available. Otherwise,
|
|
|
|
|
// only pass the default variables, using the basic placeholder data.
|
|
|
|
|
generatedPlaceholderMap := packer.BasicPlaceholderData()
|
|
|
|
|
if generatedVars != nil {
|
|
|
|
|
for _, k := range generatedVars {
|
|
|
|
|
generatedPlaceholderMap[k] = fmt.Sprintf("Build_%s. "+
|
|
|
|
|
common.PlaceholderMsg, k)
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
provisioners, moreDiags := p.getCoreBuildProvisioners(build.ProvisionerBlocks, cfg.EvalContext(), generatedPlaceholderMap)
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
postProcessors, moreDiags := p.getCoreBuildPostProcessors(build.PostProcessors, cfg.EvalContext())
|
|
|
|
|
postProcessors, moreDiags := p.getCoreBuildPostProcessors(build.PostProcessors, cfg.EvalContext(), generatedPlaceholderMap)
|
|
|
|
|
pps := [][]packer.CoreBuildPostProcessor{}
|
|
|
|
|
if len(postProcessors) > 0 {
|
|
|
|
|
pps = [][]packer.CoreBuildPostProcessor{postProcessors}
|
|
|
|
|
@ -124,6 +140,7 @@ func (p *Parser) getBuilds(cfg *PackerConfig) ([]packer.Build, hcl.Diagnostics)
|
|
|
|
|
Builder: builder,
|
|
|
|
|
Provisioners: provisioners,
|
|
|
|
|
PostProcessors: pps,
|
|
|
|
|
Prepared: true,
|
|
|
|
|
}
|
|
|
|
|
res = append(res, pcb)
|
|
|
|
|
}
|
|
|
|
|
|