Class: MetasploitDataModels::ModuleRun

Inherits:
ApplicationRecord
  • Object
show all
Defined in:
app/models/metasploit_data_models/module_run.rb

Overview

ModuleRun holds the record of having launched a piece of Metasploit content. It has associations to Mdm::User for audit purposes, and makes polymorphic associations to things like Mdm::Vuln and Mdm::Host for flexible record keeping about activity attacking either specific vulns or just making mischief on specific remote targets w/out the context of a vuln or even a remote IP service.

There are also associations to Mdm::Session for two use cases: a spawned_session is a session created by the ModuleRun. A target_session is a session that the ModuleRun is acting upon (e.g.) for running a post module.

Constant Summary collapse

SUCCEED =

Marks the module as having successfully run

'succeeded'
FAIL =

Marks the run as having not run successfully

'failed'
ERROR =

Marks the module as having had a runtime error

'error'
VALID_STATUSES =

MetasploitDataModels::ModuleRun objects will be validated against these statuses

[SUCCEED, FAIL, ERROR]

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#attempted_atDatetime

The date/time when this module was run

Returns:

  • (Datetime)


# File 'app/models/metasploit_data_models/module_run.rb', line 28

#fail_detailString

Arbitrary information captured by the module to give in-depth reason for failure

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 32

#fail_reasonString

One of the values of the constants in Msf::Module::Failure

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 36

#lootsActiveRecord::Relation<Mdm::Loot>

The sweet, sweet loot taken by this module_run

Returns:



77
78
79
# File 'app/models/metasploit_data_models/module_run.rb', line 77

has_many :loots,
class_name: 'Mdm::Loot',
inverse_of: :module_run

#module_detailActiveRecord::Relation<Mdm::Module::Detail>

The cached module information

Returns:



85
86
87
88
89
# File 'app/models/metasploit_data_models/module_run.rb', line 85

belongs_to :module_detail,
class_name: 'Mdm::Module::Detail',
inverse_of: :module_runs,
foreign_key: :module_fullname,
primary_key: :fullname

#module_nameString

The Msf::Module#fullname of the module being run

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 40

#portFixnum

The port that the remote host was attacked on, if any

Returns:

  • (Fixnum)


# File 'app/models/metasploit_data_models/module_run.rb', line 44

#protoString

The name of the protocol that the host was attacked on, if any

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 48

#session_idDatetime

The Mdm::Session that this was run with, in the case of a post module. In exploit modules, this field will remain null.

Returns:

  • (Datetime)


# File 'app/models/metasploit_data_models/module_run.rb', line 52

#spawned_sessionMdm::Session

The session created by running this module. Note that this is NOT the session that modules are run on.

Returns:



97
98
99
# File 'app/models/metasploit_data_models/module_run.rb', line 97

has_one :spawned_session,
class_name: 'Mdm::Session',
inverse_of: :originating_module_run

#statusString

The result of running the module

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 57

#target_sessionMdm::Session

The session this module was run on, if any. Note that this is NOT a session created by this module run of exploit modules.

Returns:



109
110
111
112
# File 'app/models/metasploit_data_models/module_run.rb', line 109

belongs_to :target_session,
class_name: 'Mdm::Session',
foreign_key: :session_id,
inverse_of: :target_module_runs

#trackableMdm::Host, Mdm::Vuln

A polymorphic association that is tracked as being related to this module run. Mdm::Host and Mdm::Vuln can each have MetasploitDataModels::ModuleRun objects.

Returns:



122
# File 'app/models/metasploit_data_models/module_run.rb', line 122

belongs_to :trackable, polymorphic: true

#userMdm::User

The user that launched this module

Returns:



130
131
132
133
# File 'app/models/metasploit_data_models/module_run.rb', line 130

belongs_to :user,
class_name:  'Mdm::User',
foreign_key: 'user_id',
inverse_of: :module_runs

#usernameString

The name of the user running this module

Returns:

  • (String)


# File 'app/models/metasploit_data_models/module_run.rb', line 61

Instance Method Details

#module_name_componentsArray

Splits strings formatted like Msf::Module#fullname into components

Examples:

module_name = "exploit/windows/multi/mah-rad-exploit"
module_name_components  # => ["exploit","windows","multi","mah-rad-exploit"]

Returns:

  • (Array)


174
175
176
# File 'app/models/metasploit_data_models/module_run.rb', line 174

def module_name_components
  module_fullname.split('/')
end