forked from hummypkg/webif
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:
parent
246112d68f
commit
232546feef
@ -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
|
||||
|
@ -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 &
|
||||
|
@ -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
|
||||
|
@ -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>
|
||||
|
@ -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);
|
||||
|
||||
|
@ -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;
|
||||
|
@ -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
|
||||
|
16
var/mongoose/html/diag/diskack.jim
Executable file
16
var/mongoose/html/diag/diskack.jim
Executable 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
|
||||
}
|
||||
|
||||
|
@ -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">
|
||||
|
@ -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">
|
||||
|
67
var/mongoose/include/diskcheck.jim
Executable file
67
var/mongoose/include/diskcheck.jim
Executable 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>
|
||||
"
|
||||
}
|
||||
|
@ -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\">
|
||||
|
@ -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
45
var/mongoose/lib/bin/diskattrs
Executable 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)
|
||||
}
|
||||
|
@ -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
|
||||
}
|
||||
|
||||
|
@ -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} {
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user