Perimeter
4/2/2012
05:15 PM
John H. Sawyer
John H. Sawyer
Commentary
50%
50%

Quick-Start Guide: Compiling Mac-Robber For Android Vuln Research

How to compile, copy, and run mac-robber on rooted Android devices

In the first part of this series, I covered an introductory approach to basic mobile device security research using some of the same tools and techniques I've used over the years as a forensic investigator. At the end, I mentioned using mac-robber directly on Android and iOS devices, followed by mactime to generate a timeline of the filesystem as a basic method of identifying system activity that can find mobile app vulnerabilities. Today, we'll be digging into some of the gritty details on how to accomplish getting mac-robber on your own Android device, followed by how to do it on iOS devices in the next blog.

Warning: The following steps require a familiarity and comfort with using Linux, which you really and truly need if you're going to be analyzing Android -- a Linux-based operating system.

First, you'll need a rooted Android device. How to actually perform the rooting and rooting-related issues is beyond the scope of this series, but there are plenty of resources on the Internet with detailed steps. The important part is that you must have root access on the device to use mac-robber.

Second, you'll need a way to get files onto your device. One of the first things I install after rooting my device is an SSH server. It comes in handy for several reasons, such as copying files using scp. Alternatively, I'll use adb (part of the Android SDK) to push the files to the device via a USB cable. There are plenty of other methods, but these are two of the quickest and easiest.

Next, you need mac-robber compiled from source code into an executable binary to run on your device. In my test environment, I used a Ubuntu Linux server, but you can easily use MobiSec or Backtrack Linux for the next steps. You'll need to download mac-robber, decompress it, open up a terminal window, and change directories into the folder containing the extracted mac-robber files. Then, run the following commands:

  1. sudo add-apt-repository ppa:linaro-maintainers/toolchain
  2. sudo apt-get install gcc-arm-linux-gnueabi
  3. arm-linux-gnueabi-gcc -static -o -mac-robber mac-robber.c

The first command adds a new Debian package repository that can be used to download and install software from. The second command installs the GNU C Compiler (GCC) cross-compiler allowing C code to be compile for ARM platforms. The third command uses the GCC cross-compiler to compile mac-robber into an executable. After step three, you should have a freshly compiled executable called "mac-robber."

Next, let's create a directory to store mac-robber on the Android filesystem and copy it over. Make sure the adb tool from the Android SDK is in your PATH or run it directly from the "platform-tools" directory.

  1. adb shell
  2. mkdir /data/mac-robber
  3. chmod 755 /data/mac-robber
  4. exit
  5. adb push mac-robber /data/mac-robber/
  6. adb shell "/data/mac-robber/mac-robber -V"

The first four steps start a shell on the Android device, create a new directory to house the mac-robber executable, set permissions on the new directory, and exit the shell. The last two commands push the mac-robber executable that we compiled earlier over to the Android device in the new directory, then run mac-robber with the "-V" flag to show the version information. Provided all of those commands completed successfully, we're ready to proceed. If not, feel free to email me at the address below.

I run mac-robber two ways on the Android device. The first is using SSH like so:

  • ssh root@ "/system/bin/mac-robber /" > AttachmentOpen.body

The second is using adb:

  • ./adb shell "/system/bin/mac-robber /" > AttachmentOpen.body

The resulting file can then be processed into a timeline using mactime from the Sleuth Kit.

  • mactime -b AttachmentOpen.body > AttachmentOpen.timeline

At this point, you have the basics to start creating timelines of the Android filesystem. In the next part of this series, I'll cover how to do the same with iOS, followed by a blog looking at some interesting things and actual vulnerabilities you can uncover using timeline analysis.

John Sawyer is a Senior Security Analyst with InGuardians, Inc. The views and opinions expressed in this blog are his own and do not represent those of his employer. He can be reached at johnhsawyer@gmail.com and found on Twitter @johnhsawyer.

Comment  | 
Print  | 
More Insights
Comments
Newest First  |  Oldest First  |  Threaded View
Jessica Findlay
50%
50%
Jessica Findlay,
User Rank: Apprentice
4/3/2012 | 8:47:58 AM
re: Quick-Start Guide: Compiling Mac-Robber For Android Vuln Research
IGÇÿm sick of the too many VoIPGÇÖs in the market. They claim so much and the output is duuhhh! It doesnGÇÖt work for me though! Does anyone know a quality standard VoIP that runs great on my iPhone 3G? I'm using FriendCaller currently. They are better than any other in term of pricing. Offering great voice quality but cheap Calls to mobile phones and landlines. Works on 3G. Supporting Group Video Calls is a plus as I need to commute for my business purposes. You might try as well http://fc.vc/infographic-fc
Register for Dark Reading Newsletters
White Papers
Cartoon
Current Issue
Flash Poll
Title Partner’s Role in Perimeter Security
Title Partner’s Role in Perimeter Security
Considering how prevalent third-party attacks are, we need to ask hard questions about how partners and suppliers are safeguarding systems and data.
Video
Slideshows
Twitter Feed
Dark Reading - Bug Report
Bug Report
Enterprise Vulnerabilities
From DHS/US-CERT's National Vulnerability Database
CVE-2015-0986
Published: 2015-05-26
Multiple stack-based buffer overflows in Moxa VPort ActiveX SDK Plus before 2.8 allow remote attackers to insert assembly-code lines via vectors involving a regkey (1) set or (2) get command.

CVE-2015-3808
Published: 2015-05-26
The dissect_lbmr_pser function in epan/dissectors/packet-lbmr.c in the LBMR dissector in Wireshark 1.12.x before 1.12.5 does not reject a zero length, which allows remote attackers to cause a denial of service (infinite loop) via a crafted packet.

CVE-2015-3809
Published: 2015-05-26
The dissect_lbmr_pser function in epan/dissectors/packet-lbmr.c in the LBMR dissector in Wireshark 1.12.x before 1.12.5 does not properly track the current offset, which allows remote attackers to cause a denial of service (infinite loop) via a crafted packet.

CVE-2015-3810
Published: 2015-05-26
epan/dissectors/packet-websocket.c in the WebSocket dissector in Wireshark 1.12.x before 1.12.5 uses a recursive algorithm, which allows remote attackers to cause a denial of service (CPU consumption) via a crafted packet.

CVE-2015-3811
Published: 2015-05-26
epan/dissectors/packet-wcp.c in the WCP dissector in Wireshark 1.10.x before 1.10.14 and 1.12.x before 1.12.5 improperly refers to previously processed bytes, which allows remote attackers to cause a denial of service (application crash) via a crafted packet, a different vulnerability than CVE-2015-...

Dark Reading Radio
Archived Dark Reading Radio
Join security and risk expert John Pironti and Dark Reading Editor-in-Chief Tim Wilson for a live online discussion of the sea-changing shift in security strategy and the many ways it is affecting IT and business.