2017-09-13 14:09:48 +02:00
|
|
|
// +build go1.7
|
|
|
|
|
2017-08-05 20:30:20 +02:00
|
|
|
package vmutils
|
|
|
|
|
2017-10-01 10:13:39 +02:00
|
|
|
// Copyright 2017 Microsoft Corporation
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2017-08-05 20:30:20 +02:00
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
|
|
|
vm "github.com/Azure/azure-sdk-for-go/management/virtualmachine"
|
|
|
|
)
|
|
|
|
|
|
|
|
// ConfigureDeploymentFromRemoteImage configures VM Role to deploy from a remote
|
|
|
|
// image source. "remoteImageSourceURL" can be any publically accessible URL to
|
|
|
|
// a VHD file, including but not limited to a SAS Azure Storage blob url. "os"
|
|
|
|
// needs to be either "Linux" or "Windows". "label" is optional.
|
|
|
|
func ConfigureDeploymentFromRemoteImage(
|
|
|
|
role *vm.Role,
|
|
|
|
remoteImageSourceURL string,
|
|
|
|
os string,
|
|
|
|
newDiskName string,
|
|
|
|
destinationVhdStorageURL string,
|
|
|
|
label string) error {
|
|
|
|
if role == nil {
|
|
|
|
return fmt.Errorf(errParamNotSpecified, "role")
|
|
|
|
}
|
|
|
|
|
|
|
|
role.OSVirtualHardDisk = &vm.OSVirtualHardDisk{
|
|
|
|
RemoteSourceImageLink: remoteImageSourceURL,
|
|
|
|
MediaLink: destinationVhdStorageURL,
|
|
|
|
DiskName: newDiskName,
|
|
|
|
OS: os,
|
|
|
|
DiskLabel: label,
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConfigureDeploymentFromPlatformImage configures VM Role to deploy from a
|
|
|
|
// platform image. See osimage package for methods to retrieve a list of the
|
|
|
|
// available platform images. "label" is optional.
|
|
|
|
func ConfigureDeploymentFromPlatformImage(
|
|
|
|
role *vm.Role,
|
|
|
|
imageName string,
|
|
|
|
mediaLink string,
|
|
|
|
label string) error {
|
|
|
|
if role == nil {
|
|
|
|
return fmt.Errorf(errParamNotSpecified, "role")
|
|
|
|
}
|
|
|
|
|
|
|
|
role.OSVirtualHardDisk = &vm.OSVirtualHardDisk{
|
|
|
|
SourceImageName: imageName,
|
|
|
|
MediaLink: mediaLink,
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConfigureDeploymentFromPublishedVMImage configures VM Role to deploy from
|
|
|
|
// a published (public) VM image.
|
|
|
|
func ConfigureDeploymentFromPublishedVMImage(
|
|
|
|
role *vm.Role,
|
|
|
|
vmImageName string,
|
|
|
|
mediaLocation string,
|
|
|
|
provisionGuestAgent bool) error {
|
|
|
|
if role == nil {
|
|
|
|
return fmt.Errorf(errParamNotSpecified, "role")
|
|
|
|
}
|
|
|
|
|
|
|
|
role.VMImageName = vmImageName
|
|
|
|
role.MediaLocation = mediaLocation
|
|
|
|
role.ProvisionGuestAgent = provisionGuestAgent
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConfigureDeploymentFromUserVMImage configures VM Role to deploy from a previously
|
|
|
|
// captured (user generated) VM image.
|
|
|
|
func ConfigureDeploymentFromUserVMImage(
|
|
|
|
role *vm.Role,
|
|
|
|
vmImageName string) error {
|
|
|
|
if role == nil {
|
|
|
|
return fmt.Errorf(errParamNotSpecified, "role")
|
|
|
|
}
|
|
|
|
|
|
|
|
role.VMImageName = vmImageName
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// ConfigureDeploymentFromExistingOSDisk configures VM Role to deploy from an
|
|
|
|
// existing disk. 'label' is optional.
|
|
|
|
func ConfigureDeploymentFromExistingOSDisk(role *vm.Role, osDiskName, label string) error {
|
|
|
|
role.OSVirtualHardDisk = &vm.OSVirtualHardDisk{
|
|
|
|
DiskName: osDiskName,
|
|
|
|
DiskLabel: label,
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|