checkpoint on the way to 1.0.0

git-svn-id: file:///root/webif/svn/humax/pkg/src/webif/trunk@1516 2a923420-c742-0410-a762-8d5b09965624
This commit is contained in:
hummypkg 2013-04-03 22:42:15 +00:00
parent 246112d68f
commit 232546feef
16 changed files with 377 additions and 78 deletions

View File

@ -1,7 +1,7 @@
Package: webif
Priority: optional
Section: web
Version: 0.13.3-4
Version: 1.0.0
Architecture: mipsel
Maintainer: af123@hummypkg.org.uk
Depends: webif-channelicons(>=1.0.5),mongoose(>=3.0-7),jim(>=0.73-1),jim-oo,jim-sqlite3(>=0.73-1),jim-cgi(>=0.7),jim-binary,service-control(>=1.2),busybox(>=1.20.2-1),lsof,epg(>=1.0.13),hmt(>=1.1.13),ssmtp,anacron,trm(>=1.1),openssl-command,nicesplice,id3v2,file,rsvsync(>=1.0.2),webif-charts(>=1.2),stripts(>=1.1.2),smartmontools,tmenu(>=1.05),ffmpeg,id3v2

View File

@ -19,10 +19,11 @@ grep -v webif/lib/bin/auto $cronf > $tmpf
# Add anacron jobs
ana=$PKG_ROOT/etc/anacrontab
grep -v 'backup/backup.jim' $ana > $tmpf
egrep -v 'backup/backup.jim|diskattrs' $ana > $tmpf
(
cat $tmpf
echo "1 8 sched_backup /mod/var/mongoose/cgi-bin/backup/backup.jim"
echo "1 5 diskattrs /mod/webif/lib/bin/diskattrs"
) > $ana
$PKG_ROOT/etc/init.d/S02anacron start < /dev/null > /dev/null 2>&1 &

View File

@ -10,7 +10,7 @@ if [ -f $cronf ]; then
fi
ana=/mod/etc/anacrontab
grep -v 'backup/backup.jim' $ana > $tmpf
egrep -v 'backup/backup.jim|diskattrs' $ana > $tmpf
cp $tmpf $ana
exit 0

View File

@ -40,6 +40,7 @@ set nomobile [$settings nomobile]
set xepghours [$settings xepghours]
if {$xepghours == 0} { set xepghours 4 }
set genrededup [$settings genrededup]
set autolog [$settings autolog]
# Handle updates
@ -80,6 +81,7 @@ handle_int_update pkgdev $pkgdev "Development Package Display"
handle_int_update notoolbar $notoolbar "Disable toolbar"
handle_int_update nomobile $nomobile "Disable mobile link"
handle_int_update genrededup $genrededup "Genre search dedup"
handle_int_update autolog $autolog "Auto-processing log level"
set acluser [cgi_get acluser "-"]
set aclpass [cgi_get aclpass "-"]
@ -177,6 +179,31 @@ puts ">
</tr>
"
puts -nonewline "
<form class=auto id=autolog method=get action=$env(REQUEST_URI)>
<th class=key>Auto-processing log level</th>
<td><select id=autolog name=autolog
class=\"text ui-widget-content ui-corner-all\">
"
puts "<option value=0"
if {$autolog == 0} { puts " selected" }
puts ">Actions and errors only\n"
puts "<option value=1"
if {$autolog == 1} { puts " selected" }
puts ">Actions, errors and scan information\n"
puts "<option value=2"
if {$autolog == 1} { puts " selected" }
puts ">Debugging information\n"
puts "
</select>
<small>
<input name=autolog value=\"set\" type=submit>
</small>
<div id=autolog_output></div>
</td>
</form>
"
puts "
</table></fieldset>
<br><br>

View File

