Added help command to ImGui client.
This commit is contained in:
@@ -1,5 +1,5 @@
|
|||||||
import whisky
|
import whisky
|
||||||
import strformat, strutils, times, json
|
import strformat, strutils, times, json, tables, sequtils
|
||||||
import imguin/[cimgui, glfw_opengl, simple]
|
import imguin/[cimgui, glfw_opengl, simple]
|
||||||
import ../utils/[appImGui, colors]
|
import ../utils/[appImGui, colors]
|
||||||
import ../../common/[types, utils]
|
import ../../common/[types, utils]
|
||||||
@@ -128,6 +128,48 @@ proc addItem*(component: ConsoleComponent, itemType: LogType, data: string, time
|
|||||||
#[
|
#[
|
||||||
Handling console commands
|
Handling console commands
|
||||||
]#
|
]#
|
||||||
|
proc displayHelp(component: ConsoleComponent) =
|
||||||
|
for module in getModules():
|
||||||
|
for cmd in module.commands:
|
||||||
|
component.addItem(LOG_OUTPUT, fmt" * {cmd.name:<15}{cmd.description}")
|
||||||
|
|
||||||
|
proc displayCommandHelp(component: ConsoleComponent, command: Command) =
|
||||||
|
var usage = command.name & " " & command.arguments.mapIt(
|
||||||
|
if it.isRequired: fmt"<{it.name}>" else: fmt"[{it.name}]"
|
||||||
|
).join(" ")
|
||||||
|
|
||||||
|
if command.example != "":
|
||||||
|
usage &= "\nExample : " & command.example
|
||||||
|
|
||||||
|
component.addItem(LOG_OUTPUT, fmt"""
|
||||||
|
{command.description}
|
||||||
|
|
||||||
|
Usage : {usage}
|
||||||
|
""")
|
||||||
|
|
||||||
|
if command.arguments.len > 0:
|
||||||
|
component.addItem(LOG_OUTPUT, "Arguments:\n")
|
||||||
|
|
||||||
|
let header = @["Name", "Type", "Required", "Description"]
|
||||||
|
component.addItem(LOG_OUTPUT, fmt" {header[0]:<15} {header[1]:<6} {header[2]:<8} {header[3]}")
|
||||||
|
component.addItem(LOG_OUTPUT, fmt" {'-'.repeat(15)} {'-'.repeat(6)} {'-'.repeat(8)} {'-'.repeat(20)}")
|
||||||
|
|
||||||
|
for arg in command.arguments:
|
||||||
|
let isRequired = if arg.isRequired: "YES" else: "NO"
|
||||||
|
component.addItem(LOG_OUTPUT, fmt" * {arg.name:<15} {($arg.argumentType).toUpperAscii():<6} {isRequired:>8} {arg.description}")
|
||||||
|
component.addItem(LOG_OUTPUT, "")
|
||||||
|
|
||||||
|
proc handleHelp(component: ConsoleComponent, parsed: seq[string]) =
|
||||||
|
try:
|
||||||
|
# Try parsing the first argument passed to 'help' as a command
|
||||||
|
component.displayCommandHelp(getCommandByName(parsed[1]))
|
||||||
|
except IndexDefect:
|
||||||
|
# 'help' command is called without additional parameters
|
||||||
|
component.displayHelp()
|
||||||
|
except ValueError:
|
||||||
|
# Command was not found
|
||||||
|
component.addItem(LOG_ERROR, fmt"The command '{parsed[1]}' does not exist.")
|
||||||
|
|
||||||
proc handleAgentCommand*(component: ConsoleComponent, ws: WebSocket, input: string) =
|
proc handleAgentCommand*(component: ConsoleComponent, ws: WebSocket, input: string) =
|
||||||
|
|
||||||
# Convert user input into sequence of string arguments
|
# Convert user input into sequence of string arguments
|
||||||
@@ -135,8 +177,7 @@ proc handleAgentCommand*(component: ConsoleComponent, ws: WebSocket, input: stri
|
|||||||
|
|
||||||
# Handle 'help' command
|
# Handle 'help' command
|
||||||
if parsedArgs[0] == "help":
|
if parsedArgs[0] == "help":
|
||||||
# cq.handleHelp(parsedArgs)
|
component.handleHelp(parsedArgs)
|
||||||
component.addItem(LOG_WARNING, "Help")
|
|
||||||
return
|
return
|
||||||
|
|
||||||
# Handle commands with actions on the agent
|
# Handle commands with actions on the agent
|
||||||
@@ -155,6 +196,7 @@ proc handleAgentCommand*(component: ConsoleComponent, ws: WebSocket, input: stri
|
|||||||
Drawing
|
Drawing
|
||||||
]#
|
]#
|
||||||
proc print(item: ConsoleItem) =
|
proc print(item: ConsoleItem) =
|
||||||
|
|
||||||
if item.timestamp > 0:
|
if item.timestamp > 0:
|
||||||
let timestamp = item.timestamp.fromUnix().format("dd-MM-yyyy HH:mm:ss")
|
let timestamp = item.timestamp.fromUnix().format("dd-MM-yyyy HH:mm:ss")
|
||||||
igTextColored(vec4(0.6f, 0.6f, 0.6f, 1.0f), fmt"[{timestamp}]".cstring)
|
igTextColored(vec4(0.6f, 0.6f, 0.6f, 1.0f), fmt"[{timestamp}]".cstring)
|
||||||
@@ -252,6 +294,7 @@ proc draw*(component: ConsoleComponent, ws: WebSocket) =
|
|||||||
let childWindowFlags = ImGuiChildFlags_NavFlattened.int32 or ImGui_ChildFlags_Borders.int32 or ImGui_ChildFlags_AlwaysUseWindowPadding.int32 or ImGuiChildFlags_FrameStyle.int32
|
let childWindowFlags = ImGuiChildFlags_NavFlattened.int32 or ImGui_ChildFlags_Borders.int32 or ImGui_ChildFlags_AlwaysUseWindowPadding.int32 or ImGuiChildFlags_FrameStyle.int32
|
||||||
if igBeginChild_Str("##Console", vec2(-1.0f, -footerHeight), childWindowFlags, ImGuiWindowFlags_HorizontalScrollbar.int32):
|
if igBeginChild_Str("##Console", vec2(-1.0f, -footerHeight), childWindowFlags, ImGuiWindowFlags_HorizontalScrollbar.int32):
|
||||||
# Display console items
|
# Display console items
|
||||||
|
|
||||||
for item in component.console.items:
|
for item in component.console.items:
|
||||||
|
|
||||||
# Apply filter
|
# Apply filter
|
||||||
|
|||||||
@@ -1,6 +1,5 @@
|
|||||||
import terminal, strformat, strutils, tables, times, system, parsetoml, prompt
|
import terminal, strformat, strutils, tables, times, system, parsetoml, prompt
|
||||||
|
|
||||||
import ./task
|
|
||||||
import ../utils
|
import ../utils
|
||||||
import ../core/logger
|
import ../core/logger
|
||||||
import ../db/database
|
import ../db/database
|
||||||
|
|||||||
@@ -124,6 +124,8 @@ proc patch(cq: Conquest, unpatchedExePath: string, configuration: seq[byte]): se
|
|||||||
for i, c in Bytes.toString(configuration):
|
for i, c in Bytes.toString(configuration):
|
||||||
exeBytes[placeholderPos + i] = c
|
exeBytes[placeholderPos + i] = c
|
||||||
|
|
||||||
|
writeFile(unpatchedExePath, exeBytes)
|
||||||
|
|
||||||
cq.success(fmt"Agent payload patched successfully: {unpatchedExePath}.")
|
cq.success(fmt"Agent payload patched successfully: {unpatchedExePath}.")
|
||||||
return string.toBytes(exeBytes)
|
return string.toBytes(exeBytes)
|
||||||
|
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
import prompt, terminal, argparse, parsetoml, times, json, math
|
import prompt, terminal, argparse, parsetoml, times, json, math
|
||||||
import strutils, strformat, system, tables
|
import strutils, strformat, system, tables
|
||||||
|
|
||||||
import ./[agent, listener, task, builder]
|
import ./[agent, listener, builder]
|
||||||
import ../globals
|
import ../globals
|
||||||
import ../db/database
|
import ../db/database
|
||||||
import ../core/logger
|
import ../core/logger
|
||||||
|
|||||||
@@ -1,51 +0,0 @@
|
|||||||
import strformat, terminal, tables, sequtils, strutils
|
|
||||||
|
|
||||||
import ../core/logger
|
|
||||||
import ../websocket
|
|
||||||
import ../../modules/manager
|
|
||||||
import ../../common/types
|
|
||||||
|
|
||||||
proc displayHelp(cq: Conquest) =
|
|
||||||
cq.output("Available commands:")
|
|
||||||
cq.output(" * back")
|
|
||||||
for key, cmd in getAvailableCommands():
|
|
||||||
cq.output(fmt" * {cmd.name:<15}{cmd.description}")
|
|
||||||
cq.output()
|
|
||||||
|
|
||||||
proc displayCommandHelp(cq: Conquest, command: Command) =
|
|
||||||
var usage = command.name & " " & command.arguments.mapIt(
|
|
||||||
if it.isRequired: fmt"<{it.name}>" else: fmt"[{it.name}]"
|
|
||||||
).join(" ")
|
|
||||||
|
|
||||||
if command.example != "":
|
|
||||||
usage &= "\nExample : " & command.example
|
|
||||||
|
|
||||||
cq.output(fmt"""
|
|
||||||
{command.description}
|
|
||||||
|
|
||||||
Usage : {usage}
|
|
||||||
""")
|
|
||||||
|
|
||||||
if command.arguments.len > 0:
|
|
||||||
cq.output("Arguments:\n")
|
|
||||||
|
|
||||||
let header = @["Name", "Type", "Required", "Description"]
|
|
||||||
cq.output(fmt" {header[0]:<15} {header[1]:<6} {header[2]:<8} {header[3]}")
|
|
||||||
cq.output(fmt" {'-'.repeat(15)} {'-'.repeat(6)} {'-'.repeat(8)} {'-'.repeat(20)}")
|
|
||||||
|
|
||||||
for arg in command.arguments:
|
|
||||||
let isRequired = if arg.isRequired: "YES" else: "NO"
|
|
||||||
cq.output(fmt" * {arg.name:<15} {($arg.argumentType).toUpperAscii():<6} {isRequired:>8} {arg.description}")
|
|
||||||
|
|
||||||
cq.output()
|
|
||||||
|
|
||||||
proc handleHelp(cq: Conquest, parsed: seq[string]) =
|
|
||||||
try:
|
|
||||||
# Try parsing the first argument passed to 'help' as a command
|
|
||||||
cq.displayCommandHelp(getCommandByName(parsed[1]))
|
|
||||||
except IndexDefect:
|
|
||||||
# 'help' command is called without additional parameters
|
|
||||||
cq.displayHelp()
|
|
||||||
except ValueError:
|
|
||||||
# Command was not found
|
|
||||||
cq.error(fmt"The command '{parsed[1]}' does not exist." & '\n')
|
|
||||||
Reference in New Issue
Block a user