experiments in optimal adaptive timing side channel attacks https://awoo.systems
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
haskal 8444759abd update readme 2 months ago
clocktower update readme 2 months ago
.flake8 Initial commit 2 months ago
.gitignore Initial commit 2 months ago
LICENSE Initial commit 2 months ago
Makefile Initial commit 2 months ago
README.md update readme 2 months ago
setup.py update readme 2 months ago

README.md

clocktower

clocktower is a python package implementing efficient strategies for executing adaptive timing side channel attacks. the goal is to use statistics to guide public input guesses in order to reveal the secret with a given level of statistical significance in a minimum number of rounds. the current strategy already significantly outperforms the naive non-adaptive strategy, and thus can be used as a framework for mounting attacks

howto

currently the model is that a correct guess will result in a longer time taken to execute, and all incorrect guesses will take the same (lower) time to execute
more abstraction is planned for different target models

import clocktower

# default input space: 0-255
# default significance level: 0.01
mgr = clocktower.ClocktowerManager()

# when next_guess() returns None, the algoritm has a statistically significant answer
while (guess := mgr.next_guess()) is not None:
    # execute the guess and get the result
    timing_value = run_attack(guess)
    mgr.update(guess, timing_value)

print(mgr.get_best_guess())