@ -221,7 +221,7 @@ puts "
onSelect: function(val, sel) {
var stt = \$(this).attr('stt');
// Extract date part
dval = ~~(val / 86400000);
dval = Math.round(val / 86400000.0);
// Extract current time part
var tm = ~~(stt % 86400);

View File

@ -65,13 +65,33 @@ div.footer
padding-top: 2em;
}
div.warningbox
div.owarningbox
{
background: url('/img/redshade.png') repeat-x;
padding: 0.5em;
margin: 1em;
}
div.warningbox
{
width: 60%;
background: url('/img/redshade.png') repeat-x;
background-size: 100%;
#color: #005000;
border: 1px solid #7a4707;
padding: 10px;
position: relative;
top: -2px;
left: -2px;
font-weight: bold;
z-index: 30;
box-shadow: 2px 2px 11px #666;
-moz-box-shadow: 2px 2px 11px #666;
-webkit-box-shadow: 2px 2px 11px #666;
border-radius: 5px;
-moz-border-radius: 5px;
}
table
{
empty-cells: show;

View File

@ -2,12 +2,12 @@
package require cgi
source /mod/webif/lib/setup
require system.class
require system.class settings.class
header
set space [system diskspace]
set device [string range [lindex $space 5] 0 end-1]
set device [system disk]
set settings [settings]
set smart Unknown
set line ""
@ -16,9 +16,11 @@ catch { set line [exec /mod/bin/smartctl -H $device | sed -n 5p] } msg
if {$msg ne "" && $line eq ""} { set line $msg }
if {$line ne ""} {
set smart [string range [lindex [split $line :] 1] 1 end]
$settings _tval_setting "SMART_status" $smart
}
puts "
<script type=text/javascript src=/js/enadis.js></script>
<h3 class=va>
<img class=va width=100 src=/img/disc.png>
SMART data read from device $device
@ -99,9 +101,18 @@ foreach line [split [exec /mod/bin/smartctl -A $device] "\n"] {
id name flags val worst thresh type updated when rval
set class normal
switch $id {
5 { if {$rval > 0} { set class orangeshade } }
197 { if {$rval > 0} { set class redshade } }
198 { if {$rval > 0} { set class redshade } }
5 {
$settings _nval_setting "SMART_realloc" $rval
if {$rval > 0} { set class orangeshade }
}
197 {
$settings _nval_setting "SMART_pending" $rval
if {$rval > 0} { set class redshade }
}
198 {
$settings _nval_setting "SMART_offline" $rval
if {$rval > 0} { set class redshade }
}
}
puts "<tr class=$class>"
puts "
@ -144,6 +155,7 @@ foreach line [split $msg "\n"] {
regsub -all -- {[[:space:]][[:space:]]+} $line "|" line
if {[incr i] < 7} continue
lassign [split $line "|"] id name status remaining when lba
if {[string length $id] > 10} continue
puts "<tr>
<td>$id</td>
<td>$name</td>
@ -157,6 +169,28 @@ foreach line [split $msg "\n"] {
puts {
</table>
</fieldset>
<div class=cleft style="padding-top: 2em">
<button id=diskack>Acknowledge any current disk faults.</button>
</div>
<script type=text/javascript>
$(function() {
$('#diskack')
.button()
.on('click', function(e) {
e.preventDefault();
$('button').disable();
$.get('diskack.jim', function() {
window.location.reload(true);
});
});
});
</script>
}
footer

View File

@ -0,0 +1,16 @@
#!/mod/bin/jimsh
source /mod/webif/lib/setup
require settings.class
httpheader
set settings [settings]
foreach attr {realloc pending offline} {
set val [$settings _nval_setting "SMART_$attr"]
if {$val <= 0} continue
$settings _nval_setting "SMART_ack_$attr" $val
}

View File

@ -25,6 +25,7 @@ source /mod/webif/html/lib/topbar.jim
puts "<div id=restart_block>"
source /mod/webif/include/restart.jim
puts "</div>"
source /mod/webif/include/diskcheck.jim
puts {
<div style="clear: both">

View File

@ -8,12 +8,13 @@ puts {
<h2>Backup/Restore</h2>
<div id=restore_warning class="hidden warningbox">
<div>
<center>
<b>!!!!!!!!!!!!!! PLEASE NOTE !!!!!!!!!!!!!!
<br><br>
After restoring the scheduled recordings you <b>MUST</b> restart the box using
the link at the top of the screen or via the remote control.
</div>
</div></div>
<div style="clear: both; float: left; width: 40%; border: 1px solid grey;
padding: 1em">

View File

@ -0,0 +1,67 @@
#!/mod/bin/jimsh
source /mod/webif/lib/setup
require settings.class
set smartattrs {realloc pending offline}
set smartattribs(SMART_status) "Unknown"
foreach sa $smartattrs {
set smartattribs(SMART_$sa) 0
set smartattribs(SMART_ack_$sa) 0
}
foreach line [[settings] smartdata] {
lassign $line x name x n x t
if {$name eq "SMART_status"} {
set smartattribs($name) $t
} else {
set smartattribs($name) $n
}
}
# (SMART_ack_status 0 SMART_ack_pending 0 SMART_status PASSED SMART_pending 7 SMART_ack_realloc 0 SMART_ack_offline 0 SMART_realloc 0 SMART_offline 7)
set smartmsg ""
if {$smartattribs(SMART_status) ne "PASSED"} {
append smartmsg \
"Disk overall health assessment is: $smartattribs(SMART_status)\n"
}
foreach sa $smartattrs {
if {$smartattribs(SMART_$sa) != $smartattribs(SMART_ack_$sa)} {
append smartmsg \
"Disk $sa sector count is: $smartattribs(SMART_$sa)"
if {$smartattribs(SMART_ack_$sa) > 0} {
append smartmsg " (was $smartattribs(SMART_ack_$sa))"
}
append smartmsg "\n"
}
}
if {$smartmsg ne ""} {
puts "
<div id=smartwarning class=warningbox><center>
!! WARNING !!
<br><br>
There are some issues with the internal hard disk on this device.
<br><br>
[string map {"\n" "<br>"} $smartmsg]
"
if {$env(REQUEST_URI) ne "/diag/disk.jim"} {
puts "
<br>
<a href=/diag/disk.jim>Go to disk diagnostics</a>
"
} else {
puts "
<br>
For help and assistance, visit
<a target=_blank href=http://hummy.tv/>hummy.tv</a>
"
}
puts "
</center></div>
"
}

View File

@ -4,7 +4,9 @@ source /mod/webif/lib/setup
require system.class
lassign [system diskspace] size used perc free fperc
set file [format "%02d" [expr {$perc * 25 / 100 + 1}]]
set dsindex $($perc * 25 / 100 + 1)
if {$dsindex > 25} { set dsindex 25 }
set dsfile [format "%02d" $dsindex]
# The HD model only has the USB images which are blue. I prefer the green
# one so use those if available.
@ -19,7 +21,7 @@ puts "
<span style=\"float: right;
background:url('/images/345_1_27_ST_USB_BG.png')
no-repeat\">
<img src=/images/${prefix}_$file.png>
<img src=/images/${prefix}_$dsfile.png>
</span>
<span style=\"float: right\">

View File

@ -1,9 +1,10 @@
#!/mod/bin/jimsh
source /mod/webif/lib/setup
require lock system.class ts.class tdelete pretty_size browse.class safe_delete
require lock system.class ts.class tdelete pretty_size browse.class \
safe_delete settings.class
set debug 0
set loglevel [[settings] autolog]
if {![acquire_lock webif_auto]} {
puts "Cannot acquire exclusive lock, terminating."
@ -18,8 +19,8 @@ if {[file exists $logfile] && [file size $logfile] > 2097152} {
}
set logfd [open "/mod/tmp/auto.log" "a+"]
proc log {msg {always 0}} {
if {!$::debug && !$always} return
proc log {msg {level 1}} {
if {$level > $::loglevel} return
puts $::logfd "[\
clock format [clock seconds] -format "%d/%m/%Y %H:%M"\
] - $msg"
@ -41,7 +42,7 @@ proc endclock {size} {
}
set scanstart [clock milliseconds]
log "-------------------------------------------------------" 1
log "-------------------------------------------------------"
# is_listening is relatively expensive so it is checked once globally at
# the start and then if the server is not listening then no decrypt
@ -51,13 +52,13 @@ log "-------------------------------------------------------" 1
# of the run.
if {[system is_listening 9000]} {
set dlnaok 1
if {$::debug} { log "DLNA Server is running." }
log "DLNA Server is running." 2
} else {
set dlnaok 0
if {$::debug} { log "DLNA Server is NOT running." }
log "DLNA Server is NOT running." 2
}
log "Media scan starting, DLNA server status: $dlnaok" 1
log "Media scan starting, DLNA server status: $dlnaok"
proc dsc {{size 0}} {
set free [system diskfree]
@ -66,7 +67,7 @@ proc dsc {{size 0}} {
set req $($size * 3 + 1073741824)
if {$free < $req} {
log "Insufficient disk space. Require=$req, Free=$free" 1
log "Insufficient disk space. Require=$req, Free=$free" 0
exit
}
}
@ -76,11 +77,11 @@ dsc
set tmp "/mod/tmp/webif_auto"
if {![file exists $tmp]} {
if {[catch {file mkdir $tmp} msg]} {
log "Cannot create temporary directory - $tmp ($msg)" 1
log "Cannot create temporary directory - $tmp ($msg)" 0
exit
}
} elseif {![file isdirectory $tmp]} {
log "Cannot create temporary directory - $tmp (file exists)" 1
log "Cannot create temporary directory - $tmp (file exists)" 0
exit
}
@ -93,14 +94,14 @@ if {[system pkginst undelete]} {
set dustbin ""
}
log "Dustbin: $dustbin"
log "Dustbin: $dustbin" 2
proc dedup {dir} {
log "DEDUP: \[$dir]"
log "DEDUP: \[$dir]" 2
loop i 0 1 {
foreach line [split \
[exec /mod/webif/html/dedup/dedup -yes -auto $dir] "\n"] {
log $line 1
log $line 2
}
}
}
@ -111,39 +112,41 @@ proc do_expire {ts} {
# Calculate the age of the file in days.
set age $(([clock seconds] - [$ts get start]) / 86400.0)
log " EXPIRE: $file (age = $age)"
log " EXPIRE: $file (age = $age)" 2
if {$age > $ax_days} {
log " EXPIRE: $file ($age > $ax_days)" 1
if {[$ts inuse]} {
log " In use." 1
log " EXPIRE: $file ($age > $ax_days)"
log " In use."
return
}
if {[safe_delete $file]} {
log " Deleted." 1
log " EXPIRE: $file ($age > $ax_days)" 0
log " Deleted." 0
}
}
}
proc do_shrink {ts} {
global tmp dustbin tsgroup
set file [$ts get file]
if {[$ts flag "Shrunk"]} {
log " Already shrunk."
log " $file - already shrunk." 2
return
}
set file [file rootname [$ts get file]]
if {[$ts inuse]} {
log " $file - in use." 1
log " $file - in use." 2
return
}
if {[catch {
set perc [exec /mod/bin/stripts -aq $file]
} msg]} {
log " Error: $msg" 1
log " Error: $msg" 0
return
}
if {[string match {*%} $perc]} {
@ -153,24 +156,24 @@ proc do_shrink {ts} {
}
if {$perc == 0} {
log " Already shrunk."
log " $file - already shrunk." 2
$ts set_shrunk
return
}
set size [$ts size]
dsc $size
startclock
log " SHRINK: $file" 1
log " Estimate $perc% saving." 1
log " Shrinking..." 1
log " SHRINK: $file" 0
log " Estimate $perc% saving." 0
log " Shrinking..." 0
if {[catch {
foreach line [split \
[exec nice -n 19 /mod/bin/stripts -q $file $tmp/shrunk] \
"\n"] {
log $line 1
log $line 0
}
} msg]} {
log "Error during shrink: $msg" 1
log "Error during shrink: $msg" 0
return
}
@ -196,7 +199,7 @@ proc do_shrink {ts} {
}
}
$ts set_shrunk
log "Done... [endclock $size]" 1
log "Done... [endclock $size]" 0
}
proc do_decrypt {ts} {
@ -207,37 +210,72 @@ proc do_decrypt {ts} {
set bfile [file tail $file]
if {![$ts flag "ODEncrypted"]} {
log " Already decrypted."
log " $file - Already decrypted." 2
return
}
lassign [$ts dlnaloc "127.0.0.1"] url
if {$url eq ""} {
log " Not yet indexed."
log " $file - Not yet indexed."
return
}
if {![system is_listening 9000]} {
log " DLNA Server not running."
log " $file - DLNA Server not running." 2
set ::dlnaok 0
return
}
if {[$ts inuse]} {
log " In use." 1
log " $file - In use."
return
}
# Check that the file is not already decrypted by analysing it.
set anencd [exec /mod/bin/stripts -qE $rfile]
if {$anencd != "1"} {
log " $file - already decrypted but the HMT flag is wrong." 0
system notify "$file - auto-decrypt - file is already decrypted but the HMT flag is wrong."
return
}
# Perform the decryption by requesting the file from the DLNA server.
set size [$ts size]
dsc $size
set flagfile "$tmp/decrypting.$bfile"
exec /mod/bin/busybox/touch $flagfile
startclock
log " DECRYPT: $rfile" 1
log " DLNA: $url" 1
log " DECRYPT: $rfile" 0
log " DLNA: $url" 0
exec wget -O "$tmp/$bfile" $url
if {[file size $file] != [file size "$tmp/$bfile"]} {
log " File size mismatch." 1
log " $file - File size mismatch." 0
file delete "$tmp/$bfile"
file delete $flagfile
return
}
# Check if the file is in use. It is possible that the file is
# now being played even though it was free when decryption started.
if {[$ts inuse]} {
log " $file - In use."
file delete "$tmp/$bfile"
file delete $flagfile
return
}
# Copy the HMT file over for stripts
set thmt "$tmp/[file rootname $bfile].hmt"
file copy "$rfile.hmt" $thmt
# Check that the file is no longer encrypted by analysing it.
set anencd [exec /mod/bin/stripts -qE "$tmp/[file rootname $bfile]"]
file delete $thmt
if {$anencd != "0"} {
log " $file - File did not decrypt properly." 0
system notify "$file - auto-decrypt failed."
file delete "$tmp/$bfile"
file delete $flagfile
return
}
@ -249,7 +287,7 @@ proc do_decrypt {ts} {
# Patch the HMT - quickest way to get back to a playable file.
exec /mod/bin/hmt -encrypted "$rfile.hmt"
log " Removing/binning old copy."
log " Removing/binning old copy." 0
# Move the old recording to the bin if undelete is installed.
if {$dustbin ne ""} {
set bin [_del_bindir $file "webif_autodecrypt"]
@ -268,7 +306,7 @@ proc do_decrypt {ts} {
} else {
tdelete "$rfile.encrypted"
}
log "Done... [endclock $size]" 1
log "Done... [endclock $size]" 0
file delete $flagfile
}
@ -283,7 +321,7 @@ proc do_mpg {ts} {
}
if {[$ts flag "ODEncrypted"]} {
log " Not decrypted."
log " $file - Not decrypted." 2
return
}
@ -293,23 +331,23 @@ proc do_mpg {ts} {
}
if {[$ts inuse]} {
log " In use." 1
log " $file - In use."
return
}
dsc [$ts size]
log " MPG: $file" 1
log " Converting..." 1
log " MPG: $file" 0
log " Converting..." 0
if {[catch {
foreach line [split \
[exec nice -n 19 /mod/bin/ffmpeg -y -benchmark -v 0 \
-i $file.ts \
-map 0:0 -map 0:1 \
-vcodec copy -acodec copy $tmp/mpg.mpg] "\n"] {
log $line 1
log $line 0
}
} msg]} {
log "Error during mpg extract: $msg" 1
log "Error during mpg extract: $msg" 0
return
}
@ -328,32 +366,33 @@ proc do_mp3 {ts} {
}
if {[$ts flag "ODEncrypted"]} {
log " Not decrypted."
log " $file - Not decrypted." 2
return
}
if {[$ts get definition] eq "HD"} {
# Cannot extract a useful MP3 from a HD recording.
log " $file - High definition." 2
return
}
if {[$ts inuse]} {
log " In use." 1
log " $file - In use."
return
}
dsc [$ts size]
log " MP3: $file" 1
log " Converting..." 1
log " MP3: $file" 0
log " Converting..." 0
if {[catch {
foreach line [split \
[exec nice -n 19 /mod/bin/ffmpeg -y -benchmark -v 0 \
-i $file.ts \
-f mp3 -vn -acodec copy $tmp/mp3.mp3] "\n"] {
log $line 1
log $line 0
}
} msg]} {
log "Error during mp3 extract: $msg" 1
log "Error during mp3 extract: $msg" 0
return
}
@ -363,7 +402,7 @@ proc do_mp3 {ts} {
--comment "[$ts get synopsis]" \
--album "[$ts get channel_name]" \
--year "[clock format [$ts get start] -format {%Y}]" \
"$tmp/mp3.mp3"]
"$tmp/mp3.mp3"] 0
}
# Move the MP3 into the local directory
@ -380,28 +419,28 @@ proc entries {dir callback} {
}
proc shrink {dir} {
log "SHRINK: \[$dir]"
log "SHRINK: \[$dir]" 2
entries $dir do_shrink
}
proc decrypt {dir} {
log "DECRYPT: \[$dir]"
log "DECRYPT: \[$dir]" 2
if {$::dlnaok} { entries $dir do_decrypt }
}
proc mpg {dir} {
log "MPG: \[$dir]"
log "MPG: \[$dir]" 2
entries $dir do_mpg
}
proc mp3 {dir} {
log "MP3: \[$dir]"
log "MP3: \[$dir]" 2
entries $dir do_mp3
}
proc expire {dir} {
global ax_days
log "EXPIRE: \[$dir]"
log "EXPIRE: \[$dir]" 2
set ax_days [{dir expiry} $dir]
entries $dir do_expire
@ -412,10 +451,10 @@ proc scan {dir attr {force 0}} {{indent 0}} {
incr indent 2
log "[string repeat " " $indent]\[$dir]"
log "[string repeat " " $indent]\[$dir]" 2
if {$dir eq $dustbin} {
log "Dustbin, skipping."
log "Dustbin, skipping." 2
return
}
@ -423,18 +462,18 @@ proc scan {dir attr {force 0}} {{indent 0}} {
# Special folder
file stat "$dir/" st
if {$st(dev) != $::rootdev} {
log "Special folder on different device, skipping."
log "Special folder on different device, skipping." 2
return
}
if {$force} {
set force 0
log "Special folder, overriding recursion."
log "Special folder, overriding recursion." 2
}
}
# Recursion
if {!$force && [file exists "$dir/.auto${attr}r"]} {
log "[string repeat " " $indent] (R)"
log "[string repeat " " $indent] (R)" 2
set force 1
}
@ -454,20 +493,20 @@ proc scan {dir attr {force 0}} {{indent 0}} {
set root [system mediaroot]
file stat "$root/" rootstat
set rootdev $rootstat(dev)
#log "Root device: $rootdev" 1
log "Root device: $rootdev" 2
if {[llength $argv] > 0} {
set debug 1
set loglevel 2
foreach arg $argv { scan $root $arg }
} else {
foreach arg {dedup decrypt shrink mpg mp3 expire} {
set st [clock milliseconds]
scan $root $arg
log "$arg scan completed in [elapsed $st] seconds." 1
log "$arg scan completed in [elapsed $st] seconds."
}
}
release_lock webif_auto
log "Media scan completed in [elapsed $scanstart] seconds." 1
log "Media scan completed in [elapsed $scanstart] seconds."

45
var/mongoose/lib/bin/diskattrs Executable file
View File

@ -0,0 +1,45 @@
#!/mod/bin/jimsh
source /mod/webif/lib/setup
require system.class settings.class
if {[system model] eq "HD"} exit
set disk [system disk]
set settings [settings]
# Extract overall SMART status.
set smart ""
set line ""
# smartctl uses non-zero exit status to indicate health hence catch.
catch { set line [exec /mod/bin/smartctl -H $disk | sed -n 5p] } msg
if {$msg ne "" && $line eq ""} { set line $msg }
if {$line ne ""} {
set smart [string range [lindex [split $line :] 1] 1 end]
$settings _tval_setting "SMART_status" $smart
}
foreach line [split [exec /mod/bin/smartctl -A -f brief $disk] "\n"] {
regsub -all -- {[[:space:]]+} $line " " line
regsub -all -- {^[[:space:]]+} $line "" line
lassign [split $line] id name flags val worst thresh when rval
if {![string is integer $id]} continue
set attrs($id) $rval
}
#puts "Attrs: ($attrs)"
puts "SMART: ($smart)"
puts "Reallocated: $attrs(5)"
puts "Pending: $attrs(197)"
puts "Offline: $attrs(198)"
if {[dict exists $attrs 5]} {
$settings _nval_setting "SMART_realloc" $attrs(5)
}
if {[dict exists $attrs 197]} {
$settings _nval_setting "SMART_pending" $attrs(197)
}
if {[dict exists $attrs 198]} {
$settings _nval_setting "SMART_offline" $attrs(198)
}

View File

@ -26,6 +26,7 @@ class settings {
nomobile 0
xepghours 4
genrededup 0
autolog 0
}
settings method hostname {{name ""}} {
@ -100,6 +101,29 @@ settings method _nval_setting {name {val -1}} {
}
}
settings method _tval_setting {name {val -1}} {
global settingsdb
if {$val == -1} {
# Get
set res [$settingsdb query "
select tval from settings
where name = '$name'
"]
if {$res ne ""} {
return [lindex [lindex $res end] end]
}
return 0
} else {
# Set
$settingsdb query "
replace into settings(name,tval)
values('$name', '%s')
" $val
return 0
}
}
settings method channel_group {{group -1}} {
return [$self _nval_setting channel_group $group]
}
@ -140,6 +164,10 @@ settings method sortorder {{val -1}} {
return [$self _nval_setting sortorder $val]
}
settings method autolog {{level -1}} {
return [$self _nval_setting autolog $level]
}
settings method channel_groups {} {
set ret ""
set db [sqlite3.open /var/lib/humaxtv/setup.db]
@ -232,3 +260,14 @@ settings method delacluser {user} {
return $msg
}
settings method smartdata {} {
global settingsdb
set res [$settingsdb query "
select name, nval, tval from settings
where name like 'SMART_%%'
"]
return $res
}

View File

@ -139,6 +139,10 @@ proc {system diskspace} {} {
return [list $size $used $perc $free $fperc $dev]
}
proc {system disk} {} {
return [string range [lindex [system diskspace] 5] 0 end-1]
}
proc {system diskfree} {} {
switch [system model] {
HDR { set part /mnt/hd2 }
@ -244,3 +248,6 @@ proc {system is_listening} {mport} {
return [llength [system listening $mport]]
}
proc {system notify} {msg} {
}