This commit is contained in:
Derek Macias 2016-02-11 14:21:18 -07:00
commit dd0c22342a
10 changed files with 4683 additions and 133 deletions

View File

@ -3,13 +3,13 @@
<!DOCTYPE PLUGIN [
<!ENTITY name "shellinabox-plugin">
<!ENTITY author "dmacias72">
<!ENTITY version "2016.01.07c">
<!ENTITY version "2016.02.11a">
<!ENTITY launch "Settings/Shellinabox">
<!ENTITY gitURL "https://raw.githubusercontent.com/&author;/unRAID-plugins/master">
<!ENTITY pluginURL "&gitURL;/plugins/&name;.plg">
<!ENTITY pkgURL "&gitURL;/source/packages">
<!ENTITY plgpath "/boot/config/plugins/&name;">
<!ENTITY plgname "&name;-&version;-x86_64-1">
<!ENTITY plgPATH "/boot/config/plugins/&name;">
<!ENTITY plgNAME "&name;-&version;-x86_64-1">
<!ENTITY emhttp "/usr/local/emhttp/plugins/&name;">
]>
@ -20,6 +20,18 @@ This Plugin installs and controls shellinabox for unRaid 6.1 All dependencies a
-->
<CHANGES>
###2016.02.11a
- fix screenfetch error if emhttp/var.ini were not ready
###2016.02.11
- fix: chmod error
- fix: shutdown not saving
###2016.02.10
- remove array event scripts and move to rc script
- start and stop with system not array
- add: choice for command line screenshot
- add: choice to backup settings in root directory on shutdown
- add: backup restore on reboot e.g. mc settings, bash history
- add: selection of all users of group users for runas
###2016.01.07c
- add option to disable SSL
###2016.01.07b
@ -33,7 +45,9 @@ This Plugin installs and controls shellinabox for unRaid 6.1 All dependencies a
- default config file
###2016.01.06
- change package path to plugin directory
- fix Tool/Command Line page misspelled cfg file and defaulting to port 8088 instead of 4200
- fix Tool/Command Line page
- fix misspelled cfg file
- fix default port 8088 to 4200
###2015.12.30
- remove old plugin directory on install
###2015.12.21
@ -64,19 +78,21 @@ This Plugin installs and controls shellinabox for unRaid 6.1 All dependencies a
</CHANGES>
<FILE Name="&plgpath;/shellinabox-2.19-x86_64-1sl.txz" Run="upgradepkg --install-new">
<FILE Name="&plgPATH;/shellinabox-2.19-x86_64-1sl.txz" Run="upgradepkg --install-new">
<URL>&pkgURL;/shellinabox-2.19-x86_64-1sl.txz</URL>
<MD5>96f21406d18181f469e732795d2965e8</MD5>
</FILE>
<FILE Name="&plgpath;/linux-pam-1.1.8-x86_64-1gds.txz" Run="upgradepkg --install-new">
<FILE Name="&plgPATH;/linux-pam-1.1.8-x86_64-1gds.txz" Run="upgradepkg --install-new">
<URL>&pkgURL;/linux-pam-1.1.8-x86_64-1gds.txz</URL>
<MD5>f5d4e99dc0b65f4d6b3bacf479c9c6e2</MD5>
</FILE>
<FILE Name="&plgpath;/&name;.cfg">
<FILE Name="&plgPATH;/&name;.cfg">
<INLINE>
<![CDATA[
SERVICE="disable"
SSL="disable"
SCREEN="disable"
IPADDR="disable"
PORT="4200"
RUNAS="nobody"
@ -88,15 +104,15 @@ CERT="certificate.pem"
<!--
The 'plugin' package file.
-->
<FILE Name="&plgpath;/&plgname;.txz">
<URL>&gitURL;/archive/&plgname;.txz</URL>
<FILE Name="&plgPATH;/&plgNAME;.txz">
<URL>&gitURL;/archive/&plgNAME;.txz</URL>
</FILE>
<!--
The 'plugin' package MD5 hash.
-->
<FILE Name="&plgpath;/&plgname;.md5">
<URL>&gitURL;/archive/&plgname;.md5</URL>
<FILE Name="&plgPATH;/&plgNAME;.md5">
<URL>&gitURL;/archive/&plgNAME;.md5</URL>
</FILE>
<!--
@ -112,27 +128,28 @@ if [[ ${version:0:3} == 6.0 ]]; then
fi
# Verify and install plugin package
sum1=$(/usr/bin/md5sum &plgpath;/&plgname;.txz)
sum2=$(/usr/bin/cat &plgpath;/&plgname;.md5)
sum1=$(/usr/bin/md5sum &plgPATH;/&plgNAME;.txz)
sum2=$(/usr/bin/cat &plgPATH;/&plgNAME;.md5)
if [ "${sum1:0:32}" != "${sum2:0:32}" ]; then
echo "Wrong 'plugin' package md5 hash."
rm &plgpath;/&plgname;.txz
rm &plgpath;/&plgname;.md5
rm &plgPATH;/&plgNAME;.txz
rm &plgPATH;/&plgNAME;.md5
exit 1
else
#remove old plugin name directory
if [ -d /usr/local/emhttp/plugins/shellinabox ]; then
rm -rf /usr/local/emhttp/plugins/shellinabox
fi
upgradepkg --install-new &plgpath;/&plgname;.txz
fi
# Update file permissions of scripts
chmod +0755 &emhttp;/scripts/*
# upgrade package
upgradepkg --install-new &plgPATH;/&plgNAME;.txz
# start shellinabox daemon
/etc/rc.d/rc.shellinaboxd restore
# Cleaning old source files
find &plgpath;/ -type f -iname "&name;*.txz" ! -iname "*&version;*" -delete
find &plgpath;/ -type f -iname "&name;*.md5" ! -iname "*&version;*" -delete
find &plgPATH;/ -type f -iname "&name;*.txz" ! -iname "*&version;*" -delete
find &plgPATH;/ -type f -iname "&name;*.md5" ! -iname "*&version;*" -delete
echo ""
echo "-----------------------------------------------------------"
@ -142,6 +159,8 @@ echo " Copyright 2016, &author;"
echo " Version: &version;"
echo "-----------------------------------------------------------"
echo ""
fi
</INLINE>
</FILE>
@ -150,11 +169,14 @@ The 'remove' script.
-->
<FILE Run="/bin/bash" Method="remove">
<INLINE>
/usr/local/emhttp/plugins/&name;/scripts/stop
removepkg &plgpath;/*.txz
/etc/rc.d/rc.shellinaboxd shutdown
removepkg &plgPATH;/*.txz
rm -rf &emhttp;
rm -f &plgpath;/*.txz
rm -f &plgpath;/*.md5
rm -f &plgPATH;/*.txz \
&plgPATH;/*.md5 \
/etc/rc.d/rc.shellinaboxd
echo ""
echo "-----------------------------------------------------------"
@ -173,6 +195,8 @@ echo ""
# This will check each entry in the config so nothing is missing, and if missing, sets to default
CFGFILE=/boot/config/plugins/shellinabox-plugin/shellinabox-plugin.cfg
[ ! `cat "$CFGFILE" | grep SERVICE` ] && echo "SERVICE=\"disable\"" >> "$CFGFILE"
[ ! `cat "$CFGFILE" | grep SCREEN` ] && echo "SCREEN=\"disable\"" >> "$CFGFILE"
[ ! `cat "$CFGFILE" | grep SSL` ] && echo "SSL=\"disable\"" >> "$CFGFILE"
[ ! `cat "$CFGFILE" | grep IPADDR` ] && echo "IPADDR=\"disable\"" >> "$CFGFILE"
[ ! `cat "$CFGFILE" | grep ^PORT` ] && echo "PORT=\"4200\"" >> "$CFGFILE"
[ ! `cat "$CFGFILE" | grep RUNAS` ] && echo "RUNAS=\"nobody\"" >> "$CFGFILE"

View File

@ -11,8 +11,20 @@ Shell In A Box implements a web server that can export arbitrary command line to
</Description>
<Support>http://lime-technology.com/forum/index.php?topic=42683.0</Support>
<Icon>https://raw.githubusercontent.com/dmacias72/unRAID-plugins/master/plugins/shellinabox-plugin.png</Icon>
<Date>2016-01-07</Date>
<Date>2016-02-11</Date>
<Changes>
###2016.02.11a
- fix screenfetch error if emhttp/var.ini were not ready
###2016.02.11
- fix: chmod error
- fix: shutdown not saving
###2016.02.10
- remove array event scripts and move to rc script
- start and stop with system not array
- add: choice for command line screenshot
- add: choice to backup settings in root directory on shutdown
- add: backup restore on reboot e.g. mc settings, bash history
- add: selection of all users of group users for runas
###2016.01.07c
- add option to disable SSL
###2016.01.07b

View File

@ -0,0 +1,126 @@
#!/bin/sh
# start/stop/shutdown/restart shellinabox daemon:
PROG="shellinaboxd"
SHELLINABOXD="/usr/sbin/$PROG"
LOCKFILE="/var/lock/$PROG"
PIDFILE="/var/run/$PROG.pid"
PROFILE="/root/.bash_profile"
STYLES="/usr/local/emhttp/plugins/shellinabox-plugin/styles"
PLGPATH="/boot/config/plugins/shellinabox-plugin"
CONFIG="$PLGPATH/shellinabox-plugin.cfg"
USER_CSS="Color:+$STYLES/color.css,Monochrome:-$STYLES/monochrome.css;White:+$STYLES/white-on-black.css,Black:-$STYLES/black-on-white.css,Blue:-$STYLES/blue-on-black.css,Green:-$STYLES/green-on-black.css,Pink:-$STYLES/pink-on-black.css,Purple:-$STYLES/purple-on-black.css,Red:-$STYLES/red-on-black.css,Yellow:-$STYLES/yellow-on-black.css"
# read our configuration
[ -e "$CONFIG" ] && source $CONFIG
# add screenfetch to bash profile
if [ "$SCREEN" == "enable" ]; then
if ! grep "/usr/sbin/screenfetch" $PROFILE >/dev/null 2>&1
#append command to file
then echo -e "\n/usr/sbin/screenfetch" >> $PROFILE
else
#uncomment command
sed -e '/\/usr\/sbin\/screenfetch/s/^#//g' -i $PROFILE
fi
else
#comment out command
sed -e '/\/usr\/sbin\/screenfetch/ s/^#*/#/' -i $PROFILE
fi
# Start shellinaboxd:
shellinaboxd_start() {
# no-op if already running
if [[ "$SERVICE" == "enable" && ! -r "$PIDFILE" ]]; then
SSL_CONFIG=""
[ $SSL == "disable" ] && SSL_CONFIG="--disable-ssl"
echo "starting shellinaboxd..."
sleep 1
nohup /usr/sbin/$PROG --user=$RUNAS --background=$PIDFILE --port=$PORT --cert=$PLGPATH --user-css=$USER_CSS $SSL_CONFIG > /dev/null 2>&1 | logger -t$PROG &
touch $LOCKFILE
TIMER=0
while [ ! -e $PIDFILE ]; do
sleep 1
let TIMER=$TIMER+1
if [ $TIMER -gt 5 ]; then
echo -n "$PIDFILE not created"
break
fi
done
else
echo "shellinaboxd is running"
fi
}
# Stop shellinaboxd:
shellinaboxd_stop() {
# no-op if not running
if [ -r "$PIDFILE" ]; then
echo "stopping shellinaboxd..."
TIMER=0
while `killall $PROG 2>/dev/null`; do
sleep 1
TIMER=$((TIMER+1))
if [ $TIMER -ge 30 ]; then
killall -9 $PROG
sleep 1
break
fi
done
rm -f $LOCKFILE && rm -f $PIDFILE
else
echo "shellinaboxd is stopped"
fi
}
# Restart shellinaboxd:
shellinaboxd_restart() {
shellinaboxd_stop
sleep 1
shellinaboxd_start
}
# Restore shellinaboxd:
shellinaboxd_restore() {
if [ "$BACKUP" == "enable" ]; then
# backup home directory
echo "restoring home directory..."
tar -zxf $PLGPATH/home_directory.tar.gz -p -C / > /dev/null 2>&1
sleep 1
fi
shellinaboxd_start
}
# Shutdown shellinaboxd:
shellinaboxd_shutdown() {
if [ "$BACKUP" == "enable" ]; then
# backup home directory
echo "saving home directory..."
tar -zcf $PLGPATH/home_directory.tar.gz -p -C / root > /dev/null 2>&1
sleep 1
fi
shellinaboxd_stop
}
case "$1" in
'start')
shellinaboxd_start
;;
'stop')
shellinaboxd_stop
;;
'shutdown')
shellinaboxd_shutdown
;;
'restore')
shellinaboxd_restore
;;
'restart')
shellinaboxd_restart
;;
*)
echo "usage rc.shellinaboxd: start|stop|shutdown|restore|restart"
esac

View File

@ -1 +1,14 @@
#!/bin/sh
RC_SCRIPT="/etc/rc.d/rc.shellinaboxd"
SD_RCFILE="/etc/rc.d/rc.local_shutdown"
# Update file permissions of scripts
chmod +0755 /usr/local/emhttp/plugins/shellinabox-plugin/scripts/* \
/etc/rc.d/rc.shellinaboxd \
/usr/sbin/screenfetch
# add stop to shutdown script
if ! grep "$RC_SCRIPT" $SD_RCFILE >/dev/null 2>&1
then echo -e "\n[ -x $RC_SCRIPT ] && $RC_SCRIPT shutdown" >> $SD_RCFILE
fi
[ ! -x $SD_RCFILE ] && chmod u+x $SD_RCFILE

View File

@ -6,16 +6,20 @@ Title="Command Line"
$sName = "shellinaboxd";
$shellinabox_cfg = parse_plugin_cfg("shellinabox-plugin");
$shellinabox_service = isset($shellinabox_cfg['SERVICE']) ? $shellinabox_cfg['SERVICE'] : "disable";
$shellinabox_screen = isset($shellinabox_cfg['SCREEN']) ? $shellinabox_cfg['SCREEN'] : "disable";
$shellinabox_backup = isset($shellinabox_cfg['BACKUP']) ? $shellinabox_cfg['BACKUP'] : "disable";
$shellinabox_ssl = isset($shellinabox_cfg['SSL']) ? $shellinabox_cfg['SSL'] : "disable";
$shellinabox_runas = isset($shellinabox_cfg['RUNAS']) ? $shellinabox_cfg['RUNAS'] : "nobody";
$shellinabox_ipaddr = isset($shellinabox_cfg['IPADDR']) ? $shellinabox_cfg['IPADDR'] : "disable";
$shellinabox_host = ($shellinabox_ipaddr == "disable") ? $var['NAME'] : $var['IPADDR'];
$shellinabox_port = (isset($shellinabox_cfg['PORT']) && is_numeric($shellinabox_cfg['PORT']) && $shellinabox_cfg['PORT'] > 0 && $shellinabox_cfg['PORT'] < 65535 ) ? $shellinabox_cfg['PORT'] : "4200";
$shellinabox_cert = isset($shellinabox_cfg['CERT']) ? $shellinabox_cfg['CERT'] : "certificate.pem";
$shellinabox_running = trim(shell_exec( "[ -f /proc/`cat /var/run/shellinaboxd.pid 2> /dev/null`/exe ] && echo 'yes' || echo 'no' 2> /dev/null" ));
$shellinabox_version = shell_exec( "/usr/sbin/shellinaboxd --version 2>&1 | grep ShellInABox | sed -e 's/^ShellInABox version //'" );
$shellinabox_version = ($shellinabox_running == "yes") ?
"<a style='color:green;' target='_blank' href='http://".$shellinabox_host.":".$shellinabox_port."' title='Click on link then accept security, then /Tools/CommandLine will work'><b>$shellinabox_version</b></a>":
"<b><font style='color:orange;'>$shellinabox_version</font></b>";
$shellinabox_port = (isset($shellinabox_cfg['PORT']) && is_numeric($shellinabox_cfg['PORT']) && $shellinabox_cfg['PORT'] > 0 && $shellinabox_cfg['PORT'] < 65535 ) ? $shellinabox_cfg['PORT'] : "4200";
$shellinabox_running = trim(shell_exec( "[ -f /proc/`cat /var/run/shellinaboxd.pid 2> /dev/null`/exe ] && echo 1 || echo 0 2> /dev/null" ));
$shellinabox_version = shell_exec( "/usr/sbin/shellinaboxd --version 2>&1 | grep ShellInABox | sed -e 's/^ShellInABox version //;s/(.*//'" );
$shellinabox_port_status = ($shellinabox_running) ?
"<a style='color:green;' target='_blank' href='http://".$shellinabox_host.":".$shellinabox_port."' title='Click on link then accept security, then /Tools/CommandLine will work'><b>$shellinabox_port</b></a>":
"<b><font style='color:orange;'>$shellinabox_port</font></b>";
exec("awk -F':' '{ if ( $3 >= 1000 ) print $1}' /etc/passwd", $shellinabox_users); // get array of group users
?>
<form markdown="1" name="shellinabox_settings" method="POST" action="/update.php" target="progressFrame">
@ -28,29 +32,43 @@ Enable Shellinabox Server <?=$shellinabox_version;?>:
<?=mk_option($shellinabox_service, "enable", "Yes");?>
</select>
Port (<?=$shellinabox_port_status;?>):
: <input style="width:135px" id="PORT" type="text" class="shellinabox-run" name="PORT" maxlength="40" value="<?=$shellinabox_port;?>" title="port must be 0-65535" placeholder="Default Port is 8000" >
Run as User:
: <select id="USERS" class="shellinabox-run" title="select user, cannot be root" size="1" onChange="checkUSER(this.form, '<?=$shellinabox_runas;?>');">
<?=mk_option($aesir_runas, "nobody", "nobody");?>
<?php foreach($shellinabox_users as $shellinabox_user){echo mk_option($shellinabox_runas, trim($shellinabox_user), trim($shellinabox_user));};?>
<option value='other' <?=($shellinabox_runas != "root" && $shellinabox_runas != "nobody" && !in_array($shellinabox_runas, $shellinabox_users))?"selected=yes":"";?>>other</option>
<?=mk_option($shellinabox_runas, "root", "root");?>
</select>
<input type="hidden" name="RUNAS" style="width:222px" maxlength="40" value=<?=$shellinabox_runas;?> >
Connect by IP Address:
: <select id="IPADDR" name="IPADDR" size="1" class="stopped">
: <select id="IPADDR" name="IPADDR" size="1" class="shellinabox-run">
<?=mk_option($shellinabox_ipaddr, "disable", "No");?>
<?=mk_option($shellinabox_ipaddr, "enable", "Yes");?>
</select>
Enable SSL connection:
: <select id="SSL" name="SSL" size="1" class="stopped">
: <select id="SSL" name="SSL" size="1" class="shellinabox-run">
<?=mk_option($shellinabox_ssl, "disable", "No");?>
<?=mk_option($shellinabox_ssl, "enable", "Yes");?>
</select>
Port:
: <input style="width:135px" id="PORT" type="text" class="stopped" name="PORT" maxlength="40" value="<?=$shellinabox_port;?>" title="port must be 0-65535" placeholder="Default Port is 8000" >
Run as User:
: <select id="USERS" class="stopped" title="select user, cannot be root" size="1" onChange="checkUSER(this.form, '<?=$shellinabox_runas;?>');">
<?=mk_option($shellinabox_runas, "nobody", "nobody");?>
<option value='other' <?=($shellinabox_runas != "root" && $shellinabox_runas != "nobody")?"selected=yes":"";?>>other</option>
Enable Command Line Screenshot:
: <select id="SCREEN" name="SCREEN" size="1" title="shows screenshot when you log in">
<?=mk_option($shellinabox_screen, "disable", "No");?>
<?=mk_option($shellinabox_screen, "enable", "Yes");?>
</select>
<input type="hidden" name="RUNAS" style="width:222px" maxlength="40" value=<?=$shellinabox_runas;?> >
<input id="DEFAULT" class="stopped" type="submit" value="Default" onClick="resetDATA(this.form)">
Enable Home Directory Backup:
: <select id="BACKUP" name="BACKUP" size="1" title="shows screenshot when you log in">
<?=mk_option($shellinabox_backup, "disable", "No");?>
<?=mk_option($shellinabox_backup, "enable", "Yes");?>
</select>
<input id="DEFAULT" class="shellinabox-run" type="submit" value="Default" onClick="resetDATA(this.form)">
: <input id="btnApply" type="submit" value="Apply" onClick="verifyDATA(this.form)"><input type="button" value="Done" onClick="done()"><!--<button id="btnCert" type="button" onclick="window.location.href='http://<?=$shellinabox_host;?>/boot/config/plugins/shellinabox-plugin/<?=$shellinabox_cert;?>'"> Download Cert </button>-->
</form>
@ -64,19 +82,21 @@ $(function(){
function resetDATA(form) {
form.IPADDR.value = "disable";
form.SSL.value = "disable";
form.SCREEN.value = "disable";
form.BACKUP.value = "disable";
form.PORT.value = "4200";
form.RUNAS.value = "nobody";
form.USERS.value = "nobody";
}
function checkRUNNING(form) {
if ("<?=$shellinabox_running;?>" == "yes")
if ("<?=$shellinabox_running;?>" == true)
{
$(".stopped").prop("disabled", true);
$(".shellinabox-run").prop("disabled", true);
form.btnApply.disabled = true;
//form.btnCert.disabled = false;
}else{
$(".stopped").prop("disabled", false);
$(".shellinabox-run").prop("disabled", false);
//form.btnCert.disabled = true;
}
@ -89,7 +109,7 @@ function checkRUNNING(form) {
}
function checkUSER(form, currentUSER) {
if (form.USERS.selectedIndex < 1 ) {
if (form.USERS.value != "other" ) {
form.RUNAS.value = form.USERS.options[form.USERS.selectedIndex].value;
form.RUNAS.type = "hidden";
}
@ -104,20 +124,17 @@ function checkUSER(form, currentUSER) {
}
function verifyDATA(form) {
if (isNumber(form.PORT.value)){
if (form.PORT.value < 0 || form.PORT.value > 65535){
if (!isNumber(form.PORT.value) || form.PORT.value < 0 || form.PORT.value > 65535){
form.PORT.value = "4200";
}
} else {
form.PORT.value = "4200";
}
if (form.RUNAS.value == null || form.RUNAS.value == "" || form.RUNAS.value == "root" ){
if (form.RUNAS.value == null || form.RUNAS.value == ""){
form.RUNAS.value = "nobody";
$shellinabox_runas = "nobody";
}
form.SERVICE.value = form.SERVICE.value.replace(/ /g,"_");
form.IPADDR.value = form.IPADDR.value.replace(/ /g,"_");
form.SSL.value = form.SSL.value.replace(/ /g,"_");
form.SCREEN.value = form.SCREEN.value.replace(/ /g,"_");
form.PORT.value = form.PORT.value.replace(/ /g,"_");
form.RUNAS.value = form.RUNAS.value.replace(/ /g,"_");
}

View File

@ -1,5 +0,0 @@
#!/bin/bash
source /boot/config/plugins/shellinabox-plugin/shellinabox-plugin.cfg
if [ $SERVICE = enable ]; then
/usr/local/emhttp/plugins/shellinabox-plugin/scripts/start
fi

View File

@ -1,3 +0,0 @@
#!/bin/bash
/usr/local/emhttp/plugins/shellinabox-plugin/scripts/stop

View File

@ -1,33 +1,2 @@
#!/bin/sh
# read our configuration
source /boot/config/plugins/shellinabox-plugin/shellinabox-plugin.cfg
prog="shellinaboxd"
SHELLINABOXD="/usr/sbin/$prog"
LOCKFILE="/var/lock/$prog"
PIDFILE="/var/run/$prog.pid"
STYLES="/usr/local/emhttp/plugins/shellinabox-plugin/styles"
CONFIG="/boot/config/plugins/shellinabox-plugin"
USER_CSS="Color:+$STYLES/color.css,Monochrome:-$STYLES/monochrome.css;White:+$STYLES/white-on-black.css,Black:-$STYLES/black-on-white.css,Blue:-$STYLES/blue-on-black.css,Green:-$STYLES/green-on-black.css,Pink:-$STYLES/pink-on-black.css,Purple:-$STYLES/purple-on-black.css,Red:-$STYLES/red-on-black.css,Yellow:-$STYLES/yellow-on-black.css"
# no-op if already running
if [ ! -r $PIDFILE ]; then
SSL_CONFIG=""
if [ $SSL == "disable" ]; then
SSL_CONFIG="--disable-ssl"
fi
sleep 1
nohup /usr/sbin/$prog --user=$RUNAS --background=$PIDFILE --port=$PORT --cert=$CONFIG --user-css=$USER_CSS $SSL_CONFIG > /dev/null 2>&1 | logger -tshellinaboxd &
touch $LOCKFILE
TIMER=0
while [ ! -e $PIDFILE ]; do
sleep 1
let TIMER=$TIMER+1
if [ $TIMER -gt 5 ]; then
echo -n "$PIDFILE not created"
break
fi
done
fi
/etc/rc.d/rc.shellinaboxd start

View File

@ -1,20 +1,2 @@
#!/bin/sh
prog="shellinaboxd"
SHELLINABOXD="/usr/sbin/$prog"
LOCKFILE="/var/lock/$prog"
PIDFILE="/var/run/$prog.pid"
# no-op if not running
if [ -r $PIDFILE ]; then
TIMER=0
while `killall $prog 2>/dev/null`; do
sleep 1
TIMER=$((TIMER+1))
if [ $TIMER -ge 30 ]; then
killall -9 $prog
sleep 1
break
fi
done
rm -f $LOCKFILE && rm -f $PIDFILE
fi
/etc/rc.d/rc.shellinaboxd stop

File diff suppressed because it is too large Load Diff