Image editing command
This commit is contained in:
parent
0529b30558
commit
3ec919abc1
93
images.go
93
images.go
@ -5,14 +5,107 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
"io/ioutil"
|
"io/ioutil"
|
||||||
"net/http"
|
"net/http"
|
||||||
"os"
|
"os"
|
||||||
"os/exec"
|
"os/exec"
|
||||||
|
"os/user"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"code.dumpstack.io/tools/out-of-tree/config"
|
||||||
|
"code.dumpstack.io/tools/out-of-tree/qemu"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type ImageCmd struct {
|
||||||
|
List ImageListCmd `cmd:"" help:"list images"`
|
||||||
|
Edit ImageEditCmd `cmd:"" help:"edit image"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ImageListCmd struct{}
|
||||||
|
|
||||||
|
func (cmd *ImageListCmd) Run(g *Globals) (err error) {
|
||||||
|
usr, err := user.Current()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
entries, err := os.ReadDir(usr.HomeDir + "/.out-of-tree/images/")
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
for _, e := range entries {
|
||||||
|
fmt.Println(e.Name())
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
type ImageEditCmd struct {
|
||||||
|
Name string `help:"image name" required:""`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (cmd *ImageEditCmd) Run(g *Globals) (err error) {
|
||||||
|
usr, err := user.Current()
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
image := usr.HomeDir + "/.out-of-tree/images/" + cmd.Name
|
||||||
|
if !exists(image) {
|
||||||
|
fmt.Println("image does not exist")
|
||||||
|
}
|
||||||
|
|
||||||
|
kcfg, err := config.ReadKernelConfig(g.Config.Kernels)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(kcfg.Kernels) == 0 {
|
||||||
|
return errors.New("No kernels found")
|
||||||
|
}
|
||||||
|
|
||||||
|
ki := config.KernelInfo{}
|
||||||
|
for _, k := range kcfg.Kernels {
|
||||||
|
if k.RootFS == image {
|
||||||
|
ki = k
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
kernel := qemu.Kernel{
|
||||||
|
KernelPath: ki.KernelPath,
|
||||||
|
InitrdPath: ki.InitrdPath,
|
||||||
|
}
|
||||||
|
|
||||||
|
q, err := qemu.NewSystem(qemu.X86x64, kernel, ki.RootFS)
|
||||||
|
|
||||||
|
q.Mutable = true
|
||||||
|
|
||||||
|
err = q.Start()
|
||||||
|
if err != nil {
|
||||||
|
fmt.Println("Qemu start error:", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
defer q.Stop()
|
||||||
|
|
||||||
|
fmt.Print("ssh command:\n\n\t")
|
||||||
|
fmt.Println(q.GetSSHCommand())
|
||||||
|
|
||||||
|
fmt.Print("\npress enter to stop")
|
||||||
|
fmt.Scanln()
|
||||||
|
|
||||||
|
q.Command("root", "poweroff")
|
||||||
|
|
||||||
|
for !q.Died {
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
// inspired by Edd Turtle code
|
// inspired by Edd Turtle code
|
||||||
func downloadFile(filepath string, url string) (err error) {
|
func downloadFile(filepath string, url string) (err error) {
|
||||||
out, err := os.Create(filepath)
|
out, err := os.Create(filepath)
|
||||||
|
1
main.go
1
main.go
@ -30,6 +30,7 @@ type CLI struct {
|
|||||||
Log LogCmd `cmd:"" help:"query logs"`
|
Log LogCmd `cmd:"" help:"query logs"`
|
||||||
Pack PackCmd `cmd:"" help:"exploit pack test"`
|
Pack PackCmd `cmd:"" help:"exploit pack test"`
|
||||||
Gen GenCmd `cmd:"" help:"generate .out-of-tree.toml skeleton"`
|
Gen GenCmd `cmd:"" help:"generate .out-of-tree.toml skeleton"`
|
||||||
|
Image ImageCmd `cmd:"" help:"manage images"`
|
||||||
|
|
||||||
Version VersionFlag `name:"version" help:"print version information and quit"`
|
Version VersionFlag `name:"version" help:"print version information and quit"`
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user