mirror of
https://github.com/ultravioletrs/cocos.git
synced 2026-06-23 04:10:25 +00:00
d5badba547
CI / lint (push) Has been cancelled
CI / test (agent) (push) Has been cancelled
CI / test (cli) (push) Has been cancelled
CI / test (cmd) (push) Has been cancelled
CI / test (internal) (push) Has been cancelled
CI / test (manager, true) (push) Has been cancelled
CI / test (pkg) (push) Has been cancelled
CI / upload-coverage (push) Has been cancelled
* feat: Implement per-resource KBS configuration, allowing algorithms and datasets to specify individual KBS URLs. Signed-off-by: Sammy Oina <sammyoina@gmail.com> * refactor: Encapsulate CLI error handling and CVM certificate paths within the CLI struct, and add algorithm type to agent's algorithm structure. Signed-off-by: Sammy Oina <sammyoina@gmail.com> * style: Remove blank lines and fix indentation in CLI commands. Signed-off-by: Sammy Oina <sammyoina@gmail.com> * refactor: Update downloadAndDecryptGenericResource to accept KBS URL as a parameter and adjust related tests Signed-off-by: Sammy Oina <sammyoina@gmail.com> * refactor: group CLI configuration into structured types and simplify skopeo decryption key handling Signed-off-by: Sammy Oina <sammyoina@gmail.com> --------- Signed-off-by: Sammy Oina <sammyoina@gmail.com>
155 lines
4.6 KiB
Go
155 lines
4.6 KiB
Go
// Copyright (c) Ultraviolet
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
package cli
|
|
|
|
import (
|
|
"os"
|
|
|
|
"github.com/fatih/color"
|
|
"github.com/spf13/cobra"
|
|
"github.com/ultravioletrs/cocos/manager"
|
|
)
|
|
|
|
const (
|
|
serverURL = "server-url"
|
|
serverCA = "server-ca"
|
|
clientKey = "client-key"
|
|
clientCrt = "client-crt"
|
|
caUrl = "ca-url"
|
|
logLevel = "log-level"
|
|
ttlFlag = "ttl"
|
|
)
|
|
|
|
func (c *CLI) NewCreateVMCmd() *cobra.Command {
|
|
cmd := &cobra.Command{
|
|
Use: "create-vm",
|
|
Short: "Create a new virtual machine",
|
|
Example: `create-vm`,
|
|
Args: cobra.ExactArgs(0),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
if c.connectErr != nil {
|
|
c.printError(cmd, "Failed to connect to manager: %v ❌ ", c.connectErr)
|
|
return
|
|
}
|
|
if c.managerClient == nil {
|
|
if err := c.InitializeManagerClient(cmd); err != nil {
|
|
c.printError(cmd, "Failed to connect to manager: %v ❌ ", err)
|
|
return
|
|
}
|
|
}
|
|
defer c.Close()
|
|
|
|
createReq, err := c.loadCerts()
|
|
if err != nil {
|
|
c.printError(cmd, "Error loading certs: %v ❌ ", err)
|
|
return
|
|
}
|
|
|
|
createReq.AgentCvmServerUrl = c.AgentVM.CVMServerURL
|
|
createReq.AgentLogLevel = c.AgentVM.LogLevel
|
|
createReq.AgentCvmCaUrl = c.AgentVM.CVMCaURL
|
|
createReq.AwsAccessKeyId = c.AWS.AccessKeyID
|
|
createReq.AwsSecretAccessKey = c.AWS.SecretAccessKey
|
|
createReq.AwsEndpointUrl = c.AWS.EndpointURL
|
|
createReq.AwsRegion = c.AWS.Region
|
|
createReq.AaKbsParams = c.Attestation.KbsParams
|
|
|
|
if c.AgentVM.Ttl > 0 {
|
|
createReq.Ttl = c.AgentVM.Ttl.String()
|
|
}
|
|
|
|
cmd.Println("🔗 Creating a new virtual machine")
|
|
|
|
res, err := c.managerClient.CreateVm(cmd.Context(), createReq)
|
|
if err != nil {
|
|
c.printError(cmd, "Error creating virtual machine: %v ❌ ", err)
|
|
return
|
|
}
|
|
|
|
cmd.Println(color.New(color.FgGreen).Sprintf("✅ Virtual machine created successfully with id %s and port %s", res.CvmId, res.ForwardedPort))
|
|
},
|
|
}
|
|
|
|
cmd.Flags().StringVar(&c.AgentVM.CVMServerURL, serverURL, "", "CVM server URL")
|
|
cmd.Flags().StringVar(&c.AgentVM.CVMServerCA, serverCA, "", "CVM server CA")
|
|
cmd.Flags().StringVar(&c.AgentVM.CVMClientKey, clientKey, "", "CVM client key")
|
|
cmd.Flags().StringVar(&c.AgentVM.CVMClientCrt, clientCrt, "", "CVM client crt")
|
|
cmd.Flags().StringVar(&c.AgentVM.CVMCaURL, caUrl, "", "CVM CA service URL")
|
|
cmd.Flags().StringVar(&c.AgentVM.LogLevel, logLevel, "", "Agent Log level")
|
|
cmd.Flags().DurationVar(&c.AgentVM.Ttl, ttlFlag, 0, "TTL for the VM")
|
|
cmd.Flags().StringVar(&c.AWS.AccessKeyID, "aws-access-key-id", "", "AWS Access Key ID for S3/MinIO")
|
|
cmd.Flags().StringVar(&c.AWS.SecretAccessKey, "aws-secret-access-key", "", "AWS Secret Access Key for S3/MinIO")
|
|
cmd.Flags().StringVar(&c.AWS.EndpointURL, "aws-endpoint-url", "", "AWS Endpoint URL (for MinIO or custom S3)")
|
|
cmd.Flags().StringVar(&c.AWS.Region, "aws-region", "", "AWS Region")
|
|
cmd.Flags().StringVar(&c.Attestation.KbsParams, "aa-kbs-params", "", "Attestation Agent KBS Parameters (e.g. protocol=http,type=kbs,url=http://... or just type=sample)")
|
|
if err := cmd.MarkFlagRequired(serverURL); err != nil {
|
|
c.printError(cmd, "Error marking flag as required: %v ❌ ", err)
|
|
return cmd
|
|
}
|
|
|
|
return cmd
|
|
}
|
|
|
|
func (c *CLI) NewRemoveVMCmd() *cobra.Command {
|
|
return &cobra.Command{
|
|
Use: "remove-vm",
|
|
Short: "Remove a virtual machine",
|
|
Example: `remove-vm <cvm_id>`,
|
|
Args: cobra.ExactArgs(1),
|
|
Run: func(cmd *cobra.Command, args []string) {
|
|
if c.connectErr != nil {
|
|
c.printError(cmd, "Failed to connect to manager: %v ❌ ", c.connectErr)
|
|
return
|
|
}
|
|
if c.managerClient == nil {
|
|
if err := c.InitializeManagerClient(cmd); err != nil {
|
|
c.printError(cmd, "Failed to connect to manager: %v ❌ ", err)
|
|
return
|
|
}
|
|
}
|
|
defer c.Close()
|
|
|
|
cmd.Println("🔗 Removing virtual machine")
|
|
|
|
_, err := c.managerClient.RemoveVm(cmd.Context(), &manager.RemoveReq{CvmId: args[0]})
|
|
if err != nil {
|
|
c.printError(cmd, "Error removing virtual machine: %v ❌ ", err)
|
|
return
|
|
}
|
|
|
|
cmd.Println(color.New(color.FgGreen).Sprintf("✅ Virtual machine removed successfully"))
|
|
},
|
|
}
|
|
}
|
|
|
|
func fileReader(path string) ([]byte, error) {
|
|
if path == "" {
|
|
return nil, nil
|
|
}
|
|
|
|
return os.ReadFile(path)
|
|
}
|
|
|
|
func (c *CLI) loadCerts() (*manager.CreateReq, error) {
|
|
clientKey, err := fileReader(c.AgentVM.CVMClientKey)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
clientCrt, err := fileReader(c.AgentVM.CVMClientCrt)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
serverCA, err := fileReader(c.AgentVM.CVMServerCA)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
return &manager.CreateReq{
|
|
AgentCvmServerCaCert: serverCA,
|
|
AgentCvmClientKey: clientKey,
|
|
AgentCvmClientCert: clientCrt,
|
|
}, nil
|
|
}
|