Merge pull request #10939 from Andy2244/wsdd2-init-update-(19.07)
[19.07] wsdd2: update to git (2019-12-15), bind to 'lan' only, update init for smbd
This commit is contained in:
commit
396c5fc9bf
3 changed files with 78 additions and 34 deletions
|
@ -1,13 +1,13 @@
|
||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=wsdd2
|
PKG_NAME:=wsdd2
|
||||||
PKG_RELEASE:=3
|
PKG_RELEASE:=1
|
||||||
|
|
||||||
PKG_SOURCE_PROTO:=git
|
PKG_SOURCE_PROTO:=git
|
||||||
PKG_SOURCE_URL:=https://github.com/Andy2244/wsdd2.git
|
PKG_SOURCE_URL:=https://github.com/Andy2244/wsdd2.git
|
||||||
PKG_SOURCE_DATE:=2018-07-24
|
PKG_SOURCE_DATE:=2019-12-15
|
||||||
PKG_SOURCE_VERSION:=2c31ba3b720af81848c47dff7ad7c6c30c0c0f50
|
PKG_SOURCE_VERSION:=8bcc0c1a42767ba518977a7104fe934f5d89ef31
|
||||||
PKG_MIRROR_HASH:=eb903a870d99c6001996dbfc22c15e1020278c45ed2441ceb61bc5395f417afa
|
PKG_MIRROR_HASH:=4eace9130b7e1ddbc5b965fa51286532d3ee2ee14bcd2e116840c7d6d48ad9bc
|
||||||
|
|
||||||
PKG_MAINTAINER:=Andy Walsh <andy.walsh44+github@gmail.com>
|
PKG_MAINTAINER:=Andy Walsh <andy.walsh44+github@gmail.com>
|
||||||
PKG_LICENSE:=GPL-3.0-only
|
PKG_LICENSE:=GPL-3.0-only
|
||||||
|
|
|
@ -3,15 +3,84 @@
|
||||||
START=99
|
START=99
|
||||||
USE_PROCD=1
|
USE_PROCD=1
|
||||||
|
|
||||||
|
SMB_CONF=""
|
||||||
|
BIND_IF_PARM=""
|
||||||
|
NB_PARM=""
|
||||||
|
WG_PARM=""
|
||||||
|
BI_PARM=""
|
||||||
|
|
||||||
|
. /lib/functions/network.sh
|
||||||
|
|
||||||
start_service() {
|
start_service() {
|
||||||
|
|
||||||
|
if [ -e /etc/smbd/smb.conf ] && [ -e /etc/init.d/smbd ] && /etc/init.d/smbd running; then
|
||||||
|
SMB_CONF="/etc/smbd/smb.conf"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -e /etc/samba/smb.conf ]; then
|
||||||
|
if [ -e /etc/init.d/samba4 ] && /etc/init.d/samba4 running; then
|
||||||
|
SMB_CONF="/etc/samba/smb.conf"
|
||||||
|
elif [ -e /etc/init.d/samba ] && /etc/init.d/samba running; then
|
||||||
|
SMB_CONF="/etc/samba/smb.conf"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$SMB_CONF" ]; then
|
||||||
|
logger -p daemon.error -t 'wsdd2' "samba36/4 or smbd is not running, can't start wsdd2!"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local nb_name
|
||||||
|
nb_name="$(grep -i 'netbios name' $SMB_CONF | awk -F'=' '{print $2}' | tr -d ' \n')"
|
||||||
|
if [ -n "$nb_name" ]; then
|
||||||
|
NB_PARM="-N $nb_name"
|
||||||
|
else
|
||||||
|
local hostname
|
||||||
|
hostname="$(cat /proc/sys/kernel/hostname)"
|
||||||
|
NB_PARM="-N $hostname"
|
||||||
|
fi
|
||||||
|
|
||||||
|
local wg_name
|
||||||
|
wg_name="$(grep -i 'workgroup' $SMB_CONF | awk -F'=' '{print $2}' | tr -d ' \n')"
|
||||||
|
if [ -n "$wg_name" ]; then
|
||||||
|
WG_PARM="-G $wg_name"
|
||||||
|
else
|
||||||
|
NB_PARM="-G WORKGROUP"
|
||||||
|
fi
|
||||||
|
|
||||||
|
# resolve lan interface (BUG: No multi-interface binds atm)
|
||||||
|
local ifname
|
||||||
|
if network_get_device ifname lan; then
|
||||||
|
BIND_IF_PARM="-i $ifname"
|
||||||
|
fi
|
||||||
|
|
||||||
|
local board_vendor
|
||||||
|
local board_model
|
||||||
|
local board_sku
|
||||||
|
|
||||||
|
if [ -e /tmp/sysinfo/board_name ]; then
|
||||||
|
board_vendor="$(cat /tmp/sysinfo/board_name | awk -F',' '{print $1}' | tr ' ' '_' | tr -d ' \n')"
|
||||||
|
board_sku="$(cat /tmp/sysinfo/board_name | awk -F',' '{print $2}' | tr ' ' '_' | tr -d ' \n')"
|
||||||
|
fi
|
||||||
|
if [ -e /tmp/sysinfo/model ]; then
|
||||||
|
board_model="$(cat /tmp/sysinfo/model | tr ' ' '_' | tr -d ' \n')"
|
||||||
|
fi
|
||||||
|
if [ -n "$board_vendor" ] && [ -n "$board_model" ]; then
|
||||||
|
if [ -n "$board_sku" ]; then
|
||||||
|
BI_PARM="-b vendor:$board_vendor,model:$board_model,sku:$board_sku"
|
||||||
|
else
|
||||||
|
BI_PARM="-b vendor:$board_vendor,model:$board_model"
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
procd_open_instance
|
procd_open_instance
|
||||||
procd_set_param command /usr/bin/wsdd2 -w
|
procd_set_param command /usr/bin/wsdd2 -w $BIND_IF_PARM $NB_PARM $WG_PARM $BI_PARM
|
||||||
procd_set_param respawn
|
procd_set_param respawn
|
||||||
procd_set_param file /var/etc/smb.conf
|
procd_set_param file $SMB_CONF
|
||||||
procd_close_instance
|
procd_close_instance
|
||||||
}
|
}
|
||||||
|
|
||||||
service_triggers() {
|
service_triggers() {
|
||||||
PROCD_RELOAD_DELAY=3000
|
PROCD_RELOAD_DELAY=1000
|
||||||
procd_add_reload_trigger "dhcp" "system" "samba4"
|
procd_add_reload_trigger "dhcp" "system" "samba" "samba4" "smbd"
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,25 +0,0 @@
|
||||||
--- a/wsd.c 2018-07-24
|
|
||||||
+++ b/wsd.c 2018-09-10
|
|
||||||
@@ -96,13 +96,19 @@ static void uuid_endpoint(char *uuid, si
|
|
||||||
{
|
|
||||||
FILE *fp = fopen("/etc/machine-id", "r");
|
|
||||||
int c, i = 0;
|
|
||||||
+
|
|
||||||
+ if (!fp) {
|
|
||||||
+ fp = fopen("/proc/sys/kernel/random/boot_id", "r");
|
|
||||||
+ }
|
|
||||||
|
|
||||||
- if (!fp)
|
|
||||||
+ if (!fp) {
|
|
||||||
+ DEBUG(0, W, "Can't open required '/etc/machine-id' or '/proc/sys/kernel/random/boot_id'");
|
|
||||||
return;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
while (i < 36 && (c = getc(fp)) != EOF &&
|
|
||||||
- (isdigit(c) || (islower(c) && isxdigit(c)))) {
|
|
||||||
- if (i == 8 || i == 13 || i == 18 || i == 23)
|
|
||||||
+ ((c == '-') || isdigit(c) || (islower(c) && isxdigit(c)))) {
|
|
||||||
+ if ((c != '-') && (i == 8 || i == 13 || i == 18 || i == 23))
|
|
||||||
uuid[i++] = '-';
|
|
||||||
uuid[i++] = c;
|
|
||||||
}
|
|
Loading…
Reference in a new issue