Skip to content

Commit

Permalink
Updated envs up/down to use intent workflows
Browse files Browse the repository at this point in the history
  • Loading branch information
BSick7 committed Jun 20, 2024
1 parent 0f9f64b commit 061b5d5
Show file tree
Hide file tree
Showing 6 changed files with 103 additions and 66 deletions.
63 changes: 6 additions & 57 deletions cmd/envs.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ import (
"gopkg.in/nullstone-io/go-api-client.v0"
"gopkg.in/nullstone-io/go-api-client.v0/find"
"gopkg.in/nullstone-io/go-api-client.v0/types"
"gopkg.in/nullstone-io/nullstone.v0/runs"
"math"
"os"
"regexp"
Expand Down Expand Up @@ -372,11 +371,6 @@ func createEnvRun(c *cli.Context, cfg api.Config, isDestroy bool) error {
stackName := c.String("stack")
envName := c.String("env")

action := "launch"
if isDestroy {
action = "destroy"
}

stack, err := client.StacksByName().Get(ctx, stackName)
if err != nil {
return fmt.Errorf("error looking for stack %q: %w", stackName, err)
Expand All @@ -391,56 +385,11 @@ func createEnvRun(c *cli.Context, cfg api.Config, isDestroy bool) error {
return fmt.Errorf("environment %q does not exist in stack %d", envName, stack.Id)
}

body := types.CreateEnvRunInput{IsDestroy: isDestroy}
newRuns, err := client.EnvRuns().Create(ctx, stack.Id, env.Id, body)
if err != nil {
return fmt.Errorf("error creating run: %w", err)
}

if len(newRuns) <= 0 {
fmt.Fprintf(os.Stdout, "no runs created to %s the %q environment\n", action, envName)
return nil
}

workspaces, err := client.Workspaces().List(ctx, stack.Id)
if err != nil {
return fmt.Errorf("error retrieving list of workspaces: %w", err)
}
blocks, err := client.Blocks().List(ctx, stack.Id)
if err != nil {
return fmt.Errorf("error retrieving list of blocks: %w", err)
input := PerformEnvRunInput{
CommitSha: "",
Stack: *stack,
Env: *env,
IsDestroy: isDestroy,
}

findWorkspace := func(run types.Run) *types.Workspace {
for _, workspace := range workspaces {
if workspace.Uid == run.WorkspaceUid {
return &workspace
}
}
return nil
}
findBlock := func(workspace *types.Workspace) *types.Block {
if workspace == nil {
return nil
}
for _, block := range blocks {
if workspace.BlockId == block.Id {
return &block
}
}
return nil
}
for _, run := range newRuns {
blockName := "(unknown)"
workspace := findWorkspace(run)
if block := findBlock(workspace); block != nil {
blockName = block.Name
}
browserUrl := ""
if workspace != nil {
browserUrl = fmt.Sprintf(" Logs: %s", runs.GetBrowserUrl(cfg, *workspace, run))
}
fmt.Fprintf(os.Stdout, "created run to %s %s and dependencies in %q environment.%s\n", action, blockName, envName, browserUrl)
}
return nil
return PerformEnvRun(ctx, cfg, input)
}
90 changes: 90 additions & 0 deletions cmd/perform_env_run.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
package cmd

import (
"context"
"fmt"
"gopkg.in/nullstone-io/go-api-client.v0"
"gopkg.in/nullstone-io/go-api-client.v0/types"
"gopkg.in/nullstone-io/nullstone.v0/app_urls"
"os"
)

type PerformEnvRunInput struct {
CommitSha string
Stack types.Stack
Env types.Environment
IsDestroy bool
}

func PerformEnvRun(ctx context.Context, cfg api.Config, input PerformEnvRunInput) error {
stdout := os.Stdout
action := "launch"
if input.IsDestroy {
action = "destroy"
}

client := api.Client{Config: cfg}
body := types.CreateEnvRunInput{IsDestroy: input.IsDestroy}
result, err := client.EnvRuns().Create(ctx, input.Stack.Id, input.Env.Id, body)
if err != nil {
return fmt.Errorf("error creating run: %w", err)
} else if result == nil {
fmt.Fprintf(stdout, "no runs created to %s the %q environment\n", action, input.Env.Name)
return nil
}

if result.IntentWorkflow.Intent != "" {
fmt.Fprintf(stdout, "created workflow to %s %q environment.\n", action, input.Env.Name)
fmt.Fprintln(stdout, app_urls.GetIntentWorkflow(cfg, result.IntentWorkflow))
return nil
} else if result.Runs == nil {
return fmt.Errorf("workflow to %q environment was not created", action)
}

if len(result.Runs) < 1 {
fmt.Fprintf(stdout, "no runs created to %s the %q environment\n", action, input.Env.Name)
return nil
}

workspaces, err := client.Workspaces().List(ctx, input.Env.Id)
if err != nil {
return fmt.Errorf("error retrieving list of workspaces: %w", err)
}
blocks, err := client.Blocks().List(ctx, input.Stack.Id)
if err != nil {
return fmt.Errorf("error retrieving list of blocks: %w", err)
}

findWorkspace := func(run types.Run) *types.Workspace {
for _, workspace := range workspaces {
if workspace.Uid == run.WorkspaceUid {
return &workspace
}
}
return nil
}
findBlock := func(workspace *types.Workspace) *types.Block {
if workspace == nil {
return nil
}
for _, block := range blocks {
if workspace.BlockId == block.Id {
return &block
}
}
return nil
}
for _, run := range result.Runs {
blockName := "(unknown)"
workspace := findWorkspace(run)
if block := findBlock(workspace); block != nil {
blockName = block.Name
}
browserUrl := ""
if workspace != nil {
browserUrl = fmt.Sprintf(" Logs: %s", app_urls.GetRun(cfg, *workspace, run))
}
fmt.Fprintf(os.Stdout, "created run to %s %s and dependencies in %q environment. %s\n", action, blockName, input.Env.Name, browserUrl)
}
return nil
}
3 changes: 2 additions & 1 deletion cmd/wait.go
Original file line number Diff line number Diff line change
Expand Up @@ -9,6 +9,7 @@ import (
"gopkg.in/nullstone-io/go-api-client.v0"
"gopkg.in/nullstone-io/go-api-client.v0/find"
"gopkg.in/nullstone-io/go-api-client.v0/types"
"gopkg.in/nullstone-io/nullstone.v0/app_urls"
"gopkg.in/nullstone-io/nullstone.v0/runs"
"strings"
"time"
Expand Down Expand Up @@ -98,7 +99,7 @@ func WaitForLaunch(ctx context.Context, osWriters logging.OsWriters, cfg api.Con
}

fmt.Fprintf(stderr, "Waiting for %q to launch in %q environment...\n", details.Block.Name, details.Env.Name)
fmt.Fprintf(stderr, "Watching run for launch: %s\n", runs.GetBrowserUrl(cfg, *details.Workspace, *launchRun))
fmt.Fprintf(stderr, "Watching run for launch: %s\n", app_urls.GetRun(cfg, *details.Workspace, *launchRun))
fmt.Fprintf(stderr, "Timeout = %s, Approval Timeout = %s\n", timeout, approvalTimeout)

result, err := runs.WaitForTerminalRun(ctx, osWriters, cfg, *details.Workspace, *launchRun, timeout, approvalTimeout)
Expand Down
4 changes: 2 additions & 2 deletions cmd/wait_for.go
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,8 @@ func waitForWorkspaceWorkflowRun(ctx context.Context, cfg api.Config, ww types.W
if cur.Run != nil {
return *cur.Run, nil
}
if types.IsTerminalRunStatus(cur.Run.Status) {
return types.Run{}, fmt.Errorf("workflow reached %s status before a run could be found", cur.Run.Status)
if types.IsTerminalWorkspaceWorkflow(cur.Status) {
return types.Run{}, fmt.Errorf("workflow reached %s status before a run could be found", cur.Status)
}
so := <-ch
if so.Err != nil {
Expand Down
5 changes: 1 addition & 4 deletions go.mod
Original file line number Diff line number Diff line change
@@ -1,9 +1,6 @@
module gopkg.in/nullstone-io/nullstone.v0

go 1.21
replace (
gopkg.in/nullstone-io/go-api-client.v0 => ../go-api-client
)

require (
github.com/aws/aws-sdk-go-v2 v1.26.0
Expand All @@ -20,7 +17,7 @@ require (
github.com/urfave/cli/v2 v2.3.0
golang.org/x/crypto v0.18.0
golang.org/x/sync v0.5.0
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240618211415-f1adb7935315
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240620203545-ee7bbc985d3f
k8s.io/api v0.27.2
k8s.io/apimachinery v0.27.2
k8s.io/client-go v0.27.2
Expand Down
4 changes: 2 additions & 2 deletions go.sum
Original file line number Diff line number Diff line change
Expand Up @@ -1444,8 +1444,8 @@ gopkg.in/gemnasium/logrus-airbrake-hook.v2 v2.1.2/go.mod h1:Xk6kEKp8OKb+X14hQBKW
gopkg.in/inf.v0 v0.9.1 h1:73M5CoZyi3ZLMOyDlQh031Cx6N9NDJ2Vvfl76EDAgDc=
gopkg.in/inf.v0 v0.9.1/go.mod h1:cWUDdTG/fYaXco+Dcufb5Vnc6Gp2YChqWtbxRZE0mXw=
gopkg.in/natefinch/lumberjack.v2 v2.0.0/go.mod h1:l0ndWWf7gzL7RNwBG7wST/UCcT4T24xpD6X8LsfU/+k=
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240618211415-f1adb7935315 h1:HujonAv49czagK9TQBUM3gf81Xsvytwwo9NgiIzmEOg=
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240618211415-f1adb7935315/go.mod h1:+cdH05EoXHHcFjSvRMXaaOhHSAmEj7tId0b+7R+N7qE=
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240620203545-ee7bbc985d3f h1:KilDEWL1n0C+1K26dko+5jFkwmUjaHELefGEat16iHY=
gopkg.in/nullstone-io/go-api-client.v0 v0.0.0-20240620203545-ee7bbc985d3f/go.mod h1:+cdH05EoXHHcFjSvRMXaaOhHSAmEj7tId0b+7R+N7qE=
gopkg.in/resty.v1 v1.12.0/go.mod h1:mDo4pnntr5jdWRML875a/NmxYqAlA73dVijT2AXvQQo=
gopkg.in/rethinkdb/rethinkdb-go.v6 v6.2.1 h1:d4KQkxAaAiRY2h5Zqis161Pv91A37uZyJOx73duwUwM=
gopkg.in/rethinkdb/rethinkdb-go.v6 v6.2.1/go.mod h1:WbjuEoo1oadwzQ4apSDU+JTvmllEHtsNHS6y7vFc7iw=
Expand Down

0 comments on commit 061b5d5

Please sign in to comment.