Class: Mdm::Session

Inherits:
ActiveRecord::Base
  • Object
show all
Defined in:
app/models/mdm/session.rb

Overview

A session opened on a #host using an exploit and controlled through a payload to connect back to the local host using meterpreter or a cmd shell.

Instance Attribute Summary collapse

Instance Method Summary collapse

Instance Attribute Details

#close_reasonString

Why the session was closed. Used to differentiate between user killing it local and the session being killed on the remote end.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 82

#closed_atDateTime

When the session was closed on #host.

Returns:

  • (DateTime)


# File 'app/models/mdm/session.rb', line 77

#datastoreHash

Options for exploit and #via_payload modules.

Returns:

  • (Hash)


# File 'app/models/mdm/session.rb', line 88

#descString

Description of session.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 93

#eventsArray<Mdm::Event>

Events that occurred when this session was open.

Returns:



12
13
14
15
16
# File 'app/models/mdm/session.rb', line 12

has_many :events,
class_name: 'Mdm::SessionEvent',
dependent: :delete_all,
inverse_of: :session,
order: 'created_at'

#exploit_attemptMdm::ExploitAttempt

Exploit attempt that created this session.

Returns:



22
23
24
# File 'app/models/mdm/session.rb', line 22

has_one :exploit_attempt,
class_name: 'Mdm::ExploitAttempt',
inverse_of: :session

#hostMdm::Host

Host on which this session was opened.

Returns:



30
31
32
# File 'app/models/mdm/session.rb', line 30

belongs_to :host,
class_name: 'Mdm::Host',
inverse_of: :sessions

#last_seenDateTime

The last time the session was checked to see that it was still open.

Returns:

  • (DateTime)


# File 'app/models/mdm/session.rb', line 98

#local_idInteger

The ID number of the in-memory session.

Returns:

  • (Integer)


# File 'app/models/mdm/session.rb', line 103

#opened_atDateTime

When the session was opened on #host.

Returns:

  • (DateTime)


# File 'app/models/mdm/session.rb', line 108

#platformString

The #host platform.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 113

#portInteger

The remote port on which this session is running on #host.

Returns:

  • (Integer)


# File 'app/models/mdm/session.rb', line 118

#routesArray<Mdm::Route>

Routes tunneled throug this session.

Returns:



38
39
40
41
# File 'app/models/mdm/session.rb', line 38

has_many :routes,
class_name: 'Mdm::Route',
dependent: :delete_all,
inverse_of: :session

#stypeString

The type of the session.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 123

#taskMdm::Session

Session this task touched

Returns:



71
# File 'app/models/mdm/session.rb', line 71

has_many :tasks, :through => :task_sessions, :class_name => 'Mdm::Task'

#task_sessionsArray<Mdm::TaskSession>

Details about sessions this task touched

Returns:



65
# File 'app/models/mdm/session.rb', line 65

has_many :task_sessions, :dependent => :destroy, :class_name => 'Mdm::TaskSession'

#via_exploitString

The full name of the exploit module that opened this session.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 128

#via_payloadString

The full name if the payload module that's running this session.

Returns:

  • (String)


# File 'app/models/mdm/session.rb', line 133

#vuln_attemptMdm::VulnAttempt

Vulnerability attempt that created this session.

Returns:



47
48
49
# File 'app/models/mdm/session.rb', line 47

has_one :vuln_attempt,
class_name: 'Mdm::VulnAttempt',
inverse_of: :session

#workspaceMdm::Workspace (readonly)

The workspace in which this session exists.

Returns:



59
# File 'app/models/mdm/session.rb', line 59

has_one :workspace, :through => :host, :class_name => 'Mdm::Workspace'

Instance Method Details

#upgradeable?true, false

Returns whether the session can be upgraded to a meterpreter session from a shell session on Windows.

Returns:

  • (true)

    if #platform is some version of Windows and #stype is 'shell'.

  • (false)

    otherwise.



162
163
164
165
166
167
168
# File 'app/models/mdm/session.rb', line 162

def upgradeable?
  if (self.platform =~ /win/i and self.stype == 'shell')
    return true
  else
    return false
  end
end