Add a form to provision a new instance
This commit is contained in:
parent
80906d3791
commit
53f63d4efd
25 changed files with 367 additions and 236 deletions
|
|
@ -3,21 +3,21 @@ package cmd
|
|||
import (
|
||||
wisski_distillery "github.com/FAU-CDI/wisski-distillery"
|
||||
"github.com/FAU-CDI/wisski-distillery/internal/cli"
|
||||
"github.com/FAU-CDI/wisski-distillery/pkg/fsx"
|
||||
"github.com/FAU-CDI/wisski-distillery/internal/dis/component/provision"
|
||||
"github.com/FAU-CDI/wisski-distillery/pkg/logging"
|
||||
"github.com/tkw1536/goprogram/exit"
|
||||
)
|
||||
|
||||
// Provision is the 'provision' command
|
||||
var Provision wisski_distillery.Command = provision{}
|
||||
var Provision wisski_distillery.Command = pv{}
|
||||
|
||||
type provision struct {
|
||||
type pv struct {
|
||||
Positionals struct {
|
||||
Slug string `positional-arg-name:"slug" required:"1-1" description:"slug of instance to create"`
|
||||
} `positional-args:"true"`
|
||||
}
|
||||
|
||||
func (provision) Description() wisski_distillery.Description {
|
||||
func (pv) Description() wisski_distillery.Description {
|
||||
return wisski_distillery.Description{
|
||||
Requirements: cli.Requirements{
|
||||
NeedsDistillery: true,
|
||||
|
|
@ -27,82 +27,19 @@ func (provision) Description() wisski_distillery.Description {
|
|||
}
|
||||
}
|
||||
|
||||
// TODO: AfterParse to check instance!
|
||||
|
||||
var errProvisionAlreadyExists = exit.Error{
|
||||
Message: "instance %q already exists",
|
||||
ExitCode: exit.ExitGeneric,
|
||||
}
|
||||
|
||||
var errProvisionGeneric = exit.Error{
|
||||
Message: "unable to provision instance %s: %s",
|
||||
ExitCode: exit.ExitGeneric,
|
||||
}
|
||||
|
||||
func (p provision) Run(context wisski_distillery.Context) error {
|
||||
dis := context.Environment
|
||||
slug := p.Positionals.Slug
|
||||
// TODO: AfterParse to check instance!
|
||||
|
||||
// check that it doesn't already exist
|
||||
logging.LogMessage(context.Stderr, context.Context, "Provisioning new WissKI instance %s", slug)
|
||||
if exists, err := dis.Instances().Has(context.Context, slug); err != nil || exists {
|
||||
return errProvisionAlreadyExists.WithMessageF(slug)
|
||||
}
|
||||
|
||||
// make it in-memory
|
||||
instance, err := dis.Instances().Create(slug)
|
||||
func (p pv) Run(context wisski_distillery.Context) error {
|
||||
instance, err := context.Environment.Provision().Provision(context.Stderr, context.Context, provision.ProvisionFlags{
|
||||
Slug: p.Positionals.Slug,
|
||||
})
|
||||
if err != nil {
|
||||
return errProvisionGeneric.WithMessageF(slug, err)
|
||||
}
|
||||
|
||||
// check that the base directory does not exist
|
||||
logging.LogMessage(context.Stderr, context.Context, "Checking that base directory %s does not exist", instance.FilesystemBase)
|
||||
if fsx.IsDirectory(dis.Environment, instance.FilesystemBase) {
|
||||
return errProvisionAlreadyExists.WithMessageF(slug)
|
||||
}
|
||||
|
||||
// Store in the instances table!
|
||||
if err := logging.LogOperation(func() error {
|
||||
if err := instance.Bookkeeping().Save(context.Context); err != nil {
|
||||
return errProvisionGeneric.WithMessageF(slug, err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}, context.Stderr, context.Context, "Updating bookkeeping database"); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// create all the resources!
|
||||
if err := logging.LogOperation(func() error {
|
||||
domain := instance.Domain()
|
||||
for _, pc := range dis.Provisionable() {
|
||||
logging.LogMessage(context.Stderr, context.Context, "Provisioning %s resources", pc.Name())
|
||||
err := pc.Provision(context.Context, instance.Instance, domain)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
return nil
|
||||
}, context.Stderr, context.Context, "Provisioning instance-specific resources"); err != nil {
|
||||
return errProvisionGeneric.WithMessageF(slug, err)
|
||||
}
|
||||
|
||||
// run the provision script
|
||||
if err := logging.LogOperation(func() error {
|
||||
if err := instance.Provisioner().Provision(context.Context, context.Stderr); err != nil {
|
||||
return errProvisionGeneric.WithMessageF(slug, err)
|
||||
}
|
||||
|
||||
return nil
|
||||
}, context.Stderr, context.Context, "Running setup scripts"); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// start the container!
|
||||
logging.LogMessage(context.Stderr, context.Context, "Starting Container")
|
||||
if err := instance.Barrel().Stack().Up(context.Context, context.Stderr); err != nil {
|
||||
return err
|
||||
return errProvisionGeneric.WithMessageF(p.Positionals.Slug, err)
|
||||
}
|
||||
|
||||
// and we're done!
|
||||
|
|
|
|||
|
|
@ -47,7 +47,7 @@ func (r reserve) Run(context wisski_distillery.Context) error {
|
|||
// check that it doesn't already exist
|
||||
logging.LogMessage(context.Stderr, context.Context, "Reserving new WissKI instance %s", slug)
|
||||
if exists, err := dis.Instances().Has(context.Context, slug); err != nil || exists {
|
||||
return errProvisionAlreadyExists.WithMessageF(slug)
|
||||
return errReserveAlreadyExists.WithMessageF(slug)
|
||||
}
|
||||
|
||||
// make it in-memory
|
||||
|
|
@ -59,7 +59,7 @@ func (r reserve) Run(context wisski_distillery.Context) error {
|
|||
// check that the base directory does not exist
|
||||
logging.LogMessage(context.Stderr, context.Context, "Checking that base directory %s does not exist", instance.FilesystemBase)
|
||||
if fsx.IsDirectory(dis.Environment, instance.FilesystemBase) {
|
||||
return errProvisionAlreadyExists.WithMessageF(slug)
|
||||
return errReserveAlreadyExists.WithMessageF(slug)
|
||||
}
|
||||
|
||||
// setup docker stack
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue