Skip to main content

Allows for runtime hooking of static class functions

Project description

Fishhook

This module allows for swapping out the slot pointers contained in static classes with the generic slot pointers used by python for heap classes. This allows for assigning arbitrary python functions to static class dunders using hook and hook_cls and for applying new functionality to previously unused dunders. A hooked static dunder can be restored to original functionality using the unhook function

it is possible to hook descriptors using hook.property, and an example can be seen below

Calling original methods

orig(self, *args, **kwargs) is a special function that looks up the original implementation of a hooked dunder in the methods cache. It will only work properly when used inside a hooked method where an original implementation existed

hooking single methods

@hook(int)
def __add__(self, other):
  ...
  return orig(self, other)

hooking multiple methods

@hook.cls(int)
class int_hook:
  attr = ...

  def __add__(self, other):
    ...

hooking descriptors

@hook.property(int)
def imag(self):
  ...
  return orig.imag

fishhook.asm

This submodule allows for more in-depth C level hooks. For obvious reasons, this is vastly unstable, mostly provided as an experiment. Originally created as a way to grab a reference to the Interned strings dictionary.

from fishhook import asm
from ctypes import py_object, pythonapi

@asm.hook(pythonapi.PyDict_SetDefault, restype=py_object, argtypes=[py_object, py_object, py_object])
def setdefault(self, key, value):
    if key == 'MAGICVAL':
        return self
    return pythonapi.PyDict_SetDefault(self, key, value)

pythonapi.PyUnicode_InternFromString.restype = py_object
interned = pythonapi.PyUnicode_InternFromString(b'MAGICVAL')

Links

Github

PyPi

Project details


Download files

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

Source Distribution

fishhook-0.3.2.tar.gz (12.3 kB view hashes)

Uploaded Source

Built Distributions

fishhook-0.3.2-pp310-pypy310_pp73-win_amd64.whl (18.6 kB view hashes)

Uploaded PyPy Windows x86-64

fishhook-0.3.2-pp310-pypy310_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.9 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-pp310-pypy310_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (17.0 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-pp310-pypy310_pp73-macosx_10_9_x86_64.whl (15.4 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

fishhook-0.3.2-pp39-pypy39_pp73-win_amd64.whl (18.6 kB view hashes)

Uploaded PyPy Windows x86-64

fishhook-0.3.2-pp39-pypy39_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.9 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-pp39-pypy39_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (17.0 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-pp39-pypy39_pp73-macosx_10_9_x86_64.whl (15.4 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

fishhook-0.3.2-pp38-pypy38_pp73-win_amd64.whl (18.6 kB view hashes)

Uploaded PyPy Windows x86-64

fishhook-0.3.2-pp38-pypy38_pp73-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (16.9 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-pp38-pypy38_pp73-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (17.0 kB view hashes)

Uploaded PyPy manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-pp38-pypy38_pp73-macosx_10_9_x86_64.whl (15.4 kB view hashes)

Uploaded PyPy macOS 10.9+ x86-64

fishhook-0.3.2-cp312-cp312-win_amd64.whl (18.4 kB view hashes)

Uploaded CPython 3.12 Windows x86-64

fishhook-0.3.2-cp312-cp312-win32.whl (18.0 kB view hashes)

Uploaded CPython 3.12 Windows x86

fishhook-0.3.2-cp312-cp312-musllinux_1_1_x86_64.whl (27.4 kB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ x86-64

fishhook-0.3.2-cp312-cp312-musllinux_1_1_i686.whl (27.4 kB view hashes)

Uploaded CPython 3.12 musllinux: musl 1.1+ i686

fishhook-0.3.2-cp312-cp312-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.2 kB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-cp312-cp312-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (24.9 kB view hashes)

Uploaded CPython 3.12 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-cp312-cp312-macosx_10_9_x86_64.whl (15.5 kB view hashes)

Uploaded CPython 3.12 macOS 10.9+ x86-64

fishhook-0.3.2-cp311-cp311-win_amd64.whl (18.4 kB view hashes)

Uploaded CPython 3.11 Windows x86-64

fishhook-0.3.2-cp311-cp311-win32.whl (18.0 kB view hashes)

Uploaded CPython 3.11 Windows x86

fishhook-0.3.2-cp311-cp311-musllinux_1_1_x86_64.whl (27.9 kB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ x86-64

fishhook-0.3.2-cp311-cp311-musllinux_1_1_i686.whl (27.9 kB view hashes)

Uploaded CPython 3.11 musllinux: musl 1.1+ i686

fishhook-0.3.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.3 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-cp311-cp311-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (25.0 kB view hashes)

Uploaded CPython 3.11 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-cp311-cp311-macosx_10_9_x86_64.whl (15.6 kB view hashes)

Uploaded CPython 3.11 macOS 10.9+ x86-64

fishhook-0.3.2-cp310-cp310-win_amd64.whl (18.4 kB view hashes)

Uploaded CPython 3.10 Windows x86-64

fishhook-0.3.2-cp310-cp310-win32.whl (18.0 kB view hashes)

Uploaded CPython 3.10 Windows x86

fishhook-0.3.2-cp310-cp310-musllinux_1_1_x86_64.whl (27.1 kB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ x86-64

fishhook-0.3.2-cp310-cp310-musllinux_1_1_i686.whl (27.1 kB view hashes)

Uploaded CPython 3.10 musllinux: musl 1.1+ i686

fishhook-0.3.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.3 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-cp310-cp310-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (25.0 kB view hashes)

Uploaded CPython 3.10 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-cp310-cp310-macosx_10_9_x86_64.whl (15.6 kB view hashes)

Uploaded CPython 3.10 macOS 10.9+ x86-64

fishhook-0.3.2-cp39-cp39-win_amd64.whl (18.4 kB view hashes)

Uploaded CPython 3.9 Windows x86-64

fishhook-0.3.2-cp39-cp39-win32.whl (18.0 kB view hashes)

Uploaded CPython 3.9 Windows x86

fishhook-0.3.2-cp39-cp39-musllinux_1_1_x86_64.whl (26.8 kB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ x86-64

fishhook-0.3.2-cp39-cp39-musllinux_1_1_i686.whl (26.8 kB view hashes)

Uploaded CPython 3.9 musllinux: musl 1.1+ i686

fishhook-0.3.2-cp39-cp39-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.0 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-cp39-cp39-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (24.8 kB view hashes)

Uploaded CPython 3.9 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-cp39-cp39-macosx_10_9_x86_64.whl (15.6 kB view hashes)

Uploaded CPython 3.9 macOS 10.9+ x86-64

fishhook-0.3.2-cp38-cp38-win_amd64.whl (18.4 kB view hashes)

Uploaded CPython 3.8 Windows x86-64

fishhook-0.3.2-cp38-cp38-win32.whl (18.0 kB view hashes)

Uploaded CPython 3.8 Windows x86

fishhook-0.3.2-cp38-cp38-musllinux_1_1_x86_64.whl (27.1 kB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ x86-64

fishhook-0.3.2-cp38-cp38-musllinux_1_1_i686.whl (27.0 kB view hashes)

Uploaded CPython 3.8 musllinux: musl 1.1+ i686

fishhook-0.3.2-cp38-cp38-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (25.6 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ x86-64

fishhook-0.3.2-cp38-cp38-manylinux_2_5_i686.manylinux1_i686.manylinux_2_17_i686.manylinux2014_i686.whl (25.4 kB view hashes)

Uploaded CPython 3.8 manylinux: glibc 2.17+ i686 manylinux: glibc 2.5+ i686

fishhook-0.3.2-cp38-cp38-macosx_10_9_x86_64.whl (15.6 kB view hashes)

Uploaded CPython 3.8 macOS 10.9+ x86-64

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