1*08b48e0bSAndroid Build Coastguard Worker#!/bin/sh 2*08b48e0bSAndroid Build Coastguard Worker# 3*08b48e0bSAndroid Build Coastguard Worker# american fuzzy lop++ - fuzzer synchronization tool 4*08b48e0bSAndroid Build Coastguard Worker# -------------------------------------------------- 5*08b48e0bSAndroid Build Coastguard Worker# 6*08b48e0bSAndroid Build Coastguard Worker# Originally written by Michal Zalewski 7*08b48e0bSAndroid Build Coastguard Worker# 8*08b48e0bSAndroid Build Coastguard Worker# Copyright 2014 Google Inc. All rights reserved. 9*08b48e0bSAndroid Build Coastguard Worker# Copyright 2019-2024 AFLplusplus Project. All rights reserved. 10*08b48e0bSAndroid Build Coastguard Worker# 11*08b48e0bSAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License"); 12*08b48e0bSAndroid Build Coastguard Worker# you may not use this file except in compliance with the License. 13*08b48e0bSAndroid Build Coastguard Worker# You may obtain a copy of the License at: 14*08b48e0bSAndroid Build Coastguard Worker# 15*08b48e0bSAndroid Build Coastguard Worker# http://www.apache.org/licenses/LICENSE-2.0 16*08b48e0bSAndroid Build Coastguard Worker# 17*08b48e0bSAndroid Build Coastguard Worker# To make this script work: 18*08b48e0bSAndroid Build Coastguard Worker# 19*08b48e0bSAndroid Build Coastguard Worker# - Edit FUZZ_HOSTS, FUZZ_DOMAIN, FUZZ_USER, and SYNC_DIR to reflect your 20*08b48e0bSAndroid Build Coastguard Worker# environment. 21*08b48e0bSAndroid Build Coastguard Worker# 22*08b48e0bSAndroid Build Coastguard Worker# - Make sure that the system you are running this on can log into FUZZ_HOSTS 23*08b48e0bSAndroid Build Coastguard Worker# without a password (authorized_keys or otherwise). 24*08b48e0bSAndroid Build Coastguard Worker# 25*08b48e0bSAndroid Build Coastguard Worker# - Make sure that every fuzzer is running with -o pointing to SYNC_DIR and -S 26*08b48e0bSAndroid Build Coastguard Worker# that consists of its local host name, followed by an underscore, and then 27*08b48e0bSAndroid Build Coastguard Worker# by some host-local fuzzer ID. 28*08b48e0bSAndroid Build Coastguard Worker# 29*08b48e0bSAndroid Build Coastguard Worker 30*08b48e0bSAndroid Build Coastguard Worker# Hosts to synchronize the data across. 31*08b48e0bSAndroid Build Coastguard WorkerFUZZ_HOSTS='host1 host2 host3 host4' 32*08b48e0bSAndroid Build Coastguard Worker 33*08b48e0bSAndroid Build Coastguard Worker# Domain for all hosts 34*08b48e0bSAndroid Build Coastguard WorkerFUZZ_DOMAIN='example.com' 35*08b48e0bSAndroid Build Coastguard Worker 36*08b48e0bSAndroid Build Coastguard Worker# Remote user for SSH 37*08b48e0bSAndroid Build Coastguard WorkerFUZZ_USER=bob 38*08b48e0bSAndroid Build Coastguard Worker 39*08b48e0bSAndroid Build Coastguard Worker# Directory to synchronize 40*08b48e0bSAndroid Build Coastguard WorkerSYNC_DIR='/home/bob/sync_dir' 41*08b48e0bSAndroid Build Coastguard Worker 42*08b48e0bSAndroid Build Coastguard Worker# We only capture -M main nodes, set the name to your chosen naming scheme 43*08b48e0bSAndroid Build Coastguard WorkerMAIN_NAME='main' 44*08b48e0bSAndroid Build Coastguard Worker 45*08b48e0bSAndroid Build Coastguard Worker# Interval (seconds) between sync attempts (eg one hour) 46*08b48e0bSAndroid Build Coastguard WorkerSYNC_INTERVAL=$((60 * 60)) 47*08b48e0bSAndroid Build Coastguard Worker 48*08b48e0bSAndroid Build Coastguard Workerif [ "$AFL_ALLOW_TMP" = "" ]; then 49*08b48e0bSAndroid Build Coastguard Worker 50*08b48e0bSAndroid Build Coastguard Worker if [ "$PWD" = "/tmp" -o "$PWD" = "/var/tmp" ]; then 51*08b48e0bSAndroid Build Coastguard Worker echo "[-] Error: do not use shared /tmp or /var/tmp directories with this script." 1>&2 52*08b48e0bSAndroid Build Coastguard Worker exit 1 53*08b48e0bSAndroid Build Coastguard Worker fi 54*08b48e0bSAndroid Build Coastguard Worker 55*08b48e0bSAndroid Build Coastguard Workerfi 56*08b48e0bSAndroid Build Coastguard Worker 57*08b48e0bSAndroid Build Coastguard Workerrm -rf .sync_tmp 2>/dev/null 58*08b48e0bSAndroid Build Coastguard Workermkdir .sync_tmp || exit 1 59*08b48e0bSAndroid Build Coastguard Worker 60*08b48e0bSAndroid Build Coastguard Workerwhile :; do 61*08b48e0bSAndroid Build Coastguard Worker 62*08b48e0bSAndroid Build Coastguard Worker # Pull data in... 63*08b48e0bSAndroid Build Coastguard Worker 64*08b48e0bSAndroid Build Coastguard Worker for host in $FUZZ_HOSTS; do 65*08b48e0bSAndroid Build Coastguard Worker 66*08b48e0bSAndroid Build Coastguard Worker echo "[*] Retrieving data from ${host}.${FUZZ_DOMAIN}..." 67*08b48e0bSAndroid Build Coastguard Worker 68*08b48e0bSAndroid Build Coastguard Worker ssh -o 'passwordauthentication no' ${FUZZ_USER}@${host}.$FUZZ_DOMAIN \ 69*08b48e0bSAndroid Build Coastguard Worker "cd '$SYNC_DIR' && tar -czf - ${host}_${MAIN_NAME}*/" > ".sync_tmp/${host}.tgz" 70*08b48e0bSAndroid Build Coastguard Worker 71*08b48e0bSAndroid Build Coastguard Worker done 72*08b48e0bSAndroid Build Coastguard Worker 73*08b48e0bSAndroid Build Coastguard Worker # Distribute data. For large fleets, see tips in the docs/ directory. 74*08b48e0bSAndroid Build Coastguard Worker 75*08b48e0bSAndroid Build Coastguard Worker for dst_host in $FUZZ_HOSTS; do 76*08b48e0bSAndroid Build Coastguard Worker 77*08b48e0bSAndroid Build Coastguard Worker echo "[*] Distributing data to ${dst_host}.${FUZZ_DOMAIN}..." 78*08b48e0bSAndroid Build Coastguard Worker 79*08b48e0bSAndroid Build Coastguard Worker for src_host in $FUZZ_HOSTS; do 80*08b48e0bSAndroid Build Coastguard Worker 81*08b48e0bSAndroid Build Coastguard Worker test "$src_host" = "$dst_host" && continue 82*08b48e0bSAndroid Build Coastguard Worker 83*08b48e0bSAndroid Build Coastguard Worker echo " Sending fuzzer data from ${src_host}.${FUZZ_DOMAIN}..." 84*08b48e0bSAndroid Build Coastguard Worker 85*08b48e0bSAndroid Build Coastguard Worker ssh -o 'passwordauthentication no' ${FUZZ_USER}@$dst_host \ 86*08b48e0bSAndroid Build Coastguard Worker "cd '$SYNC_DIR' && tar -xkzf - " < ".sync_tmp/${src_host}.tgz" 87*08b48e0bSAndroid Build Coastguard Worker 88*08b48e0bSAndroid Build Coastguard Worker done 89*08b48e0bSAndroid Build Coastguard Worker 90*08b48e0bSAndroid Build Coastguard Worker done 91*08b48e0bSAndroid Build Coastguard Worker 92*08b48e0bSAndroid Build Coastguard Worker echo "[+] Done. Sleeping for $SYNC_INTERVAL seconds (Ctrl-C to quit)." 93*08b48e0bSAndroid Build Coastguard Worker 94*08b48e0bSAndroid Build Coastguard Worker sleep $SYNC_INTERVAL 95*08b48e0bSAndroid Build Coastguard Worker 96*08b48e0bSAndroid Build Coastguard Workerdone 97*08b48e0bSAndroid Build Coastguard Worker 98