Merge pull request #10218 from hashicorp/clean_plugin_sdk

Clean plugin sdk
This commit is contained in:
Megan Marsh 2020-11-06 12:35:23 -08:00 committed by GitHub
commit efc117fb55
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
35 changed files with 71 additions and 68 deletions

View File

@ -14,10 +14,10 @@ import (
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
awscommon "github.com/hashicorp/packer/builder/amazon/common" awscommon "github.com/hashicorp/packer/builder/amazon/common"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/chroot" "github.com/hashicorp/packer/common/chroot"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/hcl2template" "github.com/hashicorp/packer/hcl2template"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
@ -372,7 +372,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
state.Put("wrappedCommand", common.CommandWrapper(wrappedCommand)) state.Put("wrappedCommand", common.CommandWrapper(wrappedCommand))
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
// Build the steps // Build the steps
steps := []multistep.Step{ steps := []multistep.Step{

View File

@ -10,8 +10,8 @@ import (
"strings" "strings"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/hashicorp/packer/template/interpolate" "github.com/hashicorp/packer/template/interpolate"
@ -31,7 +31,7 @@ type StepMountDevice struct {
MountPartition string MountPartition string
mountPath string mountPath string
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *StepMountDevice) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { func (s *StepMountDevice) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -6,14 +6,14 @@ import (
"log" "log"
"os" "os"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )
// StepPrepareDevice finds an available device and sets it. // StepPrepareDevice finds an available device and sets it.
type StepPrepareDevice struct { type StepPrepareDevice struct {
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *StepPrepareDevice) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { func (s *StepPrepareDevice) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -3,7 +3,7 @@ package common
import ( import (
"github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
) )
@ -17,7 +17,7 @@ type BuildInfoTemplate struct {
SourceAMITags map[string]string SourceAMITags map[string]string
} }
func extractBuildInfo(region string, state multistep.StateBag, generatedData *builder.GeneratedData) *BuildInfoTemplate { func extractBuildInfo(region string, state multistep.StateBag, generatedData *packerbuilderdata.GeneratedData) *BuildInfoTemplate {
rawSourceAMI, hasSourceAMI := state.GetOk("source_image") rawSourceAMI, hasSourceAMI := state.GetOk("source_image")
if !hasSourceAMI { if !hasSourceAMI {
return &BuildInfoTemplate{ return &BuildInfoTemplate{

View File

@ -6,7 +6,7 @@ import (
"github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
) )
@ -35,8 +35,8 @@ func testState() multistep.StateBag {
return state return state
} }
func testGeneratedData(state multistep.StateBag) builder.GeneratedData { func testGeneratedData(state multistep.StateBag) packerbuilderdata.GeneratedData {
generatedData := builder.GeneratedData{State: state} generatedData := packerbuilderdata.GeneratedData{State: state}
return generatedData return generatedData
} }

View File

@ -14,7 +14,7 @@ import (
"github.com/aws/aws-sdk-go/service/ssm/ssmiface" "github.com/aws/aws-sdk-go/service/ssm/ssmiface"
"github.com/hashicorp/packer/builder/amazon/common/awserrors" "github.com/hashicorp/packer/builder/amazon/common/awserrors"
"github.com/hashicorp/packer/common/retry" "github.com/hashicorp/packer/common/retry"
"github.com/hashicorp/packer/helper/builder/localexec" "github.com/hashicorp/packer/common/shell-local/localexec"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )

View File

@ -7,7 +7,7 @@ import (
"github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/aws/session" "github.com/aws/aws-sdk-go/aws/session"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/hashicorp/packer/template/interpolate" "github.com/hashicorp/packer/template/interpolate"
@ -22,7 +22,7 @@ type StepModifyAMIAttributes struct {
Description string Description string
Ctx interpolate.Context Ctx interpolate.Context
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *StepModifyAMIAttributes) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { func (s *StepModifyAMIAttributes) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -4,7 +4,7 @@ import (
"context" "context"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
) )
@ -13,7 +13,7 @@ import (
// }, // },
type StepSetGeneratedData struct { type StepSetGeneratedData struct {
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *StepSetGeneratedData) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { func (s *StepSetGeneratedData) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -5,7 +5,7 @@ import (
"github.com/aws/aws-sdk-go/aws" "github.com/aws/aws-sdk-go/aws"
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/hashicorp/packer/template/interpolate" "github.com/hashicorp/packer/template/interpolate"
@ -23,7 +23,7 @@ func (t EC2Tags) Report(ui packer.Ui) {
func (t TagMap) EC2Tags(ictx interpolate.Context, region string, state multistep.StateBag) (EC2Tags, error) { func (t TagMap) EC2Tags(ictx interpolate.Context, region string, state multistep.StateBag) (EC2Tags, error) {
var ec2Tags []*ec2.Tag var ec2Tags []*ec2.Tag
generatedData := builder.GeneratedData{State: state} generatedData := packerbuilderdata.GeneratedData{State: state}
ictx.Data = extractBuildInfo(region, state, &generatedData) ictx.Data = extractBuildInfo(region, state, &generatedData)
for key, value := range t { for key, value := range t {

View File

@ -15,9 +15,9 @@ import (
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/aws/aws-sdk-go/service/iam" "github.com/aws/aws-sdk-go/service/iam"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
awscommon "github.com/hashicorp/packer/builder/amazon/common" awscommon "github.com/hashicorp/packer/builder/amazon/common"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/hcl2template" "github.com/hashicorp/packer/hcl2template"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
@ -169,7 +169,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("awsSession", session) state.Put("awsSession", session)
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
var instanceStep multistep.Step var instanceStep multistep.Step

View File

@ -13,9 +13,9 @@ import (
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/aws/aws-sdk-go/service/iam" "github.com/aws/aws-sdk-go/service/iam"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
awscommon "github.com/hashicorp/packer/builder/amazon/common" awscommon "github.com/hashicorp/packer/builder/amazon/common"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/hcl2template" "github.com/hashicorp/packer/hcl2template"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
@ -192,7 +192,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("awsSession", session) state.Put("awsSession", session)
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
var instanceStep multistep.Step var instanceStep multistep.Step

View File

@ -12,9 +12,9 @@ import (
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/aws/aws-sdk-go/service/iam" "github.com/aws/aws-sdk-go/service/iam"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
awscommon "github.com/hashicorp/packer/builder/amazon/common" awscommon "github.com/hashicorp/packer/builder/amazon/common"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/hcl2template" "github.com/hashicorp/packer/hcl2template"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
@ -180,7 +180,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("iam", iam) state.Put("iam", iam)
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
var instanceStep multistep.Step var instanceStep multistep.Step

View File

@ -15,9 +15,9 @@ import (
"github.com/aws/aws-sdk-go/service/ec2" "github.com/aws/aws-sdk-go/service/ec2"
"github.com/aws/aws-sdk-go/service/iam" "github.com/aws/aws-sdk-go/service/iam"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
awscommon "github.com/hashicorp/packer/builder/amazon/common" awscommon "github.com/hashicorp/packer/builder/amazon/common"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
@ -250,7 +250,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("awsSession", session) state.Put("awsSession", session)
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
var instanceStep multistep.Step var instanceStep multistep.Step

View File

@ -5,8 +5,8 @@ import (
"log" "log"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
@ -52,7 +52,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("config", &b.config) state.Put("config", &b.config)
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
// Setup the driver that will talk to Docker // Setup the driver that will talk to Docker
state.Put("driver", driver) state.Put("driver", driver)

View File

@ -3,7 +3,7 @@ package docker
import ( import (
"os/exec" "os/exec"
"github.com/hashicorp/packer/helper/builder/localexec" "github.com/hashicorp/packer/common/shell-local/localexec"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )

View File

@ -3,12 +3,12 @@ package docker
import ( import (
"context" "context"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
) )
type StepSetGeneratedData struct { type StepSetGeneratedData struct {
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *StepSetGeneratedData) Run(_ context.Context, state multistep.StateBag) multistep.StepAction { func (s *StepSetGeneratedData) Run(_ context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -4,14 +4,14 @@ import (
"context" "context"
"testing" "testing"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
) )
func TestStepSetGeneratedData_Run(t *testing.T) { func TestStepSetGeneratedData_Run(t *testing.T) {
state := testState(t) state := testState(t)
step := new(StepSetGeneratedData) step := new(StepSetGeneratedData)
step.GeneratedData = &builder.GeneratedData{State: state} step.GeneratedData = &packerbuilderdata.GeneratedData{State: state}
driver := state.Get("driver").(*MockDriver) driver := state.Get("driver").(*MockDriver)
driver.Sha256Result = "80B3BB1B1696E73A9B19DEEF92F664F8979F948DF348088B61F9A3477655AF64" driver.Sha256Result = "80B3BB1B1696E73A9B19DEEF92F664F8979F948DF348088B61F9A3477655AF64"
state.Put("image_id", "12345") state.Put("image_id", "12345")
@ -33,7 +33,7 @@ func TestStepSetGeneratedData_Run(t *testing.T) {
// Image ID not implement // Image ID not implement
state = testState(t) state = testState(t)
step.GeneratedData = &builder.GeneratedData{State: state} step.GeneratedData = &packerbuilderdata.GeneratedData{State: state}
driver = state.Get("driver").(*MockDriver) driver = state.Get("driver").(*MockDriver)
notImplementedMsg := "ERR_IMAGE_SHA256_NOT_FOUND" notImplementedMsg := "ERR_IMAGE_SHA256_NOT_FOUND"

View File

@ -5,7 +5,7 @@ import (
"fmt" "fmt"
"net/http" "net/http"
commonhelper "github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/net"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )
@ -29,7 +29,7 @@ func (s *stepSetISO) Run(ctx context.Context, state multistep.StateBag) multiste
req.Header.Set("User-Agent", "Packer") req.Header.Set("User-Agent", "Packer")
httpClient := commonhelper.HttpClientWithEnvironmentProxy() httpClient := net.HttpClientWithEnvironmentProxy()
res, err := httpClient.Do(req) res, err := httpClient.Do(req)
if err == nil && (res.StatusCode >= 200 && res.StatusCode < 300) { if err == nil && (res.StatusCode >= 200 && res.StatusCode < 300) {

View File

@ -6,8 +6,8 @@ import (
"github.com/google/uuid" "github.com/google/uuid"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/communicator" "github.com/hashicorp/packer/helper/communicator"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
@ -64,7 +64,7 @@ func (b *Builder) Run(ctx context.Context, ui packer.Ui, hook packer.Hook) (pack
state.Put("sdk", driver.SDK()) state.Put("sdk", driver.SDK())
state.Put("hook", hook) state.Put("hook", hook)
state.Put("ui", ui) state.Put("ui", ui)
generatedData := &builder.GeneratedData{State: state} generatedData := &packerbuilderdata.GeneratedData{State: state}
// Build the steps // Build the steps
steps := []multistep.Step{ steps := []multistep.Step{

View File

@ -6,7 +6,7 @@ import (
"fmt" "fmt"
"log" "log"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
@ -15,7 +15,7 @@ import (
) )
type stepCreateImage struct { type stepCreateImage struct {
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func (s *stepCreateImage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction { func (s *stepCreateImage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction {

View File

@ -7,7 +7,7 @@ import (
"io/ioutil" "io/ioutil"
"github.com/c2h5oh/datasize" "github.com/c2h5oh/datasize"
"github.com/hashicorp/packer/builder" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/common/uuid" "github.com/hashicorp/packer/common/uuid"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
@ -23,7 +23,7 @@ type StepCreateInstance struct {
Debug bool Debug bool
SerialLogFile string SerialLogFile string
GeneratedData *builder.GeneratedData GeneratedData *packerbuilderdata.GeneratedData
} }
func createNetwork(ctx context.Context, c *Config, d Driver) (*vpc.Network, error) { func createNetwork(ctx context.Context, c *Config, d Driver) (*vpc.Network, error) {

View File

@ -1,4 +1,4 @@
package common package net
import ( import (
"net/http" "net/http"

View File

@ -1,7 +1,12 @@
package builder package packerbuilderdata
import "github.com/hashicorp/packer/helper/multistep" import "github.com/hashicorp/packer/helper/multistep"
// This is used in the BasicPlaceholderData() func in the packer/provisioner.go
// To force users to access generated data via the "generated" func.
const PlaceholderMsg = "To set this dynamically in the Packer template, " +
"you must use the `build` function"
// GeneratedData manages variables exported by a builder after // GeneratedData manages variables exported by a builder after
// it started. It uses the builder's multistep.StateBag internally, make sure it // it started. It uses the builder's multistep.StateBag internally, make sure it
// is not nil before calling any functions. // is not nil before calling any functions.

View File

@ -1,4 +1,4 @@
package builder package packerbuilderdata
import ( import (
"testing" "testing"

View File

@ -14,6 +14,10 @@ import (
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
) )
// RunAndStream allows you to run a local command and stream output to the UI.
// This does not require use of a shell-local communicator, so is a nice tool
// for plugins that need to shell out to a local dependency and provide clear
// output to users.
func RunAndStream(cmd *exec.Cmd, ui packer.Ui, sensitive []string) error { func RunAndStream(cmd *exec.Cmd, ui packer.Ui, sensitive []string) error {
stdout_r, stdout_w := io.Pipe() stdout_r, stdout_w := io.Pipe()
stderr_r, stderr_w := io.Pipe() stderr_r, stderr_w := io.Pipe()

View File

@ -11,7 +11,7 @@ import (
"runtime" "runtime"
"strings" "strings"
"github.com/hashicorp/packer/helper/builder/localexec" "github.com/hashicorp/packer/common/shell-local/localexec"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
"github.com/hashicorp/packer/packer/tmp" "github.com/hashicorp/packer/packer/tmp"

View File

@ -1,6 +0,0 @@
package common
// This is used in the BasicPlaceholderData() func in the packer/provisioner.go
// To force users to access generated data via the "generated" func.
const PlaceholderMsg = "To set this dynamically in the Packer template, " +
"you must use the `build` function"

View File

@ -6,7 +6,7 @@ import (
"log" "log"
"sync" "sync"
"github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/packerbuilderdata"
) )
const ( const (
@ -182,7 +182,7 @@ func (b *CoreBuild) Prepare() (warn []string, err error) {
if generatedVars != nil { if generatedVars != nil {
for _, k := range generatedVars { for _, k := range generatedVars {
generatedPlaceholderMap[k] = fmt.Sprintf("Build_%s. "+ generatedPlaceholderMap[k] = fmt.Sprintf("Build_%s. "+
common.PlaceholderMsg, k) packerbuilderdata.PlaceholderMsg, k)
} }
} }

View File

@ -5,7 +5,7 @@ import (
"reflect" "reflect"
"testing" "testing"
"github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/packerbuilderdata"
) )
func boolPointer(tf bool) *bool { func boolPointer(tf bool) *bool {
@ -214,7 +214,7 @@ func TestBuildPrepare_ProvisionerGetsGeneratedMap(t *testing.T) {
} }
generated := BasicPlaceholderData() generated := BasicPlaceholderData()
generated["PartyVar"] = "Build_PartyVar. " + common.PlaceholderMsg generated["PartyVar"] = "Build_PartyVar. " + packerbuilderdata.PlaceholderMsg
if !reflect.DeepEqual(prov.PrepConfigs, []interface{}{42, packerConfig, generated}) { if !reflect.DeepEqual(prov.PrepConfigs, []interface{}{42, packerConfig, generated}) {
t.Fatalf("bad: %#v", prov.PrepConfigs) t.Fatalf("bad: %#v", prov.PrepConfigs)
} }

View File

@ -8,7 +8,7 @@ import (
"time" "time"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/packerbuilderdata"
) )
// A provisioner is responsible for installing and configuring software // A provisioner is responsible for installing and configuring software
@ -79,7 +79,7 @@ var BuilderDataCommonKeys = []string{
func BasicPlaceholderData() map[string]string { func BasicPlaceholderData() map[string]string {
placeholderData := map[string]string{} placeholderData := map[string]string{}
for _, key := range BuilderDataCommonKeys { for _, key := range BuilderDataCommonKeys {
placeholderData[key] = fmt.Sprintf("Build_%s. "+common.PlaceholderMsg, key) placeholderData[key] = fmt.Sprintf("Build_%s. "+packerbuilderdata.PlaceholderMsg, key)
} }
// Backwards-compatability: WinRM Password can get through without forcing // Backwards-compatability: WinRM Password can get through without forcing

View File

@ -11,7 +11,7 @@ import (
"os" "os"
"strings" "strings"
commonhelper "github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/net"
) )
type VagrantCloudClient struct { type VagrantCloudClient struct {
@ -48,7 +48,7 @@ func (v VagrantCloudErrors) FormatErrors() string {
func (v VagrantCloudClient) New(baseUrl string, token string, InsecureSkipTLSVerify bool) (*VagrantCloudClient, error) { func (v VagrantCloudClient) New(baseUrl string, token string, InsecureSkipTLSVerify bool) (*VagrantCloudClient, error) {
c := &VagrantCloudClient{ c := &VagrantCloudClient{
client: commonhelper.HttpClientWithEnvironmentProxy(), client: net.HttpClientWithEnvironmentProxy(),
BaseURL: baseUrl, BaseURL: baseUrl,
AccessToken: token, AccessToken: token,
} }

View File

@ -12,9 +12,9 @@ import (
"time" "time"
"github.com/hashicorp/hcl/v2/hcldec" "github.com/hashicorp/hcl/v2/hcldec"
"github.com/hashicorp/packer/builder"
"github.com/hashicorp/packer/builder/yandex" "github.com/hashicorp/packer/builder/yandex"
"github.com/hashicorp/packer/common" "github.com/hashicorp/packer/common"
"github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/helper/config" "github.com/hashicorp/packer/helper/config"
"github.com/hashicorp/packer/helper/multistep" "github.com/hashicorp/packer/helper/multistep"
"github.com/hashicorp/packer/packer" "github.com/hashicorp/packer/packer"
@ -210,7 +210,7 @@ func (p *PostProcessor) PostProcess(ctx context.Context, ui packer.Ui, artifact
}, },
&yandex.StepCreateInstance{ &yandex.StepCreateInstance{
Debug: p.config.PackerDebug, Debug: p.config.PackerDebug,
GeneratedData: &builder.GeneratedData{State: state}, GeneratedData: &packerbuilderdata.GeneratedData{State: state},
}, },
new(yandex.StepWaitCloudInitScript), new(yandex.StepWaitCloudInitScript),
new(yandex.StepTeardownInstance), new(yandex.StepTeardownInstance),

View File

@ -10,9 +10,9 @@ import (
"text/template" "text/template"
"time" "time"
"github.com/hashicorp/packer/common/packerbuilderdata"
commontpl "github.com/hashicorp/packer/common/template" commontpl "github.com/hashicorp/packer/common/template"
"github.com/hashicorp/packer/common/uuid" "github.com/hashicorp/packer/common/uuid"
"github.com/hashicorp/packer/helper/common"
"github.com/hashicorp/packer/version" "github.com/hashicorp/packer/version"
strftime "github.com/jehiah/go-strftime" strftime "github.com/jehiah/go-strftime"
) )
@ -170,7 +170,7 @@ func passthroughOrInterpolate(data map[interface{}]interface{}, s string) (strin
// If we're in the first interpolation pass, the goal is to // If we're in the first interpolation pass, the goal is to
// make sure that we pass the value through. // make sure that we pass the value through.
// TODO match against an actual string constant // TODO match against an actual string constant
if strings.Contains(hp, common.PlaceholderMsg) { if strings.Contains(hp, packerbuilderdata.PlaceholderMsg) {
return fmt.Sprintf("{{.%s}}", s), nil return fmt.Sprintf("{{.%s}}", s), nil
} else { } else {
return hp, nil return hp, nil

View File

@ -9,7 +9,7 @@ import (
"time" "time"
"github.com/google/go-cmp/cmp" "github.com/google/go-cmp/cmp"
"github.com/hashicorp/packer/helper/common" "github.com/hashicorp/packer/common/packerbuilderdata"
"github.com/hashicorp/packer/version" "github.com/hashicorp/packer/version"
) )
@ -351,7 +351,7 @@ func TestFuncPackerBuild(t *testing.T) {
}, },
// Data map is a map[string]string and contains value with placeholder. // Data map is a map[string]string and contains value with placeholder.
{ {
DataMap: map[string]string{"PartyVar": "PartyVal" + common.PlaceholderMsg}, DataMap: map[string]string{"PartyVar": "PartyVal" + packerbuilderdata.PlaceholderMsg},
ErrExpected: false, ErrExpected: false,
Template: "{{ build `PartyVar` }}", Template: "{{ build `PartyVar` }}",
OutVal: "{{.PartyVar}}", OutVal: "{{.PartyVar}}",
@ -372,14 +372,14 @@ func TestFuncPackerBuild(t *testing.T) {
}, },
// Data map is a map[interface{}]interface{} and contains value with placeholder. // Data map is a map[interface{}]interface{} and contains value with placeholder.
{ {
DataMap: map[interface{}]interface{}{"PartyVar": "PartyVal" + common.PlaceholderMsg}, DataMap: map[interface{}]interface{}{"PartyVar": "PartyVal" + packerbuilderdata.PlaceholderMsg},
ErrExpected: false, ErrExpected: false,
Template: "{{ build `PartyVar` }}", Template: "{{ build `PartyVar` }}",
OutVal: "{{.PartyVar}}", OutVal: "{{.PartyVar}}",
}, },
// Data map is a map[interface{}]interface{} and doesn't have value. // Data map is a map[interface{}]interface{} and doesn't have value.
{ {
DataMap: map[interface{}]interface{}{"BadVar": "PartyVal" + common.PlaceholderMsg}, DataMap: map[interface{}]interface{}{"BadVar": "PartyVal" + packerbuilderdata.PlaceholderMsg},
ErrExpected: true, ErrExpected: true,
Template: "{{ build `MissingVar` }}", Template: "{{ build `MissingVar` }}",
OutVal: "", OutVal: "",