if {![exists -proc class ]} { package require oo } if {![exists -proc sqlite3.open ]} { package require sqlite3 } if {![file exists /mod/etc/webif.db]} { set settingsdb [sqlite3.open /mod/etc/webif.db] catch { $settingsdb query { CREATE TABLE settings(name text, nval int, tval text); } $settingsdb query { CREATE UNIQUE INDEX key on settings(name); } } } else { set settingsdb [sqlite3.open /mod/etc/webif.db] } class settings { hostname "" channel_group 0 epg_style "standard" smtp_server "" pkgdev 0 } settings method hostname {{name ""}} { if {$name == ""} { # Get if {[catch {set fd [open "/var/lib/humaxtv/hostname" r]}]} { set name "humax" } else { set name [string trim [read $fd]] close $fd } return $name } else { # Set if [string is alnum -strict $name] { set fd [open "/var/lib/humaxtv/hostname" w] puts $fd $name close $fd exec hostname -F /var/lib/humaxtv/hostname } } } settings method smtp_server {{server ""}} { if {$server == ""} { # Get if {[catch {set fd [open "/mod/etc/ssmtp/ssmtp.conf" r]}]} { set server "mail" } else { foreach line [split [read $fd] "\n"] { set a [string first "mailhub=" $line] if {$a == 0} { set server [string range $line 8 end] set server [string trim $server] } } close $fd } return $server } else { # Set if {[string is ascii -strict $server]} { set fd [open "/mod/etc/ssmtp/ssmtp.conf" w] puts $fd "mailhub=$server" puts $fd "rewriteDomain=hummypkg.org.uk" puts $fd "hostname=[$self hostname].hummypkg.org.uk" close $fd } } } settings method _nval_setting {name {val -1}} { global settingsdb; if {$val == -1} { # Get set res [$settingsdb query " select nval from settings where name = '$name' "] if {$res ne ""} { return [lindex [lindex $res end] end] } return 0 } else { # Set $settingsdb query " replace into settings(name,nval) values('$name', $val) " return 0 } } settings method channel_group {{group -1}} { return [$self _nval_setting channel_group $group] } settings method epg_style {{style -1}} { if {$style != -1} { if {$style eq "grid"} { set style 1 } else { set style 0} return [$self _nval_setting epg_style $style] } set val [$self _nval_setting epg_style] if {$val == 1} { return "grid" } return "standard" } settings method pkgdev {{val -1}} { return [$self _nval_setting pkgdev $val] } settings method channel_groups {} { set ret "" set db [sqlite3.open /var/lib/humaxtv/setup.db] set res [$db query { select itemText from TBL_MENUCONFIG where itemName like 'FAV\_CUSTOM\_STR%%' ESCAPE '\' }] $db close foreach g $res { set g $g(itemText) if {[string index $g 0] == "\025"} { lappend ret [string range $g 1 end] } else { lappend ret $g } } return $ret } settings method aclusers {} { if {![file exists "/mod/etc/htpasswd"]} { return {} } set fd [open "/mod/etc/htpasswd" r] set users {} foreach line [string trim [split [read $fd] "\n"]] { set info [split $line ":"] if {[llength $info] != 3} { continue } lappend users $info } $fd close return $users } settings method mongooseauth {{mode 1}} { set fd [open "/mod/etc/mongoose.conf" r] set fdnew [open "/mod/etc/mongoose.conf.new" w] foreach line [string trim [split [read $fd] "\n"]] { if {[string match -nocase {authentication_domain*} $line]} { continue } if {[string match -nocase {global_passwords_file*} $line]} { continue } if {$line ne ""} { puts $fdnew $line } } $fd close if {$mode} { puts $fdnew "authentication_domain webif" puts $fdnew "global_passwords_file /mod/etc/htpasswd" } $fdnew close file delete "/mod/etc/mongoose.conf" file rename "/mod/etc/mongoose.conf.new" "/mod/etc/mongoose.conf" } settings method addacluser {user pass} { set msg "" if {![llength [$self aclusers]]} { $self mongooseauth 1 append msg "Enabled web server authentication
" } set cmd "/mod/sbin/mongoose -A /mod/etc/htpasswd webif $user $pass" exec {*}$cmd append msg "Successfully updated user $user" return $msg } settings method delacluser {user} { if {![file exists "/mod/etc/htpasswd"]} { return } set fd [open "/mod/etc/htpasswd" r] set fdnew [open "/mod/etc/htpasswd.new" w] set num 0 foreach line [string trim [split [read $fd] "\n"]] { lassign [split $line ":"] xuser if {$xuser eq $user} { continue } if {$line ne ""} { puts $fdnew $line incr num } } $fd close $fdnew close file delete "/mod/etc/htpasswd" file rename "/mod/etc/htpasswd.new" "/mod/etc/htpasswd" set msg "Successfully removed user $user" if {$num == 0} { $self mongooseauth 0 append msg "
Disabled web server authentication
" } return $msg }