first commit

This commit is contained in:
Jean-Marie Mineau 2023-11-15 15:59:13 +01:00
commit cd1e91bb99
Signed by: histausse
GPG key ID: B66AEEDA9B645AD2
287 changed files with 86425 additions and 0 deletions

View file

@ -0,0 +1 @@
home_build

View file

@ -0,0 +1,7 @@
# DialDroid
- [source](https://github.com/dialdroid-android/DIALDroid/tree/master)
- [paper]()
- language: Java 8
- number of years without at least 1 commit since first commit: 5
- License: GPLv3

View file

@ -0,0 +1,37 @@
FROM ubuntu:18.04
RUN apt-get update && apt-get install -y git wget time openjdk-8-jdk ant mysql-server unzip
RUN mkdir /workspace && \
git init /workspace/dialdroid && \
cd /workspace/dialdroid && \
git remote add origin https://github.com/dialdroid-android/DIALDroid.git && \
git fetch --depth=1 origin 968577d43de9c2377a024593e2b2fcecb4b3e875 && \
git reset --hard FETCH_HEAD
RUN git clone https://github.com/dialdroid-android/android-platforms.git /workspace/platforms && \
git clone https://github.com/Sable/android-platforms.git /workspace/sable-platforms && \
cp -R -n /workspace/sable-platforms/* /workspace/platforms/ && \
rm -rf /workspace/sable-platforms
RUN git init /workspace/dialdroid_db && \
cd /workspace/dialdroid_db && \
git remote add origin https://github.com/dialdroid-android/dialdroid-db.git && \
git fetch --depth=1 origin c8d364c11eaced258057d2b214547ccbd32edfc5 && \
git reset --hard FETCH_HEAD
# RUN sed -i 's/mysql-connector-java-5.1.31.jar/mysql-connector-java-8.0.18.jar/g' /workspace/dialdroid/build.xml
RUN cd /workspace/dialdroid && \
mkdir bin && \
cp build/*.txt . && \
cp build/cc.properties . && \
rm -rf build/* && rm -rf target/* && \
update-java-alternatives -s java-1.8.0-openjdk-amd64 && \
ant create_run_jar
# jar in jar + singularity = problems... so:
RUN mkdir /workspace/dialdroid_bin && \
mv /workspace/dialdroid/build/dialdroid.jar /workspace/dialdroid_bin && \
cd /workspace/dialdroid_bin && \
unzip dialdroid.jar
COPY run.sh /

View file

@ -0,0 +1,59 @@
#!/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}