Skip to main content

Static MachO/ObjC Reverse Engineering Toolkit

Project description

Logo

MachO/ObjC Analysis + Editing toolkit.


Library Documentation

Installation

# Installing
pip3 install k2l

# Updating
pip3 install --upgrade k2l

Usage

> $ ktool
Usage: ktool [command] <flags> [filename]

Commands:

GUI (Still in active development) ---
    ktool open [filename] - Open the ktool command line GUI and browse a file

MachO Analysis ---
    dump - Tools to reconstruct headers and TBDs from compiled MachOs
    kcache - Kernel cache specific tools
    list - Print various lists (Classlist, etc.)
    symbols - Print various tables (Symbols, imports, exports)
    info - Print misc info about the target mach-o

MachO Editing ---
    insert - Utils for inserting load commands into MachO Binaries
    edit - Utils for editing MachO Binaries
    lipo - Utilities for combining/separating slices in fat MachO files.

Misc Utilities ---
    file - Print very basic info about the MachO
    img4 - IMG4 Utilities
    

Run `ktool [command]` for info/examples on using that command

written in pure, 100% python for the sake of platform independence when operating on static binaries and libraries. this should run on any and all implementations of python3.

Tested on:

  • Windows/Windows on ARM64
  • MacOS x86/arm64
  • Linux/Linux ARM64
  • iOS (iSH, ssh)
  • Android (Termux)
  • WebAssembly
  • Brython

Credits

Chained fixup processing is currently entirely based on https://github.com/xpcmdshell/bn-chained-fixups

Special thanks to

JLevin and *OS Internals for existing

arandomdev for guidance + code

Blacktop for their amazing ipsw project: https://github.com/blacktop/ipsw

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

k2l-1.1.4.tar.gz (85.1 kB view details)

Uploaded Source

Built Distribution

k2l-1.1.4-py3-none-any.whl (93.4 kB view details)

Uploaded Python 3

File details

Details for the file k2l-1.1.4.tar.gz.

File metadata

  • Download URL: k2l-1.1.4.tar.gz
  • Upload date:
  • Size: 85.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.8.10 Linux/4.4.0-22572-Microsoft

File hashes

Hashes for k2l-1.1.4.tar.gz
Algorithm Hash digest
SHA256 a0b0cfc9c49a73c2aa174137297bd6657e682415d0112ae4a7bf3cc4b3fe27a2
MD5 8b1792fb5039cb8745fd127a6109fb71
BLAKE2b-256 c6176a17269965afecb63f1a43d61528ca0ad3ab04d9cb6b80fa32ae3930f9ff

See more details on using hashes here.

File details

Details for the file k2l-1.1.4-py3-none-any.whl.

File metadata

  • Download URL: k2l-1.1.4-py3-none-any.whl
  • Upload date:
  • Size: 93.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.8.10 Linux/4.4.0-22572-Microsoft

File hashes

Hashes for k2l-1.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 975a75e862b328ba4e911d524f423e7d6d95693901ff56f612a8dd8a4b58fb29
MD5 d916e2ff3b835bcc511434a58769c4f7
BLAKE2b-256 bece9901bf2ee66cce0e7eadb13847c7bdcf47dcc96262952da50e79caf857df

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page