Documentation ¶
Index ¶
- Constants
- type Artifact
- type Builder
- type Config
- type FlatConfig
- type InitScript
- type LoginKey
- type NcloudAPIClient
- type StepCreateAccessControlGroup
- type StepCreateBlockStorage
- type StepCreateInitScript
- type StepCreateLoginKey
- type StepCreatePublicIP
- type StepCreateServerImage
- type StepCreateServerInstance
- type StepDeleteBlockStorage
- type StepGetRootPassword
- type StepStopServerInstance
- type StepTerminateServerInstance
- type StepValidateTemplate
Constants ¶
const ( BlockStorageStatusAttached = "ATTAC" BlockStorageStatusDetached = "DETAC" )
const ( PublicIpStatusUsed = "USED" PublicIpStatusCreated = "CREAT" PublicIpStatusRunning = "RUN" )
const ( ServerInstanceStatusStopped = "NSTOP" ServerInstanceStatusTerminated = "TERMT" ServerInstanceStatusRunning = "RUN" )
const BuilderID = "ncloud.server.image"
const (
ServerImageStatusCreated = "CREAT"
)
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Artifact ¶
type Artifact struct { MemberServerImage *server.MemberServerImage // StateData should store data such as GeneratedData // to be shared with post-processors StateData map[string]interface{} }
type Builder ¶
type Builder struct {
// contains filtered or unexported fields
}
Builder assume this implements packersdk.Builder
func (*Builder) ConfigSpec ¶
func (b *Builder) ConfigSpec() hcldec.ObjectSpec
type Config ¶
type Config struct { common.PackerConfig `mapstructure:",squash"` // User's access key. Go to [\[Account Management > Authentication Key\]](https://www.ncloud.com/mypage/manage/authkey) to create and view your authentication key. AccessKey string `mapstructure:"access_key" required:"true"` // User's secret key paired with the access key. Go to [\[Account Management > Authentication Key\]](https://www.ncloud.com/mypage/manage/authkey) to create and view your authentication key. SecretKey string `mapstructure:"secret_key" required:"true"` // Product code of an image to create. // (member_server_image_no is required if not specified) ServerImageProductCode string `mapstructure:"server_image_product_code" required:"true"` // Product (spec) code to create. ServerProductCode string `mapstructure:"server_product_code" required:"false"` // Whether to use VPC without specific vpc or subnet. Packer will try find public subnet in entire vpc if you set this value `true`. // (You are required to least one three parameters if u want using VPC environment: `support_vpc` or `vpc_no` or `subnet_no`) SupportVPC bool `mapstructure:"support_vpc" required:"false"` // The ID of the VPC where you want to place the Server Instance. If this field is left blank, Packer will try to get the VPC ID from the `subnet_no` or exists public subnet. // (You are required to least one three parameters if u want using VPC environment: `support_vpc` or `vpc_no` or `subnet_no`) VpcNo string `mapstructure:"vpc_no" required:"false"` // The ID of the Subnet where you want to place the Server Instance. This field is required if you are using an specific subnets. // (You are required to least one three parameters if u want using VPC environment: `support_vpc` or `vpc_no` or `subnet_no`) SubnetNo string `mapstructure:"subnet_no" required:"false"` // Previous image code. If there is an // image previously created, it can be used to create a new image. // (server_image_product_code is required if not specified) MemberServerImageNo string `mapstructure:"member_server_image_no" required:"false"` // Name of an image to create. ServerImageName string `mapstructure:"server_image_name" required:"false"` // Description of an image to create. ServerImageDescription string `mapstructure:"server_image_description" required:"false"` // You can add block storage ranging from 10GB to 2000 GB, in increments of 10 GB. BlockStorageSize int `mapstructure:"block_storage_size" required:"false"` // This is used to allow // winrm access when you create a Windows server. An ACG that specifies an // access source (0.0.0.0/0) and allowed port (5985) must be created in // advance if you use CLASSIC env. If this field is left blank, // Packer will create temporary ACG for automatically in VPC environment. AccessControlGroupNo string `mapstructure:"access_control_group_no" required:"false"` // User data to apply when launching the instance. Note // that you need to be careful about escaping characters due to the templates // being JSON. It is often more convenient to use user_data_file, instead. // Packer will not automatically wait for a user script to finish before // shutting down the instance this must be handled in a provisioner. UserData string `mapstructure:"user_data" required:"false"` // Path to a file that will be used for the user // data when launching the instance. UserDataFile string `mapstructure:"user_data_file" required:"false"` // The name of the region where you want to create an image. Such as `Korea`. To be deprecated Region string `mapstructure:"region" required:"false"` // The code of the region where you want to create an image. Such as KR. // (pub or gov default: KR) (fin default: FKR) RegionCode string `mapstructure:"region_code" required:"false"` // The ncloud site. Available sites are public(`www.ncloud.com`), gov(`www.gov-ncloud.com`) and fin(`www.fin-ncloud.com`) (default: public) // - values: public / gov / fin Site string `mapstructure:"site" required:"false"` Comm communicator.Config `mapstructure:",squash"` // contains filtered or unexported fields }
Config is structure to use packer builder plugin for Naver Cloud Platform nolint: unused
func (*Config) Client ¶
func (c *Config) Client() (*NcloudAPIClient, error)
func (*Config) FlatMapstructure ¶
FlatMapstructure returns a new FlatConfig. FlatConfig is an auto-generated flat version of Config. Where the contents a fields with a `mapstructure:,squash` tag are bubbled up.
type FlatConfig ¶
type FlatConfig struct { PackerBuildName *string `mapstructure:"packer_build_name" cty:"packer_build_name" hcl:"packer_build_name"` PackerBuilderType *string `mapstructure:"packer_builder_type" cty:"packer_builder_type" hcl:"packer_builder_type"` PackerCoreVersion *string `mapstructure:"packer_core_version" cty:"packer_core_version" hcl:"packer_core_version"` PackerDebug *bool `mapstructure:"packer_debug" cty:"packer_debug" hcl:"packer_debug"` PackerForce *bool `mapstructure:"packer_force" cty:"packer_force" hcl:"packer_force"` PackerOnError *string `mapstructure:"packer_on_error" cty:"packer_on_error" hcl:"packer_on_error"` PackerUserVars map[string]string `mapstructure:"packer_user_variables" cty:"packer_user_variables" hcl:"packer_user_variables"` PackerSensitiveVars []string `mapstructure:"packer_sensitive_variables" cty:"packer_sensitive_variables" hcl:"packer_sensitive_variables"` AccessKey *string `mapstructure:"access_key" required:"true" cty:"access_key" hcl:"access_key"` SecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key" hcl:"secret_key"` ServerImageProductCode *string `mapstructure:"server_image_product_code" required:"true" cty:"server_image_product_code" hcl:"server_image_product_code"` ServerProductCode *string `mapstructure:"server_product_code" required:"false" cty:"server_product_code" hcl:"server_product_code"` SupportVPC *bool `mapstructure:"support_vpc" required:"false" cty:"support_vpc" hcl:"support_vpc"` VpcNo *string `mapstructure:"vpc_no" required:"false" cty:"vpc_no" hcl:"vpc_no"` SubnetNo *string `mapstructure:"subnet_no" required:"false" cty:"subnet_no" hcl:"subnet_no"` MemberServerImageNo *string `mapstructure:"member_server_image_no" required:"false" cty:"member_server_image_no" hcl:"member_server_image_no"` ServerImageName *string `mapstructure:"server_image_name" required:"false" cty:"server_image_name" hcl:"server_image_name"` ServerImageDescription *string `mapstructure:"server_image_description" required:"false" cty:"server_image_description" hcl:"server_image_description"` BlockStorageSize *int `mapstructure:"block_storage_size" required:"false" cty:"block_storage_size" hcl:"block_storage_size"` AccessControlGroupNo *string `mapstructure:"access_control_group_no" required:"false" cty:"access_control_group_no" hcl:"access_control_group_no"` UserData *string `mapstructure:"user_data" required:"false" cty:"user_data" hcl:"user_data"` UserDataFile *string `mapstructure:"user_data_file" required:"false" cty:"user_data_file" hcl:"user_data_file"` Region *string `mapstructure:"region" required:"false" cty:"region" hcl:"region"` RegionCode *string `mapstructure:"region_code" required:"false" cty:"region_code" hcl:"region_code"` Site *string `mapstructure:"site" required:"false" cty:"site" hcl:"site"` Type *string `mapstructure:"communicator" cty:"communicator" hcl:"communicator"` PauseBeforeConnect *string `mapstructure:"pause_before_connecting" cty:"pause_before_connecting" hcl:"pause_before_connecting"` SSHHost *string `mapstructure:"ssh_host" cty:"ssh_host" hcl:"ssh_host"` SSHPort *int `mapstructure:"ssh_port" cty:"ssh_port" hcl:"ssh_port"` SSHUsername *string `mapstructure:"ssh_username" cty:"ssh_username" hcl:"ssh_username"` SSHPassword *string `mapstructure:"ssh_password" cty:"ssh_password" hcl:"ssh_password"` SSHKeyPairName *string `mapstructure:"ssh_keypair_name" undocumented:"true" cty:"ssh_keypair_name" hcl:"ssh_keypair_name"` SSHTemporaryKeyPairName *string `mapstructure:"temporary_key_pair_name" undocumented:"true" cty:"temporary_key_pair_name" hcl:"temporary_key_pair_name"` SSHTemporaryKeyPairType *string `mapstructure:"temporary_key_pair_type" cty:"temporary_key_pair_type" hcl:"temporary_key_pair_type"` SSHTemporaryKeyPairBits *int `mapstructure:"temporary_key_pair_bits" cty:"temporary_key_pair_bits" hcl:"temporary_key_pair_bits"` SSHCiphers []string `mapstructure:"ssh_ciphers" cty:"ssh_ciphers" hcl:"ssh_ciphers"` SSHClearAuthorizedKeys *bool `mapstructure:"ssh_clear_authorized_keys" cty:"ssh_clear_authorized_keys" hcl:"ssh_clear_authorized_keys"` SSHKEXAlgos []string `mapstructure:"ssh_key_exchange_algorithms" cty:"ssh_key_exchange_algorithms" hcl:"ssh_key_exchange_algorithms"` SSHPrivateKeyFile *string `mapstructure:"ssh_private_key_file" undocumented:"true" cty:"ssh_private_key_file" hcl:"ssh_private_key_file"` SSHCertificateFile *string `mapstructure:"ssh_certificate_file" cty:"ssh_certificate_file" hcl:"ssh_certificate_file"` SSHPty *bool `mapstructure:"ssh_pty" cty:"ssh_pty" hcl:"ssh_pty"` SSHTimeout *string `mapstructure:"ssh_timeout" cty:"ssh_timeout" hcl:"ssh_timeout"` SSHWaitTimeout *string `mapstructure:"ssh_wait_timeout" undocumented:"true" cty:"ssh_wait_timeout" hcl:"ssh_wait_timeout"` SSHAgentAuth *bool `mapstructure:"ssh_agent_auth" undocumented:"true" cty:"ssh_agent_auth" hcl:"ssh_agent_auth"` SSHDisableAgentForwarding *bool `mapstructure:"ssh_disable_agent_forwarding" cty:"ssh_disable_agent_forwarding" hcl:"ssh_disable_agent_forwarding"` SSHHandshakeAttempts *int `mapstructure:"ssh_handshake_attempts" cty:"ssh_handshake_attempts" hcl:"ssh_handshake_attempts"` SSHBastionHost *string `mapstructure:"ssh_bastion_host" cty:"ssh_bastion_host" hcl:"ssh_bastion_host"` SSHBastionPort *int `mapstructure:"ssh_bastion_port" cty:"ssh_bastion_port" hcl:"ssh_bastion_port"` SSHBastionAgentAuth *bool `mapstructure:"ssh_bastion_agent_auth" cty:"ssh_bastion_agent_auth" hcl:"ssh_bastion_agent_auth"` SSHBastionUsername *string `mapstructure:"ssh_bastion_username" cty:"ssh_bastion_username" hcl:"ssh_bastion_username"` SSHBastionPassword *string `mapstructure:"ssh_bastion_password" cty:"ssh_bastion_password" hcl:"ssh_bastion_password"` SSHBastionInteractive *bool `mapstructure:"ssh_bastion_interactive" cty:"ssh_bastion_interactive" hcl:"ssh_bastion_interactive"` SSHBastionPrivateKeyFile *string `mapstructure:"ssh_bastion_private_key_file" cty:"ssh_bastion_private_key_file" hcl:"ssh_bastion_private_key_file"` SSHBastionCertificateFile *string `mapstructure:"ssh_bastion_certificate_file" cty:"ssh_bastion_certificate_file" hcl:"ssh_bastion_certificate_file"` SSHFileTransferMethod *string `mapstructure:"ssh_file_transfer_method" cty:"ssh_file_transfer_method" hcl:"ssh_file_transfer_method"` SSHProxyHost *string `mapstructure:"ssh_proxy_host" cty:"ssh_proxy_host" hcl:"ssh_proxy_host"` SSHProxyPort *int `mapstructure:"ssh_proxy_port" cty:"ssh_proxy_port" hcl:"ssh_proxy_port"` SSHProxyUsername *string `mapstructure:"ssh_proxy_username" cty:"ssh_proxy_username" hcl:"ssh_proxy_username"` SSHProxyPassword *string `mapstructure:"ssh_proxy_password" cty:"ssh_proxy_password" hcl:"ssh_proxy_password"` SSHKeepAliveInterval *string `mapstructure:"ssh_keep_alive_interval" cty:"ssh_keep_alive_interval" hcl:"ssh_keep_alive_interval"` SSHReadWriteTimeout *string `mapstructure:"ssh_read_write_timeout" cty:"ssh_read_write_timeout" hcl:"ssh_read_write_timeout"` SSHRemoteTunnels []string `mapstructure:"ssh_remote_tunnels" cty:"ssh_remote_tunnels" hcl:"ssh_remote_tunnels"` SSHLocalTunnels []string `mapstructure:"ssh_local_tunnels" cty:"ssh_local_tunnels" hcl:"ssh_local_tunnels"` SSHPublicKey []byte `mapstructure:"ssh_public_key" undocumented:"true" cty:"ssh_public_key" hcl:"ssh_public_key"` SSHPrivateKey []byte `mapstructure:"ssh_private_key" undocumented:"true" cty:"ssh_private_key" hcl:"ssh_private_key"` WinRMUser *string `mapstructure:"winrm_username" cty:"winrm_username" hcl:"winrm_username"` WinRMPassword *string `mapstructure:"winrm_password" cty:"winrm_password" hcl:"winrm_password"` WinRMHost *string `mapstructure:"winrm_host" cty:"winrm_host" hcl:"winrm_host"` WinRMNoProxy *bool `mapstructure:"winrm_no_proxy" cty:"winrm_no_proxy" hcl:"winrm_no_proxy"` WinRMPort *int `mapstructure:"winrm_port" cty:"winrm_port" hcl:"winrm_port"` WinRMTimeout *string `mapstructure:"winrm_timeout" cty:"winrm_timeout" hcl:"winrm_timeout"` WinRMUseSSL *bool `mapstructure:"winrm_use_ssl" cty:"winrm_use_ssl" hcl:"winrm_use_ssl"` WinRMInsecure *bool `mapstructure:"winrm_insecure" cty:"winrm_insecure" hcl:"winrm_insecure"` WinRMUseNTLM *bool `mapstructure:"winrm_use_ntlm" cty:"winrm_use_ntlm" hcl:"winrm_use_ntlm"` }
FlatConfig is an auto-generated flat version of Config. Where the contents of a field with a `mapstructure:,squash` tag are bubbled up.
type InitScript ¶
type NcloudAPIClient ¶
type NcloudAPIClient struct {
// contains filtered or unexported fields
}
type StepCreateAccessControlGroup ¶
type StepCreateAccessControlGroup struct { Conn *NcloudAPIClient GetAccessControlGroup func(acgNo string) (*vserver.AccessControlGroup, error) CreateAccessControlGroup func() (string, error) AddAccessControlGroupRule func(acgNo string) error Say func(message string) Error func(e error) Config *Config // contains filtered or unexported fields }
func NewStepCreateAccessControlGroup ¶
func NewStepCreateAccessControlGroup(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateAccessControlGroup
func (*StepCreateAccessControlGroup) Cleanup ¶
func (s *StepCreateAccessControlGroup) Cleanup(state multistep.StateBag)
func (*StepCreateAccessControlGroup) Run ¶
func (s *StepCreateAccessControlGroup) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateBlockStorage ¶
type StepCreateBlockStorage struct { Conn *NcloudAPIClient CreateBlockStorage func(serverInstanceNo string) (*string, error) DeleteBlockStorage func(blockStorageInstanceNo string) error WaiterBlockStorageStatus func(conn *NcloudAPIClient, blockStorageInstanceNo *string, status string, timeout time.Duration) error Say func(message string) Error func(e error) Config *Config }
StepCreateBlockStorageInstance struct is for making extra block storage
func NewStepCreateBlockStorage ¶
func NewStepCreateBlockStorage(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateBlockStorage
NewStepCreateBlockStorageInstance make StepCreateBlockStorage struct to make extra block storage
func (*StepCreateBlockStorage) Cleanup ¶
func (s *StepCreateBlockStorage) Cleanup(state multistep.StateBag)
func (*StepCreateBlockStorage) Run ¶
func (s *StepCreateBlockStorage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateInitScript ¶
type StepCreateInitScript struct { Conn *NcloudAPIClient CreateInitScript func() (string, error) DeleteInitScript func(initScriptNo string) error Say func(message string) Error func(e error) Config *Config }
func NewStepCreateInitScript ¶
func NewStepCreateInitScript(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateInitScript
func (*StepCreateInitScript) Cleanup ¶
func (s *StepCreateInitScript) Cleanup(state multistep.StateBag)
func (*StepCreateInitScript) Run ¶
func (s *StepCreateInitScript) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateLoginKey ¶
type StepCreateLoginKey struct { Conn *NcloudAPIClient CreateLoginKey func() (*LoginKey, error) DeleteLoginKey func(loginKey string) error Say func(message string) Error func(e error) Config *Config }
func NewStepCreateLoginKey ¶
func NewStepCreateLoginKey(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateLoginKey
func (*StepCreateLoginKey) Cleanup ¶
func (s *StepCreateLoginKey) Cleanup(state multistep.StateBag)
func (*StepCreateLoginKey) Run ¶
func (s *StepCreateLoginKey) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreatePublicIP ¶
type StepCreatePublicIP struct { Conn *NcloudAPIClient GetPublicIP func(publicIPNo string) (*server.PublicIpInstance, error) CreatePublicIP func(serverInstanceNo string) (*server.PublicIpInstance, error) DeletePublicIp func(publicIPNo string) error WaiterAssociatePublicIPToServerInstance func(serverInstanceNo string, publicIP string) error DisassociatePublicIpFromServerInstance func(publicIPNo string) error Say func(message string) Error func(e error) Config *Config }
func NewStepCreatePublicIP ¶
func NewStepCreatePublicIP(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreatePublicIP
func (*StepCreatePublicIP) Cleanup ¶
func (s *StepCreatePublicIP) Cleanup(state multistep.StateBag)
func (*StepCreatePublicIP) Run ¶
func (s *StepCreatePublicIP) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateServerImage ¶
type StepCreateServerImage struct { Conn *NcloudAPIClient CreateServerImage func(serverInstanceNo string) (*server.MemberServerImage, error) Say func(message string) Error func(e error) Config *Config }
func NewStepCreateServerImage ¶
func NewStepCreateServerImage(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateServerImage
func (*StepCreateServerImage) Cleanup ¶
func (*StepCreateServerImage) Cleanup(multistep.StateBag)
func (*StepCreateServerImage) Run ¶
func (s *StepCreateServerImage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateServerInstance ¶
type StepCreateServerInstance struct { Conn *NcloudAPIClient CreateServerInstance func(loginKeyName string, feeSystemTypeCode string, state multistep.StateBag) (string, error) GetServerInstance func() (string, string, error) WaiterServerInstanceStatus func(conn *NcloudAPIClient, serverInstanceNo string, status string, timeout time.Duration) error Say func(message string) Error func(e error) Config *Config // contains filtered or unexported fields }
func NewStepCreateServerInstance ¶
func NewStepCreateServerInstance(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepCreateServerInstance
func (*StepCreateServerInstance) Cleanup ¶
func (s *StepCreateServerInstance) Cleanup(state multistep.StateBag)
func (*StepCreateServerInstance) Run ¶
func (s *StepCreateServerInstance) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepDeleteBlockStorage ¶
type StepDeleteBlockStorage struct { Conn *NcloudAPIClient DeleteBlockStorage func(blockStorageNo string) error Say func(message string) Error func(e error) Config *Config }
func NewStepDeleteBlockStorage ¶
func NewStepDeleteBlockStorage(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepDeleteBlockStorage
func (*StepDeleteBlockStorage) Cleanup ¶
func (*StepDeleteBlockStorage) Cleanup(multistep.StateBag)
func (*StepDeleteBlockStorage) Run ¶
func (s *StepDeleteBlockStorage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepGetRootPassword ¶
type StepGetRootPassword struct { Conn *NcloudAPIClient GetRootPassword func(serverInstanceNo string, privateKey string) (string, error) Say func(message string) Error func(e error) Config *Config }
func NewStepGetRootPassword ¶
func NewStepGetRootPassword(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepGetRootPassword
func (*StepGetRootPassword) Cleanup ¶
func (*StepGetRootPassword) Cleanup(multistep.StateBag)
func (*StepGetRootPassword) Run ¶
func (s *StepGetRootPassword) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepStopServerInstance ¶
type StepStopServerInstance struct { Conn *NcloudAPIClient StopServerInstance func(serverInstanceNo string) error WaiterServerInstanceStatus func(conn *NcloudAPIClient, serverInstanceNo string, status string, timeout time.Duration) error Say func(message string) Error func(e error) Config *Config }
func NewStepStopServerInstance ¶
func NewStepStopServerInstance(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepStopServerInstance
func (*StepStopServerInstance) Cleanup ¶
func (*StepStopServerInstance) Cleanup(multistep.StateBag)
func (*StepStopServerInstance) Run ¶
func (s *StepStopServerInstance) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepTerminateServerInstance ¶
type StepTerminateServerInstance struct { Conn *NcloudAPIClient TerminateServerInstance func(serverInstanceNo string) error Say func(message string) Error func(e error) Config *Config }
func NewStepTerminateServerInstance ¶
func NewStepTerminateServerInstance(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepTerminateServerInstance
func (*StepTerminateServerInstance) Cleanup ¶
func (*StepTerminateServerInstance) Cleanup(multistep.StateBag)
func (*StepTerminateServerInstance) Run ¶
func (s *StepTerminateServerInstance) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepValidateTemplate ¶
type StepValidateTemplate struct { Conn *NcloudAPIClient Validate func() error Say func(message string) Error func(e error) Config *Config FeeSystemTypeCode string // contains filtered or unexported fields }
StepValidateTemplate : struct for Validation a template
func NewStepValidateTemplate ¶
func NewStepValidateTemplate(conn *NcloudAPIClient, ui packersdk.Ui, config *Config) *StepValidateTemplate
NewStepValidateTemplate : function for Validation a template
func (*StepValidateTemplate) Cleanup ¶
func (s *StepValidateTemplate) Cleanup(multistep.StateBag)
Cleanup : cleanup on error
func (*StepValidateTemplate) Run ¶
func (s *StepValidateTemplate) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
Run : main function for validation a template
Source Files ¶
- artifact.go
- builder.go
- config.go
- config.hcl2spec.go
- step.go
- step_create_access_control_group.go
- step_create_block_storage_instance.go
- step_create_init_script.go
- step_create_login_key.go
- step_create_public_ip_instance.go
- step_create_server_image.go
- step_create_server_instance.go
- step_delete_block_storage_instance.go
- step_get_rootpassword.go
- step_stop_server_instance.go
- step_terminate_server_instance.go
- step_validate_template.go
- waiter_block_storage_instance.go
- waiter_server_image_status.go
- waiter_server_instance_status.go