Skip to main content

Static MachO/ObjC Reverse Engineering Toolkit

Project description

Logo

MachO/ObjC Analysis + Editing toolkit.



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
    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.0.0rc3.tar.gz (71.6 kB view details)

Uploaded Source

Built Distribution

k2l-1.0.0rc3-py3-none-any.whl (79.2 kB view details)

Uploaded Python 3

File details

Details for the file k2l-1.0.0rc3.tar.gz.

File metadata

  • Download URL: k2l-1.0.0rc3.tar.gz
  • Upload date:
  • Size: 71.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.0rc1 Linux/4.4.0-22543-Microsoft

File hashes

Hashes for k2l-1.0.0rc3.tar.gz
Algorithm Hash digest
SHA256 38f0cbf1350e8ad1fb334bfd31f4de85b64d11995f13caba29ca57b012a8ed70
MD5 6e3ab5492dbae13111822b788f99f2f0
BLAKE2b-256 62d340ba6f7d1f4228a04c17055e68d2f7c5206fe5a7b458ac290979086974ee

See more details on using hashes here.

File details

Details for the file k2l-1.0.0rc3-py3-none-any.whl.

File metadata

  • Download URL: k2l-1.0.0rc3-py3-none-any.whl
  • Upload date:
  • Size: 79.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.0rc1 Linux/4.4.0-22543-Microsoft

File hashes

Hashes for k2l-1.0.0rc3-py3-none-any.whl
Algorithm Hash digest
SHA256 32c37a44fc850dc65f8bbfea540643b0ffee41c3ca7b20f18753334e4abe8a5f
MD5 e999c775ef72f8d5bfe2f8f07e9bc585
BLAKE2b-256 db57436c3bcc273db64d7ffcddcfed55bf19d4b8bf33b67afb59982464acda80

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