|
|
|
|
@ -31,6 +31,12 @@ type PackerConfig struct {
|
|
|
|
|
|
|
|
|
|
// Builds is the list of Build blocks defined in the config files.
|
|
|
|
|
Builds Builds
|
|
|
|
|
|
|
|
|
|
builderSchemas packer.BuilderStore
|
|
|
|
|
|
|
|
|
|
provisionersSchemas packer.ProvisionerStore
|
|
|
|
|
|
|
|
|
|
postProcessorsSchemas packer.PostProcessorStore
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type ValidationOptions struct {
|
|
|
|
|
@ -188,11 +194,11 @@ func (c *PackerConfig) evaluateLocalVariable(local *Local) hcl.Diagnostics {
|
|
|
|
|
|
|
|
|
|
// getCoreBuildProvisioners takes a list of provisioner block, starts according
|
|
|
|
|
// provisioners and sends parsed HCL2 over to it.
|
|
|
|
|
func (p *Parser) getCoreBuildProvisioners(source *SourceBlock, blocks []*ProvisionerBlock, ectx *hcl.EvalContext, generatedVars map[string]string) ([]packer.CoreBuildProvisioner, hcl.Diagnostics) {
|
|
|
|
|
func (cfg *PackerConfig) getCoreBuildProvisioners(source *SourceBlock, blocks []*ProvisionerBlock, ectx *hcl.EvalContext, generatedVars map[string]string) ([]packer.CoreBuildProvisioner, hcl.Diagnostics) {
|
|
|
|
|
var diags hcl.Diagnostics
|
|
|
|
|
res := []packer.CoreBuildProvisioner{}
|
|
|
|
|
for _, pb := range blocks {
|
|
|
|
|
provisioner, moreDiags := p.startProvisioner(source, pb, ectx, generatedVars)
|
|
|
|
|
provisioner, moreDiags := cfg.startProvisioner(source, pb, ectx, generatedVars)
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
@ -228,11 +234,11 @@ func (p *Parser) getCoreBuildProvisioners(source *SourceBlock, blocks []*Provisi
|
|
|
|
|
|
|
|
|
|
// getCoreBuildProvisioners takes a list of post processor block, starts
|
|
|
|
|
// according provisioners and sends parsed HCL2 over to it.
|
|
|
|
|
func (p *Parser) getCoreBuildPostProcessors(source *SourceBlock, blocks []*PostProcessorBlock, ectx *hcl.EvalContext, generatedVars map[string]string) ([]packer.CoreBuildPostProcessor, hcl.Diagnostics) {
|
|
|
|
|
func (cfg *PackerConfig) getCoreBuildPostProcessors(source *SourceBlock, 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(source, ppb, ectx, generatedVars)
|
|
|
|
|
postProcessor, moreDiags := cfg.startPostProcessor(source, ppb, ectx, generatedVars)
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
@ -250,7 +256,7 @@ func (p *Parser) getCoreBuildPostProcessors(source *SourceBlock, blocks []*PostP
|
|
|
|
|
// getBuilds will return a list of packer Build based on the HCL2 parsed build
|
|
|
|
|
// blocks. All Builders, Provisioners and Post Processors will be started and
|
|
|
|
|
// configured.
|
|
|
|
|
func (p *Parser) getBuilds(cfg *PackerConfig, onlyGlobs []glob.Glob, exceptGlobs []glob.Glob) ([]packer.Build, hcl.Diagnostics) {
|
|
|
|
|
func (cfg *PackerConfig) getBuilds(onlyGlobs []glob.Glob, exceptGlobs []glob.Glob) ([]packer.Build, hcl.Diagnostics) {
|
|
|
|
|
res := []packer.Build{}
|
|
|
|
|
var diags hcl.Diagnostics
|
|
|
|
|
|
|
|
|
|
@ -297,7 +303,7 @@ func (p *Parser) getBuilds(cfg *PackerConfig, onlyGlobs []glob.Glob, exceptGlobs
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
builder, moreDiags, generatedVars := p.startBuilder(src, cfg.EvalContext(nil))
|
|
|
|
|
builder, moreDiags, generatedVars := cfg.startBuilder(src, cfg.EvalContext(nil))
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
@ -323,12 +329,12 @@ func (p *Parser) getBuilds(cfg *PackerConfig, onlyGlobs []glob.Glob, exceptGlobs
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
provisioners, moreDiags := p.getCoreBuildProvisioners(src, build.ProvisionerBlocks, cfg.EvalContext(variables), generatedPlaceholderMap)
|
|
|
|
|
provisioners, moreDiags := cfg.getCoreBuildProvisioners(src, build.ProvisionerBlocks, cfg.EvalContext(variables), generatedPlaceholderMap)
|
|
|
|
|
diags = append(diags, moreDiags...)
|
|
|
|
|
if moreDiags.HasErrors() {
|
|
|
|
|
continue
|
|
|
|
|
}
|
|
|
|
|
postProcessors, moreDiags := p.getCoreBuildPostProcessors(src, build.PostProcessors, cfg.EvalContext(variables), generatedPlaceholderMap)
|
|
|
|
|
postProcessors, moreDiags := cfg.getCoreBuildPostProcessors(src, build.PostProcessors, cfg.EvalContext(variables), generatedPlaceholderMap)
|
|
|
|
|
pps := [][]packer.CoreBuildPostProcessor{}
|
|
|
|
|
if len(postProcessors) > 0 {
|
|
|
|
|
pps = [][]packer.CoreBuildPostProcessor{postProcessors}
|
|
|
|
|
@ -404,6 +410,6 @@ func (p *Parser) Parse(path string, varFiles []string, argVars map[string]string
|
|
|
|
|
return nil, diags
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
builds, moreDiags := p.getBuilds(cfg, onlyGlobs, exceptGlobs)
|
|
|
|
|
builds, moreDiags := cfg.getBuilds(onlyGlobs, exceptGlobs)
|
|
|
|
|
return builds, append(diags, moreDiags...)
|
|
|
|
|
}
|
|
|
|
|
|