xref: /aosp_15_r20/external/AFLplusplus/utils/distributed_fuzzing/sync_script.sh (revision 08b48e0b10e97b33e7b60c5b6e2243bd915777f2)
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