Documentation
¶
Index ¶
- Constants
- type Artifact
- type Builder
- type ClientEpcConfig
- type ClientEpcWrapper
- type Config
- type FlatConfig
- type KsyunEpcRunConfig
- func (c *KsyunEpcRunConfig) Check() (errors []error)
- func (c *KsyunEpcRunConfig) ExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
- func (c *KsyunEpcRunConfig) Init(ctx *interpolate.Context) []error
- func (c *KsyunEpcRunConfig) MergeExtensionSecurityGroup(config *ksyun.CommonConfig) ksyun.AfterStepRun
- func (c *KsyunEpcRunConfig) MergeExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
- func (c *KsyunEpcRunConfig) NeedExtensionNetwork() bool
- func (c *KsyunEpcRunConfig) Prepare(ctx *interpolate.Context) []error
- func (c *KsyunEpcRunConfig) PrepareExtensionSecurityGroup(config *ksyun.CommonConfig) ksyun.AfterStepRun
- func (c *KsyunEpcRunConfig) PrepareExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
- type KsyunImageConfig
Constants ¶
View Source
const BuilderId = "ksyun.epc"
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type Artifact ¶
type Artifact struct {
*ksyun.Artifact
// ksyun connection for performing API stuff.
Client *ClientEpcWrapper
}
type Builder ¶
type Builder struct {
// contains filtered or unexported fields
}
func (*Builder) ConfigSpec ¶
func (b *Builder) ConfigSpec() hcldec.ObjectSpec
type ClientEpcConfig ¶
type ClientEpcConfig struct {
ksyun.ClientConfig `mapstructure:",squash"`
// contains filtered or unexported fields
}
func (*ClientEpcConfig) EpcClient ¶
func (c *ClientEpcConfig) EpcClient(stateBag *multistep.BasicStateBag) *ClientEpcWrapper
type ClientEpcWrapper ¶
type ClientEpcWrapper struct {
*ksyun.ClientWrapper
EpcClient *epc.Epc
}
func (*ClientEpcWrapper) WaitEpcInstanceStatus ¶
type Config ¶
type Config struct {
common.PackerConfig `mapstructure:",squash"`
ClientEpcConfig `mapstructure:",squash"`
KsyunEpcRunConfig `mapstructure:",squash"`
KsyunImageConfig `mapstructure:",squash"`
// contains filtered or unexported fields
}
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"`
KsyunAccessKey *string `mapstructure:"access_key" required:"true" cty:"access_key" hcl:"access_key"`
KsyunSecretKey *string `mapstructure:"secret_key" required:"true" cty:"secret_key" hcl:"secret_key"`
KsyunRegion *string `mapstructure:"region" required:"true" cty:"region" hcl:"region"`
HostType *string `mapstructure:"host_type" required:"true" cty:"host_type" hcl:"host_type"`
Raid *string `mapstructure:"raid" required:"false" cty:"raid" hcl:"raid"`
SourceImageId *string `mapstructure:"source_image_id" required:"true" cty:"source_image_id" hcl:"source_image_id"`
NetworkInterfaceMode *string `mapstructure:"network_interface_mode" required:"false" cty:"network_interface_mode" hcl:"network_interface_mode"`
HostName *string `mapstructure:"host_name" required:"false" cty:"host_name" hcl:"host_name"`
ComputerName *string `mapstructure:"computer_name" required:"false" cty:"computer_name" hcl:"computer_name"`
HostChargeType *string `mapstructure:"host_charge_type" required:"false" cty:"host_charge_type" hcl:"host_charge_type"`
SecurityAgent *string `mapstructure:"security_agent" required:"false" cty:"security_agent" hcl:"security_agent"`
ContainerAgent *string `mapstructure:"container_agent" required:"false" cty:"container_agent" hcl:"container_agent"`
CloudMonitorAgent *string `mapstructure:"cloud_monitor_agent" required:"false" cty:"cloud_monitor_agent" hcl:"cloud_monitor_agent"`
SystemFileType *string `mapstructure:"system_file_type" required:"false" cty:"system_file_type" hcl:"system_file_type"`
DataFileType *string `mapstructure:"data_file_type" required:"false" cty:"data_file_type" hcl:"data_file_type"`
DataDiskCatalogue *string `mapstructure:"data_disk_catalogue" required:"false" cty:"data_disk_catalogue" hcl:"data_disk_catalogue"`
DataDiskCatalogueSuffix *string `mapstructure:"data_disk_catalogue_suffix" required:"false" cty:"data_disk_catalogue_suffix" hcl:"data_disk_catalogue_suffix"`
ExtensionSubnetId *string `mapstructure:"extension_subnet_id" required:"false" cty:"extension_subnet_id" hcl:"extension_subnet_id"`
ExtensionSubnetName *string `mapstructure:"extension_subnet_name" required:"false" cty:"extension_subnet_name" hcl:"extension_subnet_name"`
ExtensionSubnetCidrBlock *string `` /* 127-byte string literal not displayed */
ExtensionPrivateIpAddress *string `` /* 130-byte string literal not displayed */
ExtensionDNS1 *string `mapstructure:"extension_dns1" required:"false" cty:"extension_dns1" hcl:"extension_dns1"`
ExtensionDNS2 *string `mapstructure:"extension_dns2" required:"false" cty:"extension_dns2" hcl:"extension_dns2"`
ExtensionSecurityGroupId *string `` /* 127-byte string literal not displayed */
ExtensionSecurityGroupName *string `` /* 133-byte string literal not displayed */
TempSubnetId *string `cty:"temp_subnet_id" hcl:"temp_subnet_id"`
TempSecurityGroupId *string `cty:"temp_security_group_id" hcl:"temp_security_group_id"`
VpcId *string `mapstructure:"vpc_id" required:"false" cty:"vpc_id" hcl:"vpc_id"`
VpcName *string `mapstructure:"vpc_name" required:"false" cty:"vpc_name" hcl:"vpc_name"`
VpcCidrBlock *string `mapstructure:"vpc_cidr_block" required:"false" cty:"vpc_cidr_block" hcl:"vpc_cidr_block"`
SubnetId *string `mapstructure:"subnet_id" required:"false" cty:"subnet_id" hcl:"subnet_id"`
SubnetName *string `mapstructure:"subnet_name" required:"false" cty:"subnet_name" hcl:"subnet_name"`
DNS1 *string `mapstructure:"dns1" required:"false" cty:"dns1" hcl:"dns1"`
DNS2 *string `mapstructure:"dns2" required:"false" cty:"dns2" hcl:"dns2"`
SubnetCidrBlock *string `mapstructure:"subnet_cidr_block" required:"false" cty:"subnet_cidr_block" hcl:"subnet_cidr_block"`
AvailabilityZone *string `mapstructure:"availability_zone" required:"false" cty:"availability_zone" hcl:"availability_zone"`
SecurityGroupId *string `mapstructure:"security_group_id" required:"false" cty:"security_group_id" hcl:"security_group_id"`
SecurityGroupName *string `mapstructure:"security_group_name" required:"false" cty:"security_group_name" hcl:"security_group_name"`
PrivateIpAddress *string `mapstructure:"private_ip_address" required:"false" cty:"private_ip_address" hcl:"private_ip_address"`
AssociatePublicIpAddress *bool `` /* 127-byte string literal not displayed */
PublicIpChargeType *string `mapstructure:"public_ip_charge_type" required:"false" cty:"public_ip_charge_type" hcl:"public_ip_charge_type"`
PublicIpBandWidth *int `mapstructure:"public_ip_band_width" required:"false" cty:"public_ip_band_width" hcl:"public_ip_band_width"`
ProjectId *string `mapstructure:"project_id" required:"false" cty:"project_id" hcl:"project_id"`
RunTags map[string]string `mapstructure:"run_tags" required:"false" cty:"run_tags" hcl:"run_tags"`
RunTag []config.FlatKeyValue `mapstructure:"run_tag" required:"false" cty:"run_tag" hcl:"run_tag"`
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"`
KsyunImageName *string `mapstructure:"image_name" required:"false" cty:"image_name" hcl:"image_name"`
}
FlatConfig is an auto-generated flat version of Config. Where the contents of a field with a `mapstructure:,squash` tag are bubbled up.
type KsyunEpcRunConfig ¶
type KsyunEpcRunConfig struct {
// Machine type of epc.
// Valid Options: see the [HostType of epc information](https://docs.ksyun.com/documents/651)
HostType string `mapstructure:"host_type" required:"true"`
// Data Disk Raid level. Valid options: `Raid1`, `Raid5`, `Raid10`, `Raid50` and `SRaid0`,
// the details see the [Raid of epc information](https://docs.ksyun.com/documents/651)
Raid string `mapstructure:"raid" required:"false"`
// Source image id whose root volume will be copied and provisioned on the currently running instance.
SourceImageId string `mapstructure:"source_image_id" required:"true"`
// Network interface mode. Valid options: `bond4`, `single` and `dual`.
NetworkInterfaceMode string `mapstructure:"network_interface_mode" required:"false"`
// The name of epc host. Default value: `ksc_epc`.
HostName string `mapstructure:"host_name" required:"false"`
// The system name of this epc computer.
ComputerName string `mapstructure:"computer_name" required:"false"`
HostChargeType string `mapstructure:"host_charge_type" required:"false"`
// Security component type. Valid options: `classic` and `no`.
SecurityAgent string `mapstructure:"security_agent" required:"false"`
// Container engine component type. Valid options: `supported` and `unsupported`, Default `unsupported`.
ContainerAgent string `mapstructure:"container_agent" required:"false"`
// The monitor agent.
CloudMonitorAgent string `mapstructure:"cloud_monitor_agent" required:"false"`
// The system disk file type. Valid options: `EXT4` and `XFS`. Default `EXT4`.
SystemFileType string `mapstructure:"system_file_type" required:"false"`
// The Data disk file type. Valid options: `EXT4` and `XFS`. Default `EXT4`.
DataFileType string `mapstructure:"data_file_type" required:"false"`
// The catalogue of data disk. Valid options: `/DATA/disk` and `/data`. Default `/data`.
DataDiskCatalogue string `mapstructure:"data_disk_catalogue" required:"false"`
// The suffix of data disk catalogue.
// `NoSuffix`: creating data disk catalogue without suffix, but it's valid, when there is one data disk.
// `NaturalNumber`: creating data disk catalogue with suffix that increment from 1.
// `NaturalNumberFromZero`: creating data disk catalogue with suffix that increment from 0.
// Valid options: `NoSuffix`, `NaturalNumber` and `NaturalNumberFromZero`.
// Default `NaturalNumber`
DataDiskCatalogueSuffix string `mapstructure:"data_disk_catalogue_suffix" required:"false"`
// The subnet id of secondary network interface
ExtensionSubnetId string `mapstructure:"extension_subnet_id" required:"false"`
// The subnet name of secondary network interface
ExtensionSubnetName string `mapstructure:"extension_subnet_name" required:"false"`
// The subnet cidr block of secondary network interface.
ExtensionSubnetCidrBlock string `mapstructure:"extension_subnet_cidr_block" required:"false"`
// The private ip address under the vpc of secondary network interface.
ExtensionPrivateIpAddress string `mapstructure:"extension_private_ip_address" required:"false"`
// The address of first dns server.
ExtensionDNS1 string `mapstructure:"extension_dns1" required:"false"`
// The address of second dns server.
ExtensionDNS2 string `mapstructure:"extension_dns2" required:"false"`
ExtensionSecurityGroupId string `mapstructure:"extension_security_group_id" required:"false"`
ExtensionSecurityGroupName string `mapstructure:"extension_security_group_name" required:"false"`
// The temporary subnet id.
TempSubnetId string
// The temporary security group id.
TempSecurityGroupId string
ksyun.CommonConfig `mapstructure:",squash"`
}
func (*KsyunEpcRunConfig) Check ¶
func (c *KsyunEpcRunConfig) Check() (errors []error)
func (*KsyunEpcRunConfig) ExtensionSubnet ¶
func (c *KsyunEpcRunConfig) ExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
func (*KsyunEpcRunConfig) Init ¶
func (c *KsyunEpcRunConfig) Init(ctx *interpolate.Context) []error
func (*KsyunEpcRunConfig) MergeExtensionSecurityGroup ¶
func (c *KsyunEpcRunConfig) MergeExtensionSecurityGroup(config *ksyun.CommonConfig) ksyun.AfterStepRun
func (*KsyunEpcRunConfig) MergeExtensionSubnet ¶
func (c *KsyunEpcRunConfig) MergeExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
func (*KsyunEpcRunConfig) NeedExtensionNetwork ¶
func (c *KsyunEpcRunConfig) NeedExtensionNetwork() bool
func (*KsyunEpcRunConfig) Prepare ¶
func (c *KsyunEpcRunConfig) Prepare(ctx *interpolate.Context) []error
func (*KsyunEpcRunConfig) PrepareExtensionSecurityGroup ¶
func (c *KsyunEpcRunConfig) PrepareExtensionSecurityGroup(config *ksyun.CommonConfig) ksyun.AfterStepRun
func (*KsyunEpcRunConfig) PrepareExtensionSubnet ¶
func (c *KsyunEpcRunConfig) PrepareExtensionSubnet(config *ksyun.CommonConfig) ksyun.AfterStepRun
type KsyunImageConfig ¶
type KsyunImageConfig struct {
// The name of the user-defined image, [2, 64] English or Chinese
// characters. It must begin with an uppercase/lowercase letter or a
// Chinese character, and may contain numbers, `_` or `-`. It cannot begin
// with `http://` or `https://`.
KsyunImageName string `mapstructure:"image_name" required:"false"`
}
func (*KsyunImageConfig) Prepare ¶
func (c *KsyunImageConfig) Prepare(ctx *interpolate.Context) []error
Click to show internal directories.
Click to hide internal directories.