11 releases

0.3.8 May 6, 2024
0.3.7 Jan 24, 2024
0.2.0 Jan 9, 2024
0.1.0 Nov 1, 2022

#491 in Asynchronous

MIT and LGPL-3.0-or-later

125KB
3.5K SLoC

ctf-pwn

crate

Pwn utilities for Rust.

Features

Pipe

  • Converting TCP Stream or Process to Pipe
  • Conditional reading
  • Bridging pipe to stdout/stdin
  • Payload crafter
  • Ansi event support for ncurses like shells

Shell

  • Intel x86
  • Amd x64
  • Arm
  • Risc-V

Binary Parsing

  • Elf
  • PE

Examples

Connecting to tcp stream

let mut pipe = TcpPipe::connect("127.0.0.1:1337").await?;

Spawning new process

let mut pipe = ProcessPipe::from_app("ls").await?;

let mut pipe = ProcessPipe::from_app_args("ls", ["-l", "-a"]).await?;

Generic loading

let mut pipe = Pipe::new(stdin(), stdout());

Reading examples

let data: Vec<u8> = pipe.recv().await?;
let data: Vec<u8> = pipe.recv_until("Name:", false).await?;
let data: Vec<u8> = pipe.recv_until([0x01, 0x02, 0x03], false).await?;
let data: String = pipe.recv_line_utf8().await?;
let data: AsciiString = pipe.recv_line_ascii().await?;

Regex

let data = pipe.recv_until(r"(Ok)|(Error)", true).await?;
let flag = pipe.recv_regex_utf8(r"HTB\{[^\}] \}").await?;

Interactive shell

pipe.interactive_shell().await?;

Ncurses support

Sending ansi commands

pipe.write_ansi_command(ansi::Down).await?;
pipe.write_ansi_command(ansi::Right).await?;
pipe.write_ansi_command(ansi::Enter).await?;

Ansi event based interactive shell

pipe.interactive_ansi().await?;

Payload

let payload = Payload::builder()
    .recv_until("> ", false)
    .push("1")
    .push("\n")
    .send()
    .recv_until("Insert card's serial number: ", false)
    .push_line("I19x%7$hn")
    .send()
    .recv_regex_utf8(r"HTB\{[^\}] \}")
    .build();

let flag = pipe.payload(payload).await?;
println!("{flag}");

Elf

let elf = Elf::parse("app_path").await?;
let got: &HashMap<String, u64> = elf.got();
let plt: &HashMap<String, u64> = elf.plt();
let symbols: &HashMap<String, Symbol> = elf.symbols();
let dynamic_symbols: &HashMap<String, Symbol> = elf.dynamic_symbols();

Dependencies

~6–13MB
~150K SLoC