-
Notifications
You must be signed in to change notification settings - Fork 69
/
Copy pathapk2url.sh
142 lines (120 loc) · 5.35 KB
/
apk2url.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
#!/bin/bash
red='\033[0;31m'
green='\033[0;32m'
yellow='\033[0;33m'
purple='\033[0;35m'
cyan='\033[0;36m'
reset='\033[0m'
printf """$green
█████╗ ██████╗ ██╗ ██╗██████╗ ██╗ ██╗██████╗ ██╗
██╔══██╗██╔══██╗██║ ██╔╝╚════██╗██║ ██║██╔══██╗██║v1.2
███████║██████╔╝█████╔╝ █████╔╝██║ ██║██████╔╝██║By
██╔══██║██╔═══╝ ██╔═██╗ ██╔═══╝ ██║ ██║██╔══██╗██║n0mi1k
██║ ██║██║ ██║ ██╗███████╗╚██████╔╝██║ ██║███████╗
╚═╝ ╚═╝╚═╝ ╚═╝ ╚═╝╚══════╝ ╚═════╝ ╚═╝ ╚═╝╚══════╝
$reset"""
dissectApktool() {
printf "$cyan[+] Disassembling ${1}with Apktool...\n$reset"
apktool d $APKPATH -o $APKTOOLDIR >/dev/null 2>&1
}
dissectJadx() {
printf "$cyan[+] Decompiling ${1}with Jadx...\n$reset"
jadx $APKPATH -d $JADXDIR>/dev/null 2>&1
}
extractEndpoints() {
printf "$green[+] Beginning Endpoint Extraction...\n$reset"
printf "$yellow[~] Extracting URLs...\n$reset"
rawurlmatch=$(grep -rIoE '(\b(https?)://|www\.)[-A-Za-z0-9+&@#/%?=~_|!:,.;]*[-A-Za-z0-9+&@#/%=~_|]' $DECOMPILEDIR)
urlmatches=$(printf "%s" "$rawurlmatch" | awk -F':' '{sub(/^[^:]+:/, "", $0); print}' | sort -u)
printf "%s\n" "$urlmatches" > "${ENDPOINTDIR}/${BASENAME}_endpoints.txt"
printf "$yellow[~] Extracting IPs...\n$reset"
rawipmatch=$(grep -rIoP '\b((https?)://)?(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]?)\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\b(?::\b(6553[0-5]|655[0-2][0-9]|65[0-4][0-9]{2}|6[0-4][0-9]{3}|[1-5][0-9]{4}|[1-9][0-9]{0,3}))?' $DECOMPILEDIR)
ipmatches=$(printf "%s" "$rawipmatch"| awk -F':' '{sub(/^[^:]+:/, "", $0); print}' | sort -u)
printf "%s\n" "$ipmatches" >> "${ENDPOINTDIR}/${BASENAME}_endpoints.txt"
if [[ $2 == "log" ]]; then
printf "$purple[~] Writing Logs to: ${ENDPOINTDIR}/${BASENAME}_log.txt\n$reset"
printf "%s\n" "$rawurlmatch" > "$ENDPOINTDIR/${BASENAME}_log.txt"
printf "%s\n" "$rawipmatch" >> "$ENDPOINTDIR/${BASENAME}_log.txt"
fi
printf "$purple[~] Performing Uniq Filter...$reset"
grep -oE '((http|https)://[^/]+)' ${ENDPOINTDIR}/${BASENAME}_endpoints.txt | awk -F/ '{print $1 "//" $3}' | sort -u > ${ENDPOINTDIR}/${BASENAME}_uniqurls.txt
grep -E '^www.*' ${ENDPOINTDIR}/${BASENAME}_endpoints.txt >> ${ENDPOINTDIR}/${BASENAME}_uniqurls.txt
grep -E '[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}.*' ${ENDPOINTDIR}/${BASENAME}_endpoints.txt >> ${ENDPOINTDIR}/${BASENAME}_uniqurls.txt
printf "$purple\n[~] Wrote Uniq Domains to: ${ENDPOINTDIR}/${BASENAME}_uniqurls.txt\n$reset"
printf "$green[*] Endpoints Extracted to: ${ENDPOINTDIR}/${BASENAME}_endpoints.txt\n$reset"
}
mainJob() {
printf "$green[++++] Decompiling $BASENAME.apk \n$reset"
printf "$yellow[~] SHA256: $(shasum -a 256 $1 | awk '{print $1}')\n$reset"
dissectApktool
dissectJadx
extractEndpoints $1 $2
}
checkDecompileDir() {
if [ -d "$DECOMPILEDIR" ]; then
read -p "[*] $BASENAME.apk was decompiled before. Do you want to overwrite it? (y/n): " choice
if [[ "${choice,,}" == "y" ]]; then
printf "$green[+] Cleaning Up...\n$reset"
rm -Rf "$DECOMPILEDIR"
else
printf "$red[+] Action Aborted...$reset"
exit 1
fi
fi
}
BASENAME="$(basename $1 .apk)"
WORKDIR=`pwd`
# Check pathing format
if [[ "$1" == .\/* ]]; then
APKPATH="`pwd`/${1:2}"
elif [[ "$1" == */* ]]; then
APKPATH="$1"
else
APKPATH="`pwd`/$1"
fi
DECOMPILEDIR="${WORKDIR}/${BASENAME}-decompiled"
APKTOOLDIR="${DECOMPILEDIR}/${BASENAME}_apktool"
JADXDIR="${DECOMPILEDIR}/${BASENAME}_jadx"
ENDPOINTDIR="${WORKDIR}/endpoints/"
if [[ -z $1 ]]; then
printf "Usage: apk2url <Name of APK File / Folder of APKs>\n"
exit 1
fi
if ! [ -x "$(command -v apktool)" ]; then
printf "$red[!] apk2url requires apktool to be installed\n$reset"
exit 1
fi
if ! [ -x "$(command -v jadx)" ]; then
printf "$red[!] apk2url requires jadx to be installed$reset"
exit 1
fi
if [ ! -d "$ENDPOINTDIR" ]; then
mkdir "$ENDPOINTDIR"
fi
if [ -d $1 ]; then
printf "$green[+] Directory specified. Will extract all APKs..\n$reset"
files=("$1/"*.apk)
for i in "${files[@]}"; do
# Set new APK parameters
BASENAME="$(basename $i .apk)"
WORKDIR=`pwd`
if [[ "$1" == .\/* ]]; then
APKPATH="`pwd`/${i:2}"
elif [[ "$1" == '.' ]]; then
APKPATH="`pwd`/$i"
else
APKPATH="$i"
fi
DECOMPILEDIR="${WORKDIR}/${BASENAME}-decompiled"
APKTOOLDIR="${DECOMPILEDIR}/${BASENAME}_apktool"
JADXDIR="${DECOMPILEDIR}/${BASENAME}_jadx"
ENDPOINTDIR="${WORKDIR}/endpoints/"
checkDecompileDir
mkdir $DECOMPILEDIR
mainJob $i $2
done
else
checkDecompileDir
mkdir $DECOMPILEDIR
mainJob $1 $2
fi