1 unstable release

0.1.0 Mar 16, 2022

#5 in #pwn

Download history 78/week @ 2024-07-22 116/week @ 2024-07-29 148/week @ 2024-08-05 212/week @ 2024-08-12 202/week @ 2024-08-19 87/week @ 2024-08-26 117/week @ 2024-09-02 76/week @ 2024-09-09 50/week @ 2024-09-16 62/week @ 2024-09-23 48/week @ 2024-09-30 79/week @ 2024-10-07 23/week @ 2024-10-14 23/week @ 2024-10-21 35/week @ 2024-10-28 64/week @ 2024-11-04

163 downloads per month

Apache-2.0

7KB
69 lines

dobby-rs

Dobby is a lightweight, multi-platform, multi-architecture exploit hook framework.

This crate is a rusty binding of Dobby.

Caution: Hooking is NOT SAFE! Use at your own risk.

Quickstart

use dobby_rs::{resolve_symbol, hook, Address};
use std::mem::transmute;

#[inline(never)]
#[no_mangle]
extern "C" fn add(a: u64, b: u64) -> u64 {
    a + b
}

#[inline(never)]
#[no_mangle]
extern "C" fn sub(a: u64, b: u64) -> u64 {
    a - b
}

unsafe {
    let addr = add as usize as Address;
    let replace = sub as usize as Address;

    let origin = hook(addr, replace).unwrap();
    let origin: extern "C" fn(u64, u64) -> u64 = transmute(origin);

    assert_eq!(origin(2, 1), 2 + 1);
    assert_eq!(add(2, 1), 2 - 1);
}

Supported Target

  • Android

    • x86
    • x86_64
    • armv7
    • aarch64
  • MacOS

    • x86_64
    • aarch64
  • Linux

    • (WIP) x86
    • x86_64

lib.rs:

This crate is a rusty binding of Dobby.

Quickstart

use dobby_rs::{resolve_symbol, hook, Address};
use std::mem::transmute;

#[inline(never)]
#[no_mangle]
extern "C" fn add(a: u64, b: u64) -> u64 {
    a + b
}

#[inline(never)]
#[no_mangle]
extern "C" fn sub(a: u64, b: u64) -> u64 {
    a - b
}

unsafe {
    let addr = add as usize as Address;
    let replace = sub as usize as Address;

    let origin = hook(addr, replace).unwrap();
    let origin: extern "C" fn(u64, u64) -> u64 = transmute(origin);

    assert_eq!(origin(2, 1), 2 + 1);
    assert_eq!(add(2, 1), 2 - 1);
}

Dependencies

~3MB
~17K SLoC