/Frida-Python-Binding

Easy to use Frida python binding script

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

Frida-Python-Binding

Easy to use Frida python binding script for Android reversing automation. The idea behind the script was to make frida's binding much easier and quicker, as of:

  1. Enumerate every connected device (usb/remote/local) to your machine and generate a selection menu.
  2. Automatically install frida agent on a selected device with changeable arguments (dir location, execution path etc). inside the bin folder I have placed a frida-server v10.7.3 for android x86, make sure to use the same version on your client or just replace the file with your current version, in other cases you can use the --frida-exec-path argument to specify a different path for your frida-server binary.
  3. Ability to enumerate running processes(--list-pids)/installed packages(--list-apps) and generate a selection menu for the user, so each spawn/attach will become easier to handle.
  4. Download and set as default new/old frida-server version and arch by user demand, use the -d argument to use this feature, also the user can choose a specific version that is already located under bin folder, use the -fv argument.

Demo

app-demo

Basic Usage

Some examples:
fridaPyBinding.py --list-apps --script /your/path/2/file
fridaPyBinding.py -i /your/path/2/frida-server --spawn com.android.browser

Use the --help argument to get the full arguments list

usage: fridaPyBinding.py [-h] [-s SPAWN] [-p PID] [-a ATTACH] [-S SCRIPT] [-d]
                         [-fv] [-P FRIDA_PATH_DEVICE] [-i FRIDA_EXEC_PATH]
                         [-n FRIDA_SERVER_NAME] [-lp] [-la] [-t TIMEOUT]

Frida RE Easy Python Binding

optional arguments:
  -h, --help            show this help message and exit
  -s SPAWN, --spawn SPAWN
                        Set package name to spawning a new process
  -p PID, --pid PID     Specify a PID number
  -a ATTACH, --attach ATTACH
                        Set a process name to attach
  -S SCRIPT, --script SCRIPT
                        Specify a Javascript hooking script name
  -d, --download-frida  Check this option for auto downloading frida-server
                        from repo
  -fv, --frida-version  Set frida-server version to use as default
  -P FRIDA_PATH_DEVICE, --frida-path-device FRIDA_PATH_DEVICE
                        Set frida-server path on selected device [Default
                        /data/local/tmp/]
  -i FRIDA_EXEC_PATH, --frida-exec-path FRIDA_EXEC_PATH
                        Set frida-server executable installation path
  -n FRIDA_SERVER_NAME, --frida-server-name FRIDA_SERVER_NAME
                        Set frida-server executable name on device [Default
                        frida-server]
  -lp, --list-pids      Enumerate running processes by PID on selected device
  -la, --list-apps      Enumerate installed applications on selected device
  -t TIMEOUT, --timeout TIMEOUT
                        Set USB connect timeout [Default 1000]

How-to install

  • Make sure to use Python 3.x.
  • Install adb via Android SDK and check that the environment variables are set correctly.
  • Install the dependecies by running:
    pip install -r requirements.txt

Special thanks

  • A special thanks to Tomer Zait (realgam3) for sharing his wide knowledge on FridaRE, and being an amazing friend :)