Documentation ¶
Index ¶
- Constants
- Variables
- func GetKeyVaultDeployment(config *Config) (*resources.Deployment, error)
- func GetVirtualMachineDeployment(config *Config) (*resources.Deployment, error)
- type AdditionalDiskArtifact
- type Artifact
- type Authenticate
- type AzureClient
- type Builder
- type CaptureBootDiagnostics
- type CaptureDiagnosticProfile
- type CaptureDisk
- type CaptureHardwareProfile
- type CaptureNetworkInterface
- type CaptureNetworkProfile
- type CaptureOSProfile
- type CaptureOperation
- type CaptureOperationProperties
- type CaptureProperties
- type CaptureResources
- type CaptureStorageProfile
- type CaptureTemplate
- type CaptureTemplateParameter
- type CaptureUri
- type Config
- type EndpointType
- type OpenSshKeyPair
- type PlanInformation
- type SharedImageGallery
- type StepCaptureImage
- type StepCreateResourceGroup
- type StepDeleteAdditionalDisk
- type StepDeleteOSDisk
- type StepDeleteResourceGroup
- type StepDeployTemplate
- type StepGetCertificate
- type StepGetDataDisk
- type StepGetIPAddress
- type StepGetOSDisk
- type StepPowerOffCompute
- type StepSaveWinRMPassword
- type StepSetCertificate
- type StepValidateTemplate
- type TempName
Constants ¶
View Source
const ( DefaultSasBlobContainer = "system/Microsoft.Compute" DefaultSecretName = "packerKeyVaultSecret" )
View Source
const ( DefaultCloudEnvironmentName = "Public" DefaultImageVersion = "latest" DefaultUserName = "packer" DefaultPrivateVirtualNetworkWithPublicIp = false DefaultVMSize = "Standard_A1" )
View Source
const (
BuilderId = "Azure.ResourceManagement.VMImage"
)
View Source
const (
EnvPackerLogAzureMaxLen = "PACKER_LOG_AZURE_MAXLEN"
)
View Source
const (
KeySize = 2048
)
Variables ¶
View Source
var ( EndpointCommunicationText = map[EndpointType]string{ PublicEndpoint: "PublicEndpoint", PrivateEndpoint: "PrivateEndpoint", PublicEndpointInPrivateNetwork: "PublicEndpointInPrivateNetwork", } )
View Source
var TemplateFuncs = template.FuncMap{
"clean_image_name": templateCleanImageName,
}
Functions ¶
func GetKeyVaultDeployment ¶
func GetKeyVaultDeployment(config *Config) (*resources.Deployment, error)
func GetVirtualMachineDeployment ¶
func GetVirtualMachineDeployment(config *Config) (*resources.Deployment, error)
Types ¶
type AdditionalDiskArtifact ¶
type Artifact ¶
type Artifact struct { // OS type: Linux, Windows OSType string // VHD StorageAccountLocation string OSDiskUri string TemplateUri string OSDiskUriReadOnlySas string TemplateUriReadOnlySas string // Managed Image ManagedImageResourceGroupName string ManagedImageName string ManagedImageLocation string ManagedImageId string // Additional Disks AdditionalDisks *[]AdditionalDiskArtifact }
func NewArtifact ¶
func NewManagedImageArtifact ¶
type Authenticate ¶
type Authenticate struct {
// contains filtered or unexported fields
}
func NewAuthenticate ¶
func NewAuthenticate(env azure.Environment, clientID, clientSecret, tenantID string) *Authenticate
type AzureClient ¶
type AzureClient struct { storage.BlobStorageClient resources.DeploymentsClient resources.DeploymentOperationsClient resources.GroupsClient network.PublicIPAddressesClient network.InterfacesClient network.SubnetsClient network.VirtualNetworksClient compute.ImagesClient compute.VirtualMachinesClient common.VaultClient armStorage.AccountsClient compute.DisksClient InspectorMaxLength int Template *CaptureTemplate LastError azureErrorResponse VaultClientDelete common.VaultClient }
func NewAzureClient ¶
func NewAzureClient(subscriptionID, resourceGroupName, storageAccountName string, cloud *azure.Environment, servicePrincipalToken, servicePrincipalTokenVault *adal.ServicePrincipalToken) (*AzureClient, error)
type CaptureBootDiagnostics ¶
type CaptureBootDiagnostics struct {
Enabled bool `json:"enabled"`
}
type CaptureDiagnosticProfile ¶
type CaptureDiagnosticProfile struct {
BootDiagnostics CaptureBootDiagnostics `json:"bootDiagnostics"`
}
type CaptureDisk ¶
type CaptureDisk struct { OSType string `json:"osType"` Name string `json:"name"` Image CaptureUri `json:"image"` Vhd CaptureUri `json:"vhd"` CreateOption string `json:"createOption"` Caching string `json:"caching"` }
type CaptureHardwareProfile ¶
type CaptureHardwareProfile struct {
VMSize string `json:"vmSize"`
}
type CaptureNetworkInterface ¶
type CaptureNetworkInterface struct {
Id string `json:"id"`
}
type CaptureNetworkProfile ¶
type CaptureNetworkProfile struct {
NetworkInterfaces []CaptureNetworkInterface `json:"networkInterfaces"`
}
type CaptureOSProfile ¶
type CaptureOperation ¶
type CaptureOperation struct { OperationId string `json:"operationId"` Status string `json:"status"` Properties *CaptureOperationProperties `json:"properties"` }
type CaptureOperationProperties ¶
type CaptureOperationProperties struct {
Output *CaptureTemplate `json:"output"`
}
type CaptureProperties ¶
type CaptureProperties struct { HardwareProfile CaptureHardwareProfile `json:"hardwareProfile"` StorageProfile CaptureStorageProfile `json:"storageProfile"` OSProfile CaptureOSProfile `json:"osProfile"` NetworkProfile CaptureNetworkProfile `json:"networkProfile"` DiagnosticsProfile CaptureDiagnosticProfile `json:"diagnosticsProfile"` ProvisioningState int `json:"provisioningState"` }
type CaptureResources ¶
type CaptureResources struct { ApiVersion string `json:"apiVersion"` Name string `json:"name"` Type string `json:"type"` Location string `json:"location"` Properties CaptureProperties `json:"properties"` }
type CaptureStorageProfile ¶
type CaptureStorageProfile struct { OSDisk CaptureDisk `json:"osDisk"` DataDisks []CaptureDisk `json:"dataDisks"` }
type CaptureTemplate ¶
type CaptureTemplate struct { Schema string `json:"$schema"` ContentVersion string `json:"contentVersion"` Parameters map[string]CaptureTemplateParameter `json:"parameters"` Resources []CaptureResources `json:"resources"` }
type CaptureUri ¶
type CaptureUri struct {
Uri string `json:"uri"`
}
type Config ¶
type Config struct { common.PackerConfig `mapstructure:",squash"` // Authentication via OAUTH ClientID string `mapstructure:"client_id"` ClientSecret string `mapstructure:"client_secret"` ObjectID string `mapstructure:"object_id"` TenantID string `mapstructure:"tenant_id"` SubscriptionID string `mapstructure:"subscription_id"` // Capture CaptureNamePrefix string `mapstructure:"capture_name_prefix"` CaptureContainerName string `mapstructure:"capture_container_name"` SharedGallery SharedImageGallery `mapstructure:"shared_image_gallery"` // Compute ImagePublisher string `mapstructure:"image_publisher"` ImageOffer string `mapstructure:"image_offer"` ImageSku string `mapstructure:"image_sku"` ImageVersion string `mapstructure:"image_version"` ImageUrl string `mapstructure:"image_url"` CustomManagedImageResourceGroupName string `mapstructure:"custom_managed_image_resource_group_name"` CustomManagedImageName string `mapstructure:"custom_managed_image_name"` Location string `mapstructure:"location"` VMSize string `mapstructure:"vm_size"` ManagedImageResourceGroupName string `mapstructure:"managed_image_resource_group_name"` ManagedImageName string `mapstructure:"managed_image_name"` ManagedImageStorageAccountType string `mapstructure:"managed_image_storage_account_type"` // Deployment AzureTags map[string]*string `mapstructure:"azure_tags"` ResourceGroupName string `mapstructure:"resource_group_name"` StorageAccount string `mapstructure:"storage_account"` TempComputeName string `mapstructure:"temp_compute_name"` TempResourceGroupName string `mapstructure:"temp_resource_group_name"` BuildResourceGroupName string `mapstructure:"build_resource_group_name"` CloudEnvironmentName string `mapstructure:"cloud_environment_name"` PrivateVirtualNetworkWithPublicIp bool `mapstructure:"private_virtual_network_with_public_ip"` VirtualNetworkName string `mapstructure:"virtual_network_name"` VirtualNetworkSubnetName string `mapstructure:"virtual_network_subnet_name"` VirtualNetworkResourceGroupName string `mapstructure:"virtual_network_resource_group_name"` CustomDataFile string `mapstructure:"custom_data_file"` PlanInfo PlanInformation `mapstructure:"plan_info"` // OS OSType string `mapstructure:"os_type"` OSDiskSizeGB int32 `mapstructure:"os_disk_size_gb"` // Additional Disks AdditionalDiskSize []int32 `mapstructure:"disk_additional_size"` // Runtime Values UserName string Password string Comm communicator.Config `mapstructure:",squash"` //Cleanup AsyncResourceGroupDelete bool `mapstructure:"async_resourcegroup_delete"` // contains filtered or unexported fields }
type EndpointType ¶
type EndpointType int
const ( PublicEndpoint EndpointType = iota PrivateEndpoint PublicEndpointInPrivateNetwork )
type OpenSshKeyPair ¶
type OpenSshKeyPair struct {
// contains filtered or unexported fields
}
func NewOpenSshKeyPair ¶
func NewOpenSshKeyPair() (*OpenSshKeyPair, error)
func NewOpenSshKeyPairWithSize ¶
func NewOpenSshKeyPairWithSize(keySize int) (*OpenSshKeyPair, error)
func (*OpenSshKeyPair) AuthorizedKey ¶
func (s *OpenSshKeyPair) AuthorizedKey() string
func (*OpenSshKeyPair) PrivateKey ¶
func (s *OpenSshKeyPair) PrivateKey() []byte
type PlanInformation ¶
type SharedImageGallery ¶
type SharedImageGallery struct {}
type StepCaptureImage ¶
type StepCaptureImage struct {
// contains filtered or unexported fields
}
func NewStepCaptureImage ¶
func NewStepCaptureImage(client *AzureClient, ui packer.Ui) *StepCaptureImage
func (*StepCaptureImage) Cleanup ¶
func (*StepCaptureImage) Cleanup(multistep.StateBag)
func (*StepCaptureImage) Run ¶
func (s *StepCaptureImage) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepCreateResourceGroup ¶
type StepCreateResourceGroup struct {
// contains filtered or unexported fields
}
func NewStepCreateResourceGroup ¶
func NewStepCreateResourceGroup(client *AzureClient, ui packer.Ui) *StepCreateResourceGroup
func (*StepCreateResourceGroup) Cleanup ¶
func (s *StepCreateResourceGroup) Cleanup(state multistep.StateBag)
func (*StepCreateResourceGroup) Run ¶
func (s *StepCreateResourceGroup) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepDeleteAdditionalDisk ¶
type StepDeleteAdditionalDisk struct {
// contains filtered or unexported fields
}
func NewStepDeleteAdditionalDisks ¶
func NewStepDeleteAdditionalDisks(client *AzureClient, ui packer.Ui) *StepDeleteAdditionalDisk
func (*StepDeleteAdditionalDisk) Cleanup ¶
func (*StepDeleteAdditionalDisk) Cleanup(multistep.StateBag)
func (*StepDeleteAdditionalDisk) Run ¶
func (s *StepDeleteAdditionalDisk) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepDeleteOSDisk ¶
type StepDeleteOSDisk struct {
// contains filtered or unexported fields
}
func NewStepDeleteOSDisk ¶
func NewStepDeleteOSDisk(client *AzureClient, ui packer.Ui) *StepDeleteOSDisk
func (*StepDeleteOSDisk) Cleanup ¶
func (*StepDeleteOSDisk) Cleanup(multistep.StateBag)
func (*StepDeleteOSDisk) Run ¶
func (s *StepDeleteOSDisk) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepDeleteResourceGroup ¶
type StepDeleteResourceGroup struct {
// contains filtered or unexported fields
}
func NewStepDeleteResourceGroup ¶
func NewStepDeleteResourceGroup(client *AzureClient, ui packer.Ui) *StepDeleteResourceGroup
func (*StepDeleteResourceGroup) Cleanup ¶
func (*StepDeleteResourceGroup) Cleanup(multistep.StateBag)
func (*StepDeleteResourceGroup) Run ¶
func (s *StepDeleteResourceGroup) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepDeployTemplate ¶
type StepDeployTemplate struct {
// contains filtered or unexported fields
}
func NewStepDeployTemplate ¶
func NewStepDeployTemplate(client *AzureClient, ui packer.Ui, config *Config, deploymentName string, factory templateFactoryFunc) *StepDeployTemplate
func (*StepDeployTemplate) Cleanup ¶
func (s *StepDeployTemplate) Cleanup(state multistep.StateBag)
func (*StepDeployTemplate) Run ¶
func (s *StepDeployTemplate) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepGetCertificate ¶
type StepGetCertificate struct {
// contains filtered or unexported fields
}
func NewStepGetCertificate ¶
func NewStepGetCertificate(client *AzureClient, ui packer.Ui) *StepGetCertificate
func (*StepGetCertificate) Cleanup ¶
func (*StepGetCertificate) Cleanup(multistep.StateBag)
func (*StepGetCertificate) Run ¶
func (s *StepGetCertificate) Run(_ context.Context, state multistep.StateBag) multistep.StepAction
type StepGetDataDisk ¶
type StepGetDataDisk struct {
// contains filtered or unexported fields
}
func NewStepGetAdditionalDisks ¶
func NewStepGetAdditionalDisks(client *AzureClient, ui packer.Ui) *StepGetDataDisk
func (*StepGetDataDisk) Cleanup ¶
func (*StepGetDataDisk) Cleanup(multistep.StateBag)
func (*StepGetDataDisk) Run ¶
func (s *StepGetDataDisk) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepGetIPAddress ¶
type StepGetIPAddress struct {
// contains filtered or unexported fields
}
func NewStepGetIPAddress ¶
func NewStepGetIPAddress(client *AzureClient, ui packer.Ui, endpoint EndpointType) *StepGetIPAddress
func (*StepGetIPAddress) Cleanup ¶
func (*StepGetIPAddress) Cleanup(multistep.StateBag)
func (*StepGetIPAddress) Run ¶
func (s *StepGetIPAddress) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepGetOSDisk ¶
type StepGetOSDisk struct {
// contains filtered or unexported fields
}
func NewStepGetOSDisk ¶
func NewStepGetOSDisk(client *AzureClient, ui packer.Ui) *StepGetOSDisk
func (*StepGetOSDisk) Cleanup ¶
func (*StepGetOSDisk) Cleanup(multistep.StateBag)
func (*StepGetOSDisk) Run ¶
func (s *StepGetOSDisk) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepPowerOffCompute ¶
type StepPowerOffCompute struct {
// contains filtered or unexported fields
}
func NewStepPowerOffCompute ¶
func NewStepPowerOffCompute(client *AzureClient, ui packer.Ui) *StepPowerOffCompute
func (*StepPowerOffCompute) Cleanup ¶
func (*StepPowerOffCompute) Cleanup(multistep.StateBag)
func (*StepPowerOffCompute) Run ¶
func (s *StepPowerOffCompute) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type StepSaveWinRMPassword ¶
func (*StepSaveWinRMPassword) Cleanup ¶
func (s *StepSaveWinRMPassword) Cleanup(multistep.StateBag)
func (*StepSaveWinRMPassword) Run ¶
func (s *StepSaveWinRMPassword) Run(_ context.Context, state multistep.StateBag) multistep.StepAction
type StepSetCertificate ¶
type StepSetCertificate struct {
// contains filtered or unexported fields
}
func NewStepSetCertificate ¶
func NewStepSetCertificate(config *Config, ui packer.Ui) *StepSetCertificate
func (*StepSetCertificate) Cleanup ¶
func (*StepSetCertificate) Cleanup(multistep.StateBag)
func (*StepSetCertificate) Run ¶
func (s *StepSetCertificate) Run(_ context.Context, state multistep.StateBag) multistep.StepAction
type StepValidateTemplate ¶
type StepValidateTemplate struct {
// contains filtered or unexported fields
}
func NewStepValidateTemplate ¶
func NewStepValidateTemplate(client *AzureClient, ui packer.Ui, config *Config, factory templateFactoryFunc) *StepValidateTemplate
func (*StepValidateTemplate) Cleanup ¶
func (*StepValidateTemplate) Cleanup(multistep.StateBag)
func (*StepValidateTemplate) Run ¶
func (s *StepValidateTemplate) Run(ctx context.Context, state multistep.StateBag) multistep.StepAction
type TempName ¶
type TempName struct { AdminPassword string CertificatePassword string ComputeName string DeploymentName string KeyVaultName string ResourceGroupName string OSDiskName string NicName string SubnetName string PublicIPAddressName string VirtualNetworkName string }
func NewTempName ¶
func NewTempName() *TempName
Source Files ¶
- artifact.go
- authenticate.go
- azure_client.go
- azure_error_response.go
- builder.go
- capture_template.go
- config.go
- config_retriever.go
- inspector.go
- openssh_key_pair.go
- resource_resolver.go
- step.go
- step_capture_image.go
- step_create_resource_group.go
- step_delete_additional_disks.go
- step_delete_os_disk.go
- step_delete_resource_group.go
- step_deploy_template.go
- step_get_additional_disks.go
- step_get_certificate.go
- step_get_ip_address.go
- step_get_os_disk.go
- step_power_off_compute.go
- step_save_winrm_password.go
- step_set_certificate.go
- step_validate_template.go
- template_factory.go
- template_funcs.go
- tempname.go
Click to show internal directories.
Click to hide internal directories.