mirror of
https://github.com/calebstewart/pwncat.git
synced 2024-11-27 10:54:14 +01:00
Added search and info commands for modules
This commit is contained in:
parent
570a653bee
commit
e2d851ecd3
@ -1,15 +1,15 @@
|
||||
# Set your remote hosts file
|
||||
set lhost "127.0.0.1"
|
||||
set -g lhost "127.0.0.1"
|
||||
# Set your command prefix
|
||||
set prefix c-k
|
||||
set -g prefix c-k
|
||||
# Set the default private key to use for privilege escalation
|
||||
set privkey "data/pwncat"
|
||||
set -g privkey "data/pwncat"
|
||||
# Set the pwncat backdoor user and password
|
||||
set backdoor_user "pwncat"
|
||||
set backdoor_pass "pwncat"
|
||||
set db "sqlite:///pwncat.sqlite"
|
||||
set -g backdoor_user "pwncat"
|
||||
set -g backdoor_pass "pwncat"
|
||||
set -g db "sqlite:///pwncat.sqlite"
|
||||
|
||||
set on_load {
|
||||
set -g on_load {
|
||||
# Run a command upon a stable connection
|
||||
# privesc -l
|
||||
}
|
||||
|
57
pwncat/commands/info.py
Normal file
57
pwncat/commands/info.py
Normal file
@ -0,0 +1,57 @@
|
||||
#!/usr/bin/env python3
|
||||
import textwrap
|
||||
|
||||
from rich.table import Table
|
||||
from rich import box
|
||||
|
||||
import pwncat
|
||||
from pwncat.commands.base import CommandDefinition, Complete, Parameter
|
||||
from pwncat.util import console
|
||||
|
||||
|
||||
class Command(CommandDefinition):
|
||||
""" View info about a module """
|
||||
|
||||
def get_module_choices(self):
|
||||
yield from [module.name for module in pwncat.modules.match(".*")]
|
||||
|
||||
PROG = "info"
|
||||
ARGS = {
|
||||
"module": Parameter(
|
||||
Complete.CHOICES,
|
||||
choices=get_module_choices,
|
||||
metavar="MODULE",
|
||||
help="The module to view information on",
|
||||
nargs="?",
|
||||
)
|
||||
}
|
||||
|
||||
def run(self, args):
|
||||
|
||||
if not args.module and pwncat.victim.config.module is None:
|
||||
console.log("[red]error[/red]: no module specified")
|
||||
return
|
||||
|
||||
if args.module:
|
||||
try:
|
||||
module = pwncat.modules.find(args.module)
|
||||
except KeyError:
|
||||
console.log(f"[red]error[/red]: {args.module}: no such module")
|
||||
return
|
||||
else:
|
||||
module = pwncat.victim.config.module
|
||||
|
||||
console.print(f"[bold underline]Module {module.name}[/bold underline]")
|
||||
console.print(
|
||||
textwrap.indent(textwrap.dedent(module.__doc__.strip("\n")), " ") + "\n"
|
||||
)
|
||||
|
||||
table = Table("Argument", "Default", "Help", box=box.MINIMAL_DOUBLE_HEAD)
|
||||
for arg, info in module.ARGUMENTS.items():
|
||||
if info.default is pwncat.modules.NoValue:
|
||||
default = ""
|
||||
else:
|
||||
default = info.default
|
||||
table.add_row(arg, str(default), info.help)
|
||||
|
||||
console.print(table)
|
39
pwncat/commands/search.py
Normal file
39
pwncat/commands/search.py
Normal file
@ -0,0 +1,39 @@
|
||||
#!/usr/bin/env python3
|
||||
import textwrap
|
||||
|
||||
from rich.table import Table, Column
|
||||
from rich import box
|
||||
|
||||
import pwncat
|
||||
from pwncat.commands.base import CommandDefinition, Complete, Parameter
|
||||
from pwncat.util import console
|
||||
|
||||
|
||||
class Command(CommandDefinition):
|
||||
""" View info about a module """
|
||||
|
||||
def get_module_choices(self):
|
||||
yield from [module.name for module in pwncat.modules.match(".*")]
|
||||
|
||||
PROG = "search"
|
||||
ARGS = {"module": Parameter(Complete.NONE, help="Regular Expression Pattern",)}
|
||||
|
||||
def run(self, args):
|
||||
|
||||
table = Table(
|
||||
Column(0, header="Name", ratio=0.2),
|
||||
Column(1, header="Description", no_wrap=True, ratio=0.8),
|
||||
title="Results",
|
||||
box=box.MINIMAL_DOUBLE_HEAD,
|
||||
expand=True,
|
||||
)
|
||||
|
||||
for module in pwncat.modules.match(args.module):
|
||||
table.add_row(
|
||||
module.name,
|
||||
textwrap.shorten(
|
||||
module.__doc__.replace("\n", " "), width=200, placeholder="..."
|
||||
),
|
||||
)
|
||||
|
||||
console.print(table)
|
@ -35,6 +35,7 @@ class Argument:
|
||||
|
||||
type: Callable[[str], Any] = str
|
||||
default: Any = NoValue
|
||||
help: str = ""
|
||||
|
||||
|
||||
def List(_type=str):
|
||||
|
@ -30,7 +30,13 @@ class EnumerateModule(BaseModule):
|
||||
# Arguments which all enumeration modules should take
|
||||
# This shouldn't be modified. Enumeration modules don't take any
|
||||
# parameters
|
||||
ARGUMENTS = {"types": Argument(List(str), default=[])}
|
||||
ARGUMENTS = {
|
||||
"types": Argument(
|
||||
List(str),
|
||||
default=[],
|
||||
help="A list of enumeration types to retrieve (default: all)",
|
||||
)
|
||||
}
|
||||
|
||||
def run(self, types):
|
||||
""" Locate all facts this module provides.
|
||||
|
@ -23,7 +23,7 @@ class FileCapabilityData:
|
||||
|
||||
|
||||
class Module(EnumerateModule):
|
||||
""" Enumerate SUID binaries on the remote host """
|
||||
""" Enumerate capabilities of the binaries of the remote host """
|
||||
|
||||
PROVIDES = ["file.caps"]
|
||||
|
||||
|
@ -7,9 +7,13 @@ from pwncat.modules import BaseModule, Status, Argument
|
||||
class Module(BaseModule):
|
||||
""" Perform a quick enumeration of common useful data """
|
||||
|
||||
ARGUMENTS = {"output": Argument(str, default=None)}
|
||||
ARGUMENTS = {
|
||||
"output": Argument(
|
||||
str, default=None, help="Path a to file to write a markdown report"
|
||||
)
|
||||
}
|
||||
|
||||
def run(self, output):
|
||||
return next(pwncat.modules.match("enumerate.report")).run(
|
||||
return pwncat.modules.find("enumerate.report").run(
|
||||
types=["file.suid", "file.caps"], output=output
|
||||
)
|
||||
|
@ -35,13 +35,27 @@ def FileType(mode: str = "r"):
|
||||
|
||||
|
||||
class Module(pwncat.modules.BaseModule):
|
||||
""" Perform multiple enumeration modules and write a formatted
|
||||
report to the filesystem. """
|
||||
"""
|
||||
Perform multiple enumeration modules and write a formatted
|
||||
report to the filesystem.
|
||||
"""
|
||||
|
||||
ARGUMENTS = {
|
||||
"output": pwncat.modules.Argument(FileType("w"), default=None),
|
||||
"modules": pwncat.modules.Argument(pwncat.modules.List(str), default=[".*"]),
|
||||
"types": pwncat.modules.Argument(pwncat.modules.List(str), default=[]),
|
||||
"output": pwncat.modules.Argument(
|
||||
FileType("w"),
|
||||
default=None,
|
||||
help="The file to write a markdown report to (default: stdout)",
|
||||
),
|
||||
"modules": pwncat.modules.Argument(
|
||||
pwncat.modules.List(str),
|
||||
default=[".*"],
|
||||
help="List of modules to run (default: all)",
|
||||
),
|
||||
"types": pwncat.modules.Argument(
|
||||
pwncat.modules.List(str),
|
||||
default=[],
|
||||
help="List of enumeration types to collect (default: all)",
|
||||
),
|
||||
}
|
||||
|
||||
def run(self, output, modules, types):
|
||||
|
Loading…
Reference in New Issue
Block a user