diff --git a/packages/addons/service/downloadmanager/transmission/source/bin/transmission.stop b/packages/addons/service/downloadmanager/transmission/source/bin/transmission.stop
index 0bded7b9b3..2a45c6f384 100755
--- a/packages/addons/service/downloadmanager/transmission/source/bin/transmission.stop
+++ b/packages/addons/service/downloadmanager/transmission/source/bin/transmission.stop
@@ -25,8 +25,9 @@
LOCKDIR="/var/lock/"
LOCKFILE="transmission.disabled"
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof transmission-daemon)" ];then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall -9 transmission-daemon
fi
diff --git a/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.start b/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.start
index 2028c5246f..738ed00780 100755
--- a/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.start
+++ b/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.start
@@ -64,6 +64,5 @@ mkdir -p $ADDON_HOME
break
fi
$ADDON_BIN $TVHEADEND_ARG &>$LOG_FILE
- sleep 1
done &
fi
diff --git a/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.stop b/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.stop
index dc58e7de61..dbf1d9d202 100755
--- a/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.stop
+++ b/packages/addons/service/multimedia/hts-tvheadend/source/bin/tvheadend.stop
@@ -27,8 +27,9 @@ LOCKFILE="tvheadend.disabled"
ADDON_BIN="tvheadend"
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof $ADDON_BIN)" ];then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall $ADDON_BIN
fi
diff --git a/packages/addons/service/multimedia/hts-tvheadend/source/sleep.d/tvheadend.power b/packages/addons/service/multimedia/hts-tvheadend/source/sleep.d/tvheadend.power
index 1fc9b6f083..b076ca9e9c 100755
--- a/packages/addons/service/multimedia/hts-tvheadend/source/sleep.d/tvheadend.power
+++ b/packages/addons/service/multimedia/hts-tvheadend/source/sleep.d/tvheadend.power
@@ -33,21 +33,17 @@ case "$1" in
tvheadend.stop
for module in $REMOVE_MODULES ; do
rmmod -w $module
- done
+ done
fi
;;
thaw|resume)
- if [ -f "$LOCKDIR/$LOCKFILE" ];then
- for module in $REMOVE_MODULES ; do
- modprobe $module
- done
- progress "Restarting HTS TVHeadend for wakeup..."
- xbmc-send --host=127.0.0.1 -a "XBMC.RunScript(service.multimedia.hts-tvheadend)" &
- fi
+ for module in $REMOVE_MODULES ; do
+ modprobe $module
+ done
+ progress "Restarting HTS TVHeadend for wakeup..."
+ xbmc-send --host=127.0.0.1 -a "XBMC.RunScript(service.multimedia.hts-tvheadend)" &
;;
-
*) exit $NA
;;
esac
-
diff --git a/packages/addons/service/multimedia/vdr-addon/source/bin/vdr.stop b/packages/addons/service/multimedia/vdr-addon/source/bin/vdr.stop
index ede8bcacbb..4cee53ecc3 100755
--- a/packages/addons/service/multimedia/vdr-addon/source/bin/vdr.stop
+++ b/packages/addons/service/multimedia/vdr-addon/source/bin/vdr.stop
@@ -25,9 +25,10 @@
LOCKDIR="/var/lock/"
LOCKFILE="vdr.disabled"
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof vdr.bin)" ];then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall vdr.bin
fi
diff --git a/packages/addons/service/softcam/oscam/source/bin/oscam.stop b/packages/addons/service/softcam/oscam/source/bin/oscam.stop
index 60349dca5f..c18b32f63f 100755
--- a/packages/addons/service/softcam/oscam/source/bin/oscam.stop
+++ b/packages/addons/service/softcam/oscam/source/bin/oscam.stop
@@ -26,11 +26,10 @@
LOCKDIR="/var/lock/"
LOCKFILE="oscam.disabled"
-# use "$(pidof)" instead of $(pidof). otherwise 'if' statement will fail
-# because oscam spawns at least one 'extra' process
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof oscam)" ];then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall -9 oscam
fi
diff --git a/packages/addons/service/system/dcron/source/bin/dcron.stop b/packages/addons/service/system/dcron/source/bin/dcron.stop
index 75858a66a7..f93d82434a 100755
--- a/packages/addons/service/system/dcron/source/bin/dcron.stop
+++ b/packages/addons/service/system/dcron/source/bin/dcron.stop
@@ -25,8 +25,9 @@
LOCKDIR="/var/lock/"
LOCKFILE="dcron.disabled"
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof crond)" ]; then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall -9 crond
fi
diff --git a/packages/addons/service/system/pcscd-addon/source/bin/pcscd.stop b/packages/addons/service/system/pcscd-addon/source/bin/pcscd.stop
index 4722ea09ff..02d1edd7e2 100755
--- a/packages/addons/service/system/pcscd-addon/source/bin/pcscd.stop
+++ b/packages/addons/service/system/pcscd-addon/source/bin/pcscd.stop
@@ -23,8 +23,9 @@
LOCKDIR="/var/lock/"
LOCKFILE="pcscd.disabled"
+mkdir -p "$LOCKDIR"
+touch "$LOCKDIR/$LOCKFILE"
+
if [ "$(pidof pcscd.bin)" ];then
- mkdir -p "$LOCKDIR"
- touch "$LOCKDIR/$LOCKFILE"
killall -9 pcscd.bin
fi
diff --git a/packages/mediacenter/xbmc-addon-settings/config/default_settings.xml b/packages/mediacenter/xbmc-addon-settings/config/default_settings.xml
index 60181b8f53..8bf4abbde6 100644
--- a/packages/mediacenter/xbmc-addon-settings/config/default_settings.xml
+++ b/packages/mediacenter/xbmc-addon-settings/config/default_settings.xml
@@ -26,6 +26,9 @@
+
+
+
diff --git a/packages/mediacenter/xbmc-addon-settings/source/resources/language/English/strings.xml b/packages/mediacenter/xbmc-addon-settings/source/resources/language/English/strings.xml
index 72c9edc799..b55f353595 100644
--- a/packages/mediacenter/xbmc-addon-settings/source/resources/language/English/strings.xml
+++ b/packages/mediacenter/xbmc-addon-settings/source/resources/language/English/strings.xml
@@ -36,5 +36,8 @@
Samba
Boot
Start Samba at boot
+ Use Samba Passwords
+ Samba Username
+ Samba Password
diff --git a/packages/mediacenter/xbmc-addon-settings/source/resources/settings.xml b/packages/mediacenter/xbmc-addon-settings/source/resources/settings.xml
index 3b223be4fb..f09078cb27 100644
--- a/packages/mediacenter/xbmc-addon-settings/source/resources/settings.xml
+++ b/packages/mediacenter/xbmc-addon-settings/source/resources/settings.xml
@@ -67,5 +67,8 @@
+
+
+
diff --git a/packages/network/samba/build b/packages/network/samba/build
index 6e00127131..6c8ac50e68 100755
--- a/packages/network/samba/build
+++ b/packages/network/samba/build
@@ -111,6 +111,7 @@ make bin/libsmbclient.so
if [ "$SAMBA_SERVER" = yes ]; then
make bin/smbd
make bin/nmbd
+ make bin/smbpasswd
fi
mkdir -p $SYSROOT_PREFIX/usr/lib
diff --git a/packages/network/samba/install b/packages/network/samba/install
index 3bb6978be1..9777f14b92 100755
--- a/packages/network/samba/install
+++ b/packages/network/samba/install
@@ -29,6 +29,7 @@ if [ "$SAMBA_SERVER" = "yes" ]; then
mkdir -p $INSTALL/usr/bin
cp $PKG_BUILD/source3/bin/smbd $INSTALL/usr/bin
cp $PKG_BUILD/source3/bin/nmbd $INSTALL/usr/bin
+ cp $PKG_BUILD/source3/bin/smbpasswd $INSTALL/usr/bin
mkdir -p $INSTALL/etc/samba
cp $PKG_DIR/config/smb.conf $INSTALL/etc/samba
diff --git a/packages/network/samba/scripts/52_samba b/packages/network/samba/scripts/52_samba
index 9410fe3b13..0c9dbb246e 100644
--- a/packages/network/samba/scripts/52_samba
+++ b/packages/network/samba/scripts/52_samba
@@ -35,13 +35,49 @@
SMB_USERCONF="/storage/.config/samba.conf"
SMB_DEFCONF="/etc/samba/smb.conf"
+ SMB_CONF="/var/run/smb.conf"
+ mkdir -p /var/run
if [ -f $SMB_USERCONF ]; then
- SMB_ARG="--configfile=$SMB_USERCONF"
+ cp $SMB_USERCONF $SMB_CONF
else
- SMB_ARG="--configfile=$SMB_DEFCONF"
+ cp $SMB_DEFCONF $SMB_CONF
fi
+ # only letters & numbers permitted for username & password
+ SAMBA_USERNAME=`echo $SAMBA_USERNAME | sed "s/[^a-zA-Z0-9]//g;"`
+ SAMBA_PASSWORD=`echo $SAMBA_PASSWORD | sed "s/[^a-zA-Z0-9]//g;"`
+
+ if [ "$SAMBA_SECURITY" == "true" -a ! "$SAMBA_USERNAME" == "" -a ! "$SAMBA_PASSWORD" == "" ] ; then
+ # username map: first line makes sure plain root does not work all the time
+ # processing continues, so if user chooses root as username, second line overrides the first
+ # this is done always in case user uses passwords in userconf.
+ # many thanks to viljoviitanen for this
+ echo -e "$SAMBA_PASSWORD\n$SAMBA_PASSWORD" | smbpasswd -s -a root >/dev/null 2>&1
+ echo -e "nobody = root\nroot = $SAMBA_USERNAME" > /var/run/samba.map
+
+ # set public = no
+ sed -e 's|^.[ \t]*.public.=.*| public = no |' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ # remove username map (if any in userconfig)
+ sed -e 's|^.[ \t]*.username map.=.*||' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ # set security = share, add username map
+ sed -e 's|^.[ \t]*.security.=.*| security = user\n username map = /var/run/samba.map|' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ else
+ # set public = yes
+ sed -e 's|^.[ \t]*.public.=.*| public = yes |' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ # remove username map (if any in userconfig)
+ sed -e 's|^.[ \t]*.username map.=.*||' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ # set security = share
+ sed -e 's|^.[ \t]*.security.=.*| security = share|' $SMB_CONF > $SMB_CONF.tmp && \
+ mv $SMB_CONF.tmp $SMB_CONF
+ fi
+
+ SMB_ARG="--configfile=$SMB_CONF"
mkdir -p /var/log/samba
nmbd --daemon $SMB_ARG > /dev/null 2>&1
smbd --daemon $SMB_ARG > /dev/null 2>&1