59 lines
3.1 KiB
Bash
Executable file
59 lines
3.1 KiB
Bash
Executable file
#!/usr/bin/env bash
|
|
|
|
APK_FILENAME=$1
|
|
|
|
export TIME="time: %e
|
|
kernel-cpu-time: %S
|
|
user-cpu-time: %U
|
|
max-rss-mem: %M
|
|
avg-rss-mem: %t
|
|
avg-total-mem: %K
|
|
page-size: %Z
|
|
nb-major-page-fault: %F
|
|
nb-minor-page-fault: %R
|
|
nb-fs-input: %I
|
|
nb-fs-output: %O
|
|
nb-socket-msg-received: %r
|
|
nb-socket-msg-sent: %s
|
|
nb-signal-delivered: %k
|
|
exit-status: %x"
|
|
|
|
export CLASS_PATH='/workspace/dialdroid_bin::/workspace/dialdroid_bin/infoflow-android-dialdroid.jar:/workspace/dialdroid_bin/infoflow-dialdroid.jar:/workspace/dialdroid_bin/soot-dialdroid.jar:/workspace/dialdroid_bin/ic3-dialdroid-classes.jar:/workspace/dialdroid_bin/axml-2.0.0.jar:/workspace/dialdroid_bin/coal-0.1.7.jar:/workspace/dialdroid_bin/coal-strings-0.1.2.jar:/workspace/dialdroid_bin/commons-cli-1.3.1.jar:/workspace/dialdroid_bin/jsch-0.1.51.jar:/workspace/dialdroid_bin/log4j-1.2.17.jar:/workspace/dialdroid_bin/mysql-connector-java-5.1.31.jar:/workspace/dialdroid_bin/protobuf-java-2.5.0.jar:/workspace/dialdroid_bin/slf4j-api-1.7.7.jar:/workspace/dialdroid_bin/slf4j-log4j12-1.7.13.jar:/workspace/dialdroid_bin/herosclasses-trunk.jar:/workspace/dialdroid_bin/soot-dialdroid.jar:/workspace/dialdroid_bin/infoflow-android-dialdroid.jar:/workspace/dialdroid_bin/infoflow-dialdroid.jar'
|
|
|
|
|
|
# Create and run database as current user on specific file
|
|
#SQL_DATA=`mktemp -d`
|
|
#
|
|
SQL_DATA=/mnt/mysql
|
|
LOG_FILE="$SQL_DATA/log"
|
|
mkdir $SQL_DATA
|
|
chmod 777 $SQL_DATA
|
|
chmod +x $SQL_DATA/..
|
|
mysqld --datadir=$SQL_DATA --log-error=$LOG_FILE --default-time-zone='+00:00' --initialize-insecure
|
|
#mysqld --datadir=$SQL_DATA --skip-name-resolve --log-error=$LOG_FILE --default-time-zone='+00:00' --bind-address=127.0.0.1 --mysqlx=OFF --socket=$SQL_DATA/mysqld.sock &
|
|
mysqld --datadir=$SQL_DATA --skip-name-resolve --log-error=$LOG_FILE --default-time-zone='+00:00' --bind-address=127.0.0.1 --pid-file=/mnt/mysql/pid.pid --socket=$SQL_DATA/mysqld.sock &
|
|
DB_PID="$!"
|
|
|
|
# Wait for connection
|
|
until mysql -u root --socket="$SQL_DATA/mysqld.sock" -e 'CREATE DATABASE dialdroid_test'
|
|
do
|
|
echo 'Waiting for DB, error 2002 ^ is normal'
|
|
sleep 1
|
|
done
|
|
mysql -u root --socket="$SQL_DATA/mysqld.sock" dialdroid_test < /workspace/dialdroid_db/DIALDroid.sql
|
|
mysql -u root --socket="$SQL_DATA/mysqld.sock" -e "CREATE USER 'root' IDENTIFIED BY 'Nice2Hear';"
|
|
mysql -u root --socket="$SQL_DATA/mysqld.sock" -e "GRANT ALL PRIVILEGES ON dialdroid_test.* TO 'root';"
|
|
|
|
cd /mnt
|
|
|
|
ln -s /workspace/dialdroid/build/cc.properties .
|
|
ln -s /workspace/dialdroid/build/AndroidCallbacks.txt .
|
|
ln -s /workspace/dialdroid/build/EasyTaintWrapperSource.txt .
|
|
ln -s /workspace/dialdroid/build/ic3-android.jar .
|
|
|
|
#/usr/bin/time -o /mnt/report -q /usr/bin/timeout --kill-after=20s ${TIMEOUT} java ${JAVA_PARAM} -jar /workspace/dialdroid/build/dialdroid.jar appanalysis /workspace/platforms/ dialdroid_test 127.0.0.1 /mnt/${APK_FILENAME} SOCIAL > /mnt/stdout 2> /mnt/stderr
|
|
|
|
/usr/bin/time -o /mnt/report -q /usr/bin/timeout --kill-after=20s ${TIMEOUT} java ${JAVA_PARAM} -cp ${CLASS_PATH} com.yaogroup.collusion.AppAnalysis appanalysis /workspace/platforms/ dialdroid_test 127.0.0.1 /mnt/${APK_FILENAME} SOCIAL > /mnt/stdout 2> /mnt/stderr
|
|
|
|
|
|
kill -9 ${DB_PID}
|