feature-14 #17

Merged
nicolas.boufideline merged 15 commits from feature-14 into main 2026-03-23 16:00:53 +00:00
2 changed files with 21 additions and 6 deletions
Showing only changes of commit 0b9714ce10 - Show all commits

f-14: code: add delete operation #14

Signed-off-by: GnomeZworc <nicolas.boufidjeline@g3e.fr>
GnomeZworc 2026-01-27 22:24:47 +01:00
Signed by: nicolas.boufideline
GPG key ID: 4406BBBF8845D632

View file

@ -41,9 +41,16 @@ func main() {
fmt.Println(err)
}
case "delete":
if err := vpc.DeleteVPC(*name); err != nil {
kv.AddInDB(DB, "vpc/"+*name+"/state", "deleting")
if err := vpc.DeleteVPC(DB, *name); err != nil {
fmt.Println(err)
}
if state, err := kv.GetFromDB(DB, "vpc/"+*name+"/state"); err != nil {
fmt.Println(err)
os.Exit(1)
} else if state == "deleted" {
kv.DeleteInDB(DB, "vpc/"+*name)
}
default:
fmt.Printf("Available commande:\n - create\n - delete\n - check\n")
os.Exit(1)

View file

@ -3,15 +3,23 @@ package vpc
import (
"git.g3e.fr/syonad/two/internal/netif"
"git.g3e.fr/syonad/two/internal/netns"
"git.g3e.fr/syonad/two/pkg/db/kv"
"github.com/dgraph-io/badger/v4"
)
func DeleteVPC(name string) error {
if err := netif.DeleteLink(name + "-ext"); err != nil {
func DeleteVPC(db *badger.DB, name string) error {
if state, err := kv.GetFromDB(db, "vpc/"+name+"/state"); err != nil {
return err
}
} else if state == "deleting" {
if err := netif.DeleteLink(name + "-ext"); err != nil {
return err
}
if err := netns.Delete(name); err != nil {
return err
if err := netns.Delete(name); err != nil {
return err
}
kv.AddInDB(db, "vpc/"+name+"/state", "deleted")
}
return nil