From 603f612d83c210de0cc3db8854d99fd2026e1814 Mon Sep 17 00:00:00 2001
From: Travis Kemen <thepeople@openwrt.org>
Date: Thu, 28 Feb 2008 19:56:09 +0000
Subject: [PATCH] Fix a wrong variable names (ifname, wan) and enhance httpd's
 init script by more configurable options. Signed-off-by: Lubos Stanek (lubek)
 <lubek@lubek.name>

SVN-Revision: 10536
---
 package/busybox/files/httpd | 48 +++++++++++++++++++++++++++++++++----
 1 file changed, 44 insertions(+), 4 deletions(-)

diff --git a/package/busybox/files/httpd b/package/busybox/files/httpd
index 35b7f62948..f7e166d0ad 100755
--- a/package/busybox/files/httpd
+++ b/package/busybox/files/httpd
@@ -1,12 +1,52 @@
 #!/bin/sh /etc/rc.common
 # Copyright (C) 2006 OpenWrt.org
+
 START=50
+HTTPD_BIN="/usr/sbin/httpd"
+
+system_config() {
+	local cfg="$1"
+
+	config_get hostname "$cfg" hostname
+}
+
+httpd_config() {
+	local cfg="$1"
+	local c_file port realm home
+
+	config_get c_file "$cfg" c_file
+	[ -n "$c_file" -a -f "$c_file" ] && append args "-c \"$c_file\""
+	config_get port "$cfg" port
+	append args "-p ${port:-80}"
+	config_get home "$cfg" home
+	home="${home:-/www}"
+	[ -d "$home" ] || return 1
+	append args "-h \"$home\""
+	config_get realm "$cfg" realm
+	realm="${realm:-$hostname}"
+	append args "-r \"$realm\""
+	eval "$HTTPD_BIN $args"
+}
 
 start() {
-	include /lib/network
-	scan_interfaces
-        config_get ifname wan hostname
-	[ -d /www ] && httpd -p 80 -h /www -r ${hostname:-OpenWrt}
+	[ -x "$HTTPD_BIN" ] || return 1
+
+	unset hostname
+	config_load system
+	config_foreach system_config system
+	hostname="${hostname:-OpenWrt}"
+
+	unset args
+	config_load httpd
+	[ "$?" != "0" ] && {
+		uci_set_default httpd <<EOF
+config 'httpd'
+	option 'port' '80'
+	option 'home' '/www'
+EOF
+		config_load httpd
+	}
+	config_foreach httpd_config httpd
 }
 
 stop() {
-- 
GitLab