#!/mod/bin/jimsh package require cgi source /mod/webif/lib/setup require settings.class plugin system.class puts "Content-Type: text/html" puts "" cgi_input #cgi_dump if {[cgi_get act] eq "https"} { if {[cgi_get val off] eq "off"} { file delete /mod/etc/mongoose.cert puts "HTTPS Server will be disabled after next reboot." } else { exec /mod/sbin/mongoose_mkcert puts "HTTPS Server will be enabled after next reboot." } exit } if {[cgi_get act] eq "xtelnet"} { if {[cgi_get val off] eq "off"} { file delete /mod/boot/xtelnet puts "Telnet server expert mode will be disabled after next reboot." } else { exec /mod/bin/busybox/touch /mod/boot/xtelnet puts "Telnet server expert mode will be enabled after next reboot." } exit } set settings [settings new] set hostname [$settings hostname] set smtp_server [$settings smtp_server] set channel_group [$settings channel_group] set epg_style [$settings epg_style] set pkgdev [$settings pkgdev] set notoolbar [$settings notoolbar] set nomobile [$settings nomobile] # Handle updates if {![dict exists $env REQUEST_URI]} { set env(REQUEST_URI) "" } proc _handle_update {class var old text} { global _cgi global settings if {[dict exists $_cgi $var]} { set new [string trim [dict get $_cgi $var]] if {$new == $old} { puts "$text unchanged." } elseif [string is $class -strict $new] { $settings $var $new puts "$text updated." } else { puts "Invalid value for $var." } exit } } proc handle_int_update {var old {text "Value"}} { _handle_update digit $var $old $text } proc handle_str_update {var old {text "Value"}} { _handle_update alnum $var $old $text } handle_str_update hostname $hostname Hostname _handle_update ascii smtp_server $smtp_server "SMTP Server" handle_int_update channel_group $channel_group "Channel Group" handle_str_update epg_style $epg_style "EPG Type" handle_int_update pkgdev $pkgdev "Development Package Display" handle_int_update notoolbar $notoolbar "Disable toolbar" handle_int_update nomobile $nomobile "Disable mobile link" set acluser [cgi_get acluser "-"] set aclpass [cgi_get aclpass "-"] set aclpassc [cgi_get aclpassc "-"] if {$acluser ne "-" && $aclpass ne "-"} { if {![string length $acluser]} { puts "No username provided." exit } if {$aclpass ne $aclpassc} { puts "Passwords do not match." exit } if {[string length $aclpass] < 4} { puts "Password is too short (< 4 characters)" exit } puts [$settings addacluser $acluser $aclpass] exit } set aclact [cgi_get aclact "-"] if {$aclact ne "-" && $acluser ne "-"} { switch $aclact { "del" { puts [$settings delacluser $acluser] } } exit } header puts { } puts "
General Settings " puts " " puts -nonewline " " puts -nonewline " " puts -nonewline " " puts " " puts " " puts "
Hostname
HTTPS web server?
Slide-down toolbar?
Mobile link on main page?
Default Now/Next style
Channel Group for EPG


Email Settings " puts " " puts "
SMTP Server for outbound email
" puts "

Web Interface User Access Control " set aclusers [$settings aclusers] if {[llength $aclusers]} { puts "" foreach user [$settings aclusers] { lassign $user user puts "" puts "" } puts "" puts "" } else { puts "" } puts "" puts "
Existing Users
$userNew password:
" puts "Again: " puts "
" puts "" puts "
 
 
Add a user to enable authentication.
Add New User
New User:
Password:
Password (confirm):
" puts { } puts -nonewline "

Advanced Settings " if {[system modversion 1] >= 214} { puts -nonewline " " } puts "
Show development and advanced packages?
Expert mode telnet server?
" eval_plugins settings footer