-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAutoRun.plugin
77 lines (65 loc) · 2.5 KB
/
AutoRun.plugin
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
import logging
from sqlalchemy.orm import Session
from empire.server.core.db import models
from empire.server.core.hooks import hooks
from empire.server.common.plugins import Plugin
log = logging.getLogger(__name__)
# anything you simply write out (like a script) will run immediately when the
# module is imported (before the class is instantiated)
log.info("autorun plugin loaded")
# this class MUST be named Plugin
class Plugin(Plugin):
def onLoad(self):
self.info = {
"Name": "AutoRun",
# List of one or more authors for the plugin
"Authors": [
{
"Name": "Hubbl3",
"Handle": "@Hubbl3",
"Link": "https://github.com/hubbl3",
}
],
"Description": ("Auto runs a shell command on an agent on checkin"),
"Software": "",
"Techniques": [],
"Comments": [],
}
# Any options needed by the plugin, settable during runtime
self.options = {
# Format:
# value_name : {description, required, default_value}
"Shell Command": {
# The 'Agent' option is the only one that MUST be in a module
"Description": "Shell Command to run on Agent check in",
"Required": True,
"Value": "ps",
}
}
self.hook_name = "checkin_autorun_hook"
hooks.register_hook(
hooks.AFTER_AGENT_CHECKIN_HOOK, self.hook_name, self.autorun
)
def execute(self, command, **kwargs):
"""
Do nothing since execution is triggered by hook
"""
self.options["Shell Command"]["Value"] = command["Shell Command"]
def register(self, mainMenu):
"""
Any modifications to the mainMenu go here - e.g.
registering functions to be run by user commands
"""
self.installPath = mainMenu.installPath
self.main_menu = mainMenu
def autorun(self, db: Session, agent: models.Agent):
res, err = self.main_menu.agenttasksv2.create_task_shell(
db, agent, self.options["Shell Command"]["Value"], True
)
if err:
log.error(f"Failed to create task: {err}")
def shutdown(self):
"""
Kills additional processes that were spawned
"""
hooks.unregister_hook(hooks.AFTER_AGENT_CHECKIN_HOOK, self.hook_name)