Skip to content

Commit

Permalink
azure: enable CustomData if the userdata has cloud-init format
Browse files Browse the repository at this point in the history
Co-authored-by: Jeremi Piotrowski <jpiotrowski@microsoft.com>
Signed-off-by: Adrian Vladu <avladu@cloudbasesolutions.com>
  • Loading branch information
ader1990 and jepio committed Aug 7, 2024
1 parent efb24b1 commit 36fd39d
Show file tree
Hide file tree
Showing 2 changed files with 7 additions and 6 deletions.
11 changes: 6 additions & 5 deletions platform/api/azure/instance.go
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@ import (
"github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/compute/armcompute/v5"
"github.com/Azure/azure-sdk-for-go/sdk/resourcemanager/network/armnetwork/v5"

"github.com/flatcar/mantle/platform/conf"
"github.com/flatcar/mantle/util"
)

Expand All @@ -52,7 +53,7 @@ func (a *API) getVMRG(rg string) string {
return vmrg
}

func (a *API) getVMParameters(name, userdata, sshkey, storageAccountURI string, ip *armnetwork.PublicIPAddress, nic *armnetwork.Interface) armcompute.VirtualMachine {
func (a *API) getVMParameters(name, sshkey, storageAccountURI string, userdata *conf.Conf, ip *armnetwork.PublicIPAddress, nic *armnetwork.Interface) armcompute.VirtualMachine {
osProfile := armcompute.OSProfile{
AdminUsername: to.Ptr("core"),
ComputerName: &name,
Expand All @@ -69,7 +70,7 @@ func (a *API) getVMParameters(name, userdata, sshkey, storageAccountURI string,
}

// Encode userdata to base64.
ud := base64.StdEncoding.EncodeToString([]byte(userdata))
ud := base64.StdEncoding.EncodeToString(userdata.Bytes())

var imgRef *armcompute.ImageReference
var plan *armcompute.Plan
Expand Down Expand Up @@ -180,7 +181,7 @@ func (a *API) getVMParameters(name, userdata, sshkey, storageAccountURI string,
// I don't think it would be an issue to have empty user-data set but better
// to be safe than sorry.
if ud != "" {
if a.Opts.UseUserData {
if a.Opts.UseUserData && (userdata.IsIgnition() || userdata.IsEmpty()) {
plog.Infof("using user-data")
vm.Properties.UserData = &ud
} else {
Expand All @@ -197,7 +198,7 @@ func (a *API) getVMParameters(name, userdata, sshkey, storageAccountURI string,
return vm
}

func (a *API) CreateInstance(name, userdata, sshkey, resourceGroup, storageAccount string, network Network) (*Machine, error) {
func (a *API) CreateInstance(name, sshkey, resourceGroup, storageAccount string, userdata *conf.Conf, network Network) (*Machine, error) {
// only VMs are created in the user supplied resource group, kola still manages a resource group
// for the gallery and storage account.
vmResourceGroup := a.getVMRG(resourceGroup)
Expand All @@ -219,7 +220,7 @@ func (a *API) CreateInstance(name, userdata, sshkey, resourceGroup, storageAccou
return nil, fmt.Errorf("couldn't get NIC name")
}

vmParams := a.getVMParameters(name, userdata, sshkey, fmt.Sprintf("https://%s.blob.core.windows.net/", storageAccount), ip, nic)
vmParams := a.getVMParameters(name, sshkey, fmt.Sprintf("https://%s.blob.core.windows.net/", storageAccount), userdata, ip, nic)
plog.Infof("Creating Instance %s", name)

clean := func() {
Expand Down
2 changes: 1 addition & 1 deletion platform/machine/azure/cluster.go
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ func (ac *cluster) NewMachine(userdata *conf.UserData) (platform.Machine, error)
return nil, err
}

instance, err := ac.flight.Api.CreateInstance(ac.vmname(), conf.String(), ac.sshKey, ac.ResourceGroup, ac.StorageAccount, ac.Network)
instance, err := ac.flight.Api.CreateInstance(ac.vmname(), ac.sshKey, ac.ResourceGroup, ac.StorageAccount, conf, ac.Network)
if err != nil {
return nil, err
}
Expand Down

0 comments on commit 36fd39d

Please sign in to comment.