finally get droplet Create() working again

Signed-off-by: Jeff Carr <jcarr@wit.com>
This commit is contained in:
Jeff Carr 2023-12-31 16:07:36 -06:00
parent 1e0773ad9e
commit 55c9d4b0c4
2 changed files with 30 additions and 12 deletions

View File

@ -46,22 +46,19 @@ func createDroplet(token, name, region, size, image string) (*godo.Droplet, erro
} }
*/ */
func (d *DigitalOcean) Create(name string, region string, size string) { func (d *DigitalOcean) Create(name string, region string, size string, image string) {
// region := "nyc1" // New York City region.
// size := "s-1vcpu-1gb" // Size of the droplet.
image := "ubuntu-20-04-x64" // Image slug for Ubuntu 20.04 (LTS) x64.
// Create a new droplet. // Create a new droplet.
droplet, err := d.createDropletNew(name, region, size, image) droplet, err := d.createDropletNew(name, region, size, image)
if err != nil { if err != nil {
log.Fatalf("Something went wrong: %s\n", err) log.Fatalf("digitalocean.Create() Something went wrong: %s\n", err)
} }
log.Printf("Created droplet ID %d with name %s\n", droplet.ID, droplet.Name) log.Infof("digitalocean.Create() droplet ID %d with name %s\n", droplet.ID, droplet.Name)
} }
// createDroplet creates a new droplet in the specified region with the given name. // createDroplet creates a new droplet in the specified region with the given name.
func (d *DigitalOcean) createDropletNew(name, region, size, image string) (*godo.Droplet, error) { func (d *DigitalOcean) createDropletNew(name, region, size, image string) (*godo.Droplet, error) {
log.Infof("digitalocean.createDropletNew() START name =", name)
// Create an OAuth2 token. // Create an OAuth2 token.
tokenSource := oauth2.StaticTokenSource(&oauth2.Token{AccessToken: d.token}) tokenSource := oauth2.StaticTokenSource(&oauth2.Token{AccessToken: d.token})
@ -72,6 +69,7 @@ func (d *DigitalOcean) createDropletNew(name, region, size, image string) (*godo
client := godo.NewClient(oauthClient) client := godo.NewClient(oauthClient)
var sshKeys []godo.DropletCreateSSHKey var sshKeys []godo.DropletCreateSSHKey
log.Info("digitalocean.createDropletNew() about to get keys. client =", client)
// Find the key by name. // Find the key by name.
for i, key := range d.sshKeys { for i, key := range d.sshKeys {
@ -101,7 +99,9 @@ func (d *DigitalOcean) createDropletNew(name, region, size, image string) (*godo
// Create the droplet. // Create the droplet.
ctx := context.TODO() ctx := context.TODO()
log.Info("digitalocean.createDropletNew() about to do client.Create(). ctx =", ctx)
newDroplet, _, err := client.Droplets.Create(ctx, createRequest) newDroplet, _, err := client.Droplets.Create(ctx, createRequest)
log.Infof("digitalocean.createDropletNew() END newDroplet =", newDroplet)
if err != nil { if err != nil {
return nil, err return nil, err
} }
@ -142,7 +142,11 @@ func InitCreateWindow() *windowCreate {
if len(region.Sizes) == 0 { if len(region.Sizes) == 0 {
log.Info("Skipping region. No available sizes region =", region.Name) log.Info("Skipping region. No available sizes region =", region.Name)
} else { } else {
myCreate.region.Add(region.Name) s := region.Name + " (" + region.Slug + ")"
if (myCreate.regionSlug == "") {
myCreate.regionSlug = region.Slug
}
myCreate.region.Add(s)
} }
} }
@ -151,7 +155,7 @@ func InitCreateWindow() *windowCreate {
log.Info("create droplet region changed to:", s) log.Info("create droplet region changed to:", s)
for _, region := range regions { for _, region := range regions {
if s == region.Name { if s == region.Name {
log.Info("Found region! slug =", region.Slug, region) log.Info("Found region! slug =", myCreate.regionSlug, region)
myCreate.regionSelected = region myCreate.regionSelected = region
log.Info("Found region! Now update all the sizes count =", len(region.Sizes)) log.Info("Found region! Now update all the sizes count =", len(region.Sizes))
for _, size := range region.Sizes { for _, size := range region.Sizes {
@ -169,6 +173,7 @@ func InitCreateWindow() *windowCreate {
size := myCreate.size.Get() size := myCreate.size.Get()
log.Info("Create() need to verify size exists in region. Digital Ocean size.Slug =", size) log.Info("Create() need to verify size exists in region. Digital Ocean size.Slug =", size)
} }
myCreate.size.Set("s-1vcpu-1gb")
myCreate.memory = gadgets.NewBasicDropdown(myCreate.grid, "Memory") myCreate.memory = gadgets.NewBasicDropdown(myCreate.grid, "Memory")
myCreate.memory.Add("1 GB") myCreate.memory.Add("1 GB")
@ -188,6 +193,11 @@ func InitCreateWindow() *windowCreate {
myCreate.UpdateSize() myCreate.UpdateSize()
} }
myCreate.image = gadgets.NewBasicCombobox(myCreate.grid, "Image")
myCreate.image.Add("debian-12-x64")
myCreate.image.Add("ubuntu-20-04-x64")
myCreate.image.Set("debian-12-x64")
// myCreate.nvme = gadgets.NewBasicCheckbox(myCreate.grid, "NVMe") // myCreate.nvme = gadgets.NewBasicCheckbox(myCreate.grid, "NVMe")
myCreate.group.NewLabel("Create Droplet") myCreate.group.NewLabel("Create Droplet")
@ -200,9 +210,15 @@ func InitCreateWindow() *windowCreate {
box.NewButton("Create", func () { box.NewButton("Create", func () {
name := myCreate.name.Get() name := myCreate.name.Get()
size := myCreate.size.Get() size := myCreate.size.Get()
region := myCreate.regionSelected.Slug region := myCreate.regionSlug
log.Info("create droplet name =", name, "region =", region, "size =", size) image := myCreate.image.Get()
myDo.Create(name, region, size) if (region == "") {
log.Info("Create() droplet name =", name, "region =", region, "size =", size, "image", image)
log.Info("Create() region lookup failed")
return
}
log.Info("Create() droplet name =", name, "region =", region, "size =", size, "image", image)
myDo.Create(name, region, size, image)
myCreate.Hide() myCreate.Hide()
}) })

View File

@ -48,11 +48,13 @@ type windowCreate struct {
grid *gui.Node grid *gui.Node
regionSelected godo.Region regionSelected godo.Region
regionSlug string
tag *gadgets.OneLiner tag *gadgets.OneLiner
name *gadgets.BasicEntry name *gadgets.BasicEntry
region *gadgets.BasicDropdown region *gadgets.BasicDropdown
size *gadgets.BasicCombobox size *gadgets.BasicCombobox
memory *gadgets.BasicDropdown memory *gadgets.BasicDropdown
image *gadgets.BasicCombobox
// nvme *gadgets.BasicCheckbox // nvme *gadgets.BasicCheckbox
} }