mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-01-28 23:47:40 +01:00
706 lines
27 KiB
PHP
706 lines
27 KiB
PHP
<?php
|
|
|
|
/* Prevent XSS input */
|
|
$_GET = filter_input_array(INPUT_GET, FILTER_SANITIZE_STRING);
|
|
$_POST = filter_input_array(INPUT_POST, FILTER_SANITIZE_STRING);
|
|
|
|
error_reporting(E_ERROR);
|
|
ini_set('display_errors',1);
|
|
require_once 'scripts/common.php';
|
|
$home = get_home();
|
|
$config = get_config();
|
|
|
|
$db = new SQLite3('./scripts/birds.db', SQLITE3_OPEN_READONLY);
|
|
$db->busyTimeout(1000);
|
|
|
|
if(isset($_GET['deletefile'])) {
|
|
ensure_authenticated('You must be authenticated to delete files.');
|
|
if (preg_match('~^.*(\.\.\/).+$~', $_GET['deletefile'])) {
|
|
echo "Error";
|
|
die();
|
|
}
|
|
$db_writable = new SQLite3('./scripts/birds.db', SQLITE3_OPEN_READWRITE);
|
|
$db->busyTimeout(1000);
|
|
$statement1 = $db_writable->prepare('DELETE FROM detections WHERE File_Name = :file_name LIMIT 1');
|
|
ensure_db_ok($statement1);
|
|
$statement1->bindValue(':file_name', explode("/", $_GET['deletefile'])[2]);
|
|
$file_pointer = $home."/BirdSongs/Extracted/By_Date/".$_GET['deletefile'];
|
|
if (!exec("sudo rm $file_pointer 2>&1 && sudo rm $file_pointer.png 2>&1", $output)) {
|
|
echo "OK";
|
|
} else {
|
|
echo "Error - file deletion failed : " . implode(", ", $output) . "<br>";
|
|
}
|
|
$result1 = $statement1->execute();
|
|
if ($result1 === false || $db_writable->changes() === 0) {
|
|
echo "Error - database line deletion failed : " . $db_writable->lastErrorMsg();
|
|
}
|
|
$db_writable->close();
|
|
die();
|
|
}
|
|
|
|
if(isset($_GET['excludefile'])) {
|
|
ensure_authenticated('You must be authenticated to change the protection of files.');
|
|
if(!file_exists($home."/BirdNET-Pi/scripts/disk_check_exclude.txt")) {
|
|
file_put_contents($home."/BirdNET-Pi/scripts/disk_check_exclude.txt", "##start\n##end\n");
|
|
}
|
|
if(isset($_GET['exclude_add'])) {
|
|
$myfile = fopen($home."/BirdNET-Pi/scripts/disk_check_exclude.txt", "a") or die("Unable to open file!");
|
|
$txt = $_GET['excludefile'];
|
|
fwrite($myfile, $txt."\n");
|
|
fwrite($myfile, $txt.".png\n");
|
|
fclose($myfile);
|
|
echo "OK";
|
|
die();
|
|
} else {
|
|
$lines = file($home."/BirdNET-Pi/scripts/disk_check_exclude.txt");
|
|
$search = $_GET['excludefile'];
|
|
|
|
$result = '';
|
|
foreach($lines as $line) {
|
|
if(stripos($line, $search) === false && stripos($line, $search.".png") === false) {
|
|
$result .= $line;
|
|
}
|
|
}
|
|
file_put_contents($home."/BirdNET-Pi/scripts/disk_check_exclude.txt", $result);
|
|
echo "OK";
|
|
die();
|
|
}
|
|
}
|
|
|
|
if(isset($_GET['getlabels'])) {
|
|
$labels = file('/home/pi/BirdNET-Pi/model/labels.txt', FILE_IGNORE_NEW_LINES);
|
|
echo json_encode($labels);
|
|
die();
|
|
}
|
|
|
|
if(isset($_GET['changefile']) && isset($_GET['newname'])) {
|
|
ensure_authenticated('You must be authenticated to delete files.');
|
|
if (preg_match('~^.*(\.\.\/).+$~', $_GET['changefile'])) {
|
|
echo "Error";
|
|
die();
|
|
}
|
|
$oldname = basename(urldecode($_GET['changefile']));
|
|
$newname = urldecode($_GET['newname']);
|
|
if (!exec("$home/BirdNET-Pi/scripts/birdnet_changeidentification.sh \"$oldname\" \"$newname\" log_errors 2>&1", $output)) {
|
|
echo "OK";
|
|
} else {
|
|
echo "Error : " . implode(", ", $output) . "<br>";
|
|
}
|
|
die();
|
|
}
|
|
|
|
$shifted_path = $home."/BirdSongs/Extracted/By_Date/shifted/";
|
|
|
|
if(isset($_GET['shiftfile'])) {
|
|
ensure_authenticated('You cannot shift files for this installation');
|
|
|
|
$filename = $_GET['shiftfile'];
|
|
$pp = pathinfo($filename);
|
|
$dir = $pp['dirname'];
|
|
$fn = $pp['filename'];
|
|
$ext = $pp['extension'];
|
|
$pi = $home."/BirdSongs/Extracted/By_Date/";
|
|
|
|
if(isset($_GET['doshift'])) {
|
|
$freqshift_tool = $config['FREQSHIFT_TOOL'];
|
|
|
|
if ($freqshift_tool == "ffmpeg") {
|
|
$cmd = "sudo /usr/bin/nohup /usr/bin/ffmpeg -y -i ".escapeshellarg($pi.$filename)." -af \"rubberband=pitch=".$config['FREQSHIFT_LO']."/".$config['FREQSHIFT_HI']."\" ".escapeshellarg($shifted_path.$filename)."";
|
|
shell_exec("sudo mkdir -p ".$shifted_path.$dir." && ".$cmd);
|
|
|
|
} else if ($freqshift_tool == "sox") {
|
|
//linux.die.net/man/1/sox
|
|
$soxopt = "-q";
|
|
$soxpitch = $config['FREQSHIFT_PITCH'];
|
|
$cmd = "sudo /usr/bin/nohup /usr/bin/sox ".escapeshellarg($pi.$filename)." ".escapeshellarg($shifted_path.$filename)." pitch ".$soxopt." ".$soxpitch;
|
|
shell_exec("sudo mkdir -p ".$shifted_path.$dir." && ".$cmd);
|
|
}
|
|
} else {
|
|
$cmd = "sudo rm -f " . escapeshellarg($shifted_path.$filename);
|
|
shell_exec($cmd);
|
|
}
|
|
|
|
echo "OK";
|
|
die();
|
|
}
|
|
|
|
if(isset($_GET['bydate'])){
|
|
$statement = $db->prepare('SELECT DISTINCT(Date) FROM detections GROUP BY Date ORDER BY Date DESC');
|
|
ensure_db_ok($statement);
|
|
$result = $statement->execute();
|
|
$view = "bydate";
|
|
|
|
#Specific Date
|
|
} elseif(isset($_GET['date'])) {
|
|
$date = $_GET['date'];
|
|
session_start();
|
|
$_SESSION['date'] = $date;
|
|
if(isset($_GET['sort']) && $_GET['sort'] == "occurrences") {
|
|
$statement = $db->prepare("SELECT DISTINCT(Com_Name) FROM detections WHERE Date == \"$date\" GROUP BY Com_Name ORDER BY COUNT(*) DESC");
|
|
} else {
|
|
$statement = $db->prepare("SELECT DISTINCT(Com_Name) FROM detections WHERE Date == \"$date\" ORDER BY Com_Name");
|
|
}
|
|
ensure_db_ok($statement);
|
|
$result = $statement->execute();
|
|
$view = "date";
|
|
|
|
#By Species
|
|
} elseif(isset($_GET['byspecies'])) {
|
|
if(isset($_GET['sort']) && $_GET['sort'] == "occurrences") {
|
|
$statement = $db->prepare('SELECT DISTINCT(Com_Name) FROM detections GROUP BY Com_Name ORDER BY COUNT(*) DESC');
|
|
} else {
|
|
$statement = $db->prepare('SELECT DISTINCT(Com_Name) FROM detections ORDER BY Com_Name ASC');
|
|
}
|
|
session_start();
|
|
ensure_db_ok($statement);
|
|
$result = $statement->execute();
|
|
$view = "byspecies";
|
|
|
|
#Specific Species
|
|
} elseif(isset($_GET['species'])) {
|
|
$species = htmlspecialchars_decode($_GET['species'], ENT_QUOTES);
|
|
session_start();
|
|
$_SESSION['species'] = $species;
|
|
$statement = $db->prepare("SELECT * FROM detections WHERE Com_Name == \"$species\" ORDER BY Com_Name");
|
|
ensure_db_ok($statement);
|
|
$statement3 = $db->prepare("SELECT Date, Time, Sci_Name, MAX(Confidence), File_Name FROM detections WHERE Com_Name == \"$species\" ORDER BY Com_Name");
|
|
ensure_db_ok($statement3);
|
|
$result = $statement->execute();
|
|
$result3 = $statement3->execute();
|
|
$view = "species";
|
|
} else {
|
|
unset($_SESSION['species']);
|
|
unset($_SESSION['date']);
|
|
$view = "choose";
|
|
}
|
|
|
|
if (get_included_files()[0] === __FILE__) {
|
|
echo '<!DOCTYPE html>
|
|
<html lang="en">
|
|
<head>
|
|
<meta charset="UTF-8">
|
|
<meta name="viewport" content="width=device-width, initial-scale=1">
|
|
</head>';
|
|
}
|
|
|
|
?>
|
|
<script>
|
|
|
|
function deleteDetection(filename,copylink=false) {
|
|
if (confirm("Are you sure you want to delete this detection from the database?") == true) {
|
|
const xhttp = new XMLHttpRequest();
|
|
xhttp.onload = function() {
|
|
if(this.responseText == "OK"){
|
|
if(copylink == true) {
|
|
window.top.close();
|
|
} else {
|
|
location.reload();
|
|
}
|
|
} else {
|
|
alert(this.responseText);
|
|
}
|
|
}
|
|
xhttp.open("GET", "play.php?deletefile="+filename, true);
|
|
xhttp.send();
|
|
}
|
|
}
|
|
|
|
function toggleLock(filename, type, elem) {
|
|
const xhttp = new XMLHttpRequest();
|
|
xhttp.onload = function() {
|
|
if(this.responseText == "OK"){
|
|
if(type == "add") {
|
|
elem.setAttribute("src","images/lock.svg");
|
|
elem.setAttribute("title", "This file is excluded from being purged.");
|
|
elem.setAttribute("onclick", elem.getAttribute("onclick").replace("add","del"));
|
|
} else {
|
|
elem.setAttribute("src","images/unlock.svg");
|
|
elem.setAttribute("title", "This file will be deleted when disk space needs to be freed.");
|
|
elem.setAttribute("onclick", elem.getAttribute("onclick").replace("del","add"));
|
|
}
|
|
}
|
|
}
|
|
if(type == "add") {
|
|
xhttp.open("GET", "play.php?excludefile="+filename+"&exclude_add=true", true);
|
|
} else {
|
|
xhttp.open("GET", "play.php?excludefile="+filename+"&exclude_del=true", true);
|
|
}
|
|
xhttp.send();
|
|
elem.setAttribute("src","images/spinner.gif");
|
|
}
|
|
|
|
function toggleShiftFreq(filename, shiftAction, elem) {
|
|
const xhttp = new XMLHttpRequest();
|
|
xhttp.onload = function() {
|
|
if(this.responseText == "OK"){
|
|
if(shiftAction == "shift") {
|
|
elem.setAttribute("src","images/unshift.svg");
|
|
elem.setAttribute("title", "This file has been shifted down in frequency.");
|
|
elem.setAttribute("onclick", elem.getAttribute("onclick").replace("shift","unshift"));
|
|
console.log("shifted freqs of " + filename);
|
|
video=elem.parentNode.getElementsByTagName("video");
|
|
if (video.length > 0) {
|
|
video[0].setAttribute("title", video[0].getAttribute("title").replace("/By_Date/","/By_Date/shifted/"));
|
|
source = video[0].getElementsByTagName("source")[0];
|
|
source.setAttribute("src", source.getAttribute("src").replace("/By_Date/","/By_Date/shifted/"));
|
|
video[0].load();
|
|
} else {
|
|
atag=elem.parentNode.getElementsByTagName("a")[0];
|
|
atag.setAttribute("href", atag.getAttribute("href").replace("/By_Date/","/By_Date/shifted/"));
|
|
}
|
|
} else {
|
|
elem.setAttribute("src","images/shift.svg");
|
|
elem.setAttribute("title", "This file is not shifted in frequency.");
|
|
elem.setAttribute("onclick", elem.getAttribute("onclick").replace("unshift","shift"));
|
|
console.log("unshifted freqs of " + filename);
|
|
video=elem.parentNode.getElementsByTagName("video");
|
|
if (video.length > 0) {
|
|
video[0].setAttribute("title", video[0].getAttribute("title").replace("/By_Date/shifted/","/By_Date/"));
|
|
source = video[0].getElementsByTagName("source")[0];
|
|
source.setAttribute("src", source.getAttribute("src").replace("/By_Date/shifted/","/By_Date/"));
|
|
video[0].load();
|
|
} else {
|
|
atag=elem.parentNode.getElementsByTagName("a")[0];
|
|
atag.setAttribute("href", atag.getAttribute("href").replace("/By_Date/shifted/","/By_Date/"));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
if(shiftAction == "shift") {
|
|
console.log("shifting freqs of " + filename);
|
|
xhttp.open("GET", "play.php?shiftfile="+filename+"&doshift=true", true);
|
|
} else {
|
|
console.log("unshifting freqs of " + filename);
|
|
xhttp.open("GET", "play.php?shiftfile="+filename, true);
|
|
}
|
|
xhttp.send();
|
|
elem.setAttribute("src","images/spinner.gif");
|
|
}
|
|
|
|
function changeDetection(filename,copylink=false) {
|
|
const xhttp = new XMLHttpRequest();
|
|
xhttp.onload = function() {
|
|
const labels = JSON.parse(this.responseText);
|
|
let dropdown = '<input type="text" id="filterInput" placeholder="Type to filter..."><select id="labelDropdown" size="5" style="display: block; margin: 0 auto;"></select>';
|
|
|
|
// Check if the modal already exists
|
|
let modal = document.getElementById('myModal');
|
|
if (!modal) {
|
|
// Create a modal box
|
|
modal = document.createElement('div');
|
|
modal.setAttribute('id', 'myModal');
|
|
modal.setAttribute('class', 'modal');
|
|
|
|
// Create a content box
|
|
let content = document.createElement('div');
|
|
content.setAttribute('class', 'modal-content');
|
|
|
|
// Add a title to the modal box
|
|
let title = document.createElement('h2');
|
|
title.textContent = 'Please select the correct specie here:';
|
|
content.appendChild(title);
|
|
|
|
// Add the dropdown to the content
|
|
let selectElement = document.createElement('div');
|
|
selectElement.innerHTML = dropdown;
|
|
content.appendChild(selectElement);
|
|
|
|
// Append the content to the modal
|
|
modal.appendChild(content);
|
|
|
|
// Append the modal to the body
|
|
document.body.appendChild(modal);
|
|
}
|
|
|
|
// Display the modal
|
|
modal.style.display = "block";
|
|
|
|
// Populate the dropdown list
|
|
let dropdownList = document.getElementById('labelDropdown');
|
|
labels.forEach(label => {
|
|
let option = document.createElement('option');
|
|
option.value = label;
|
|
option.text = label;
|
|
dropdownList.appendChild(option);
|
|
});
|
|
|
|
// Add an event listener to the modal box to hide it when clicked outside
|
|
document.addEventListener('click', function(event) {
|
|
if (event.target == modal) {
|
|
modal.style.display = "none";
|
|
dropdownList.selectedIndex = -1; // Reset the dropdown selection
|
|
}
|
|
});
|
|
|
|
// Add an event listener to the input box to filter the dropdown list
|
|
document.getElementById('filterInput').addEventListener('keyup', function() {
|
|
let filter = this.value.toUpperCase();
|
|
let options = dropdownList.options;
|
|
// Clear the dropdown list
|
|
while (dropdownList.firstChild) {
|
|
dropdownList.removeChild(dropdownList.firstChild);
|
|
}
|
|
// Populate the dropdown list with the filtered labels
|
|
labels.forEach(label => {
|
|
if (label.toUpperCase().indexOf(filter) > -1) {
|
|
let option = document.createElement('option');
|
|
option.value = label;
|
|
option.text = label;
|
|
dropdownList.appendChild(option);
|
|
}
|
|
});
|
|
});
|
|
|
|
dropdownList.addEventListener('change', function() {
|
|
const newname = this.value;
|
|
// Check if the default option is selected
|
|
if (newname === '') {
|
|
return; // Exit the function early
|
|
}
|
|
if (confirm("Are you sure you want to change the specie identified in this detection to " + newname + "?") == true) {
|
|
const xhttp2 = new XMLHttpRequest();
|
|
xhttp2.onload = function() {
|
|
if(this.responseText == "OK"){
|
|
if(copylink == true) {
|
|
window.top.close();
|
|
} else {
|
|
location.reload();
|
|
}
|
|
} else {
|
|
alert(this.responseText);
|
|
}
|
|
}
|
|
xhttp2.open("GET", "play.php?changefile="+filename+"&newname="+newname, true);
|
|
xhttp2.send();
|
|
}
|
|
// Hide the modal box and reset the dropdown selection
|
|
modal.style.display = "none";
|
|
this.selectedIndex = -1;
|
|
});
|
|
}
|
|
xhttp.open("GET", "play.php?getlabels=true", true);
|
|
xhttp.send();
|
|
}
|
|
|
|
</script>
|
|
|
|
<?php
|
|
#If no specific species
|
|
if(!isset($_GET['species']) && !isset($_GET['filename'])){
|
|
?>
|
|
<div class="play">
|
|
<?php if($view == "byspecies" || $view == "date") { ?>
|
|
<div style="width: auto;
|
|
text-align: center">
|
|
<form action="views.php" method="GET">
|
|
<input type="hidden" name="view" value="Recordings">
|
|
<input type="hidden" name="<?php echo $view; ?>" value="<?php echo $_GET['date']; ?>">
|
|
<button <?php if(!isset($_GET['sort']) || $_GET['sort'] == "alphabetical"){ echo "style='background:#9fe29b !important;'"; }?> class="sortbutton" type="submit" name="sort" value="alphabetical">
|
|
<img src="images/sort_abc.svg" title="Sort by alphabetical" alt="Sort by alphabetical">
|
|
</button>
|
|
<button <?php if(isset($_GET['sort']) && $_GET['sort'] == "occurrences"){ echo "style='background:#9fe29b !important;'"; }?> class="sortbutton" type="submit" name="sort" value="occurrences">
|
|
<img src="images/sort_occ.svg" title="Sort by occurrences" alt="Sort by occurrences">
|
|
</button>
|
|
</form>
|
|
</div>
|
|
<br>
|
|
<?php } ?>
|
|
<form action="views.php" method="GET">
|
|
<input type="hidden" name="view" value="Recordings">
|
|
<table>
|
|
<?php
|
|
#By Date
|
|
if($view == "bydate") {
|
|
while($results=$result->fetchArray(SQLITE3_ASSOC)){
|
|
$date = $results['Date'];
|
|
if(realpath($home."/BirdSongs/Extracted/By_Date/".$date) !== false){
|
|
echo "<td>
|
|
<button action=\"submit\" name=\"date\" value=\"$date\">".($date == date('Y-m-d') ? "Today" : $date)."</button></td></tr>";}}
|
|
|
|
#By Species
|
|
} elseif($view == "byspecies") {
|
|
$birds = array();
|
|
while($results=$result->fetchArray(SQLITE3_ASSOC))
|
|
{
|
|
$name = $results['Com_Name'];
|
|
$birds[] = $name;
|
|
}
|
|
|
|
if(count($birds) > 45) {
|
|
$num_cols = 3;
|
|
} else {
|
|
$num_cols = 1;
|
|
}
|
|
$num_rows = ceil(count($birds) / $num_cols);
|
|
|
|
for ($row = 0; $row < $num_rows; $row++) {
|
|
echo "<tr>";
|
|
|
|
for ($col = 0; $col < $num_cols; $col++) {
|
|
$index = $row + $col * $num_rows;
|
|
|
|
if ($index < count($birds)) {
|
|
?>
|
|
<td class="spec">
|
|
<button type="submit" name="species" value="<?php echo $birds[$index];?>"><?php echo $birds[$index];?></button>
|
|
</td>
|
|
<?php
|
|
} else {
|
|
echo "<td></td>";
|
|
}
|
|
}
|
|
|
|
echo "</tr>";
|
|
}
|
|
} elseif($view == "date") {
|
|
$birds = array();
|
|
while($results=$result->fetchArray(SQLITE3_ASSOC))
|
|
{
|
|
$name = $results['Com_Name'];
|
|
$dir_name = str_replace("'", '', $name);
|
|
if(realpath($home."/BirdSongs/Extracted/By_Date/".$date."/".str_replace(" ", "_", $dir_name)) !== false){
|
|
$birds[] = $name;
|
|
}
|
|
}
|
|
|
|
if(count($birds) > 45) {
|
|
$num_cols = 3;
|
|
} else {
|
|
$num_cols = 1;
|
|
}
|
|
$num_rows = ceil(count($birds) / $num_cols);
|
|
|
|
for ($row = 0; $row < $num_rows; $row++) {
|
|
echo "<tr>";
|
|
|
|
for ($col = 0; $col < $num_cols; $col++) {
|
|
$index = $row + $col * $num_rows;
|
|
|
|
if ($index < count($birds)) {
|
|
?>
|
|
<td class="spec">
|
|
<button type="submit" name="species" value="<?php echo $birds[$index];?>"><?php echo $birds[$index];?></button>
|
|
</td>
|
|
<?php
|
|
} else {
|
|
echo "<td></td>";
|
|
}
|
|
}
|
|
|
|
echo "</tr>";
|
|
}
|
|
|
|
#Choose
|
|
} else {
|
|
echo "<td>
|
|
<button action=\"submit\" name=\"byspecies\" value=\"byspecies\">By Species</button></td></tr>
|
|
<tr><td><button action=\"submit\" name=\"bydate\" value=\"bydate\">By Date</button></td>";
|
|
}
|
|
|
|
echo "</table></form>";
|
|
}
|
|
|
|
#Specific Species
|
|
if(isset($_GET['species'])){ ?>
|
|
<div style="width: auto;
|
|
text-align: center">
|
|
<form action="views.php" method="GET">
|
|
<input type="hidden" name="view" value="Recordings">
|
|
<input type="hidden" name="species" value="<?php echo $_GET['species']; ?>">
|
|
<input type="hidden" name="sort" value="<?php echo $_GET['sort']; ?>">
|
|
<button <?php if(!isset($_GET['sort']) || $_GET['sort'] == "" || $_GET['sort'] == "date"){ echo "style='background:#9fe29b !important;'"; }?> class="sortbutton" type="submit" name="sort" value="date">
|
|
<img width=35px src="images/sort_date.svg" title="Sort by date" alt="Sort by date">
|
|
</button>
|
|
<button <?php if(isset($_GET['sort']) && $_GET['sort'] == "confidence"){ echo "style='background:#9fe29b !important;'"; }?> class="sortbutton" type="submit" name="sort" value="confidence">
|
|
<img src="images/sort_occ.svg" title="Sort by confidence" alt="Sort by confidence">
|
|
</button><br>
|
|
<input style="margin-top:10px" <?php if(isset($_GET['only_excluded'])){ echo "checked"; }?> type="checkbox" name="only_excluded" onChange="submit()">
|
|
<label for="onlyverified">Only Show Purge Excluded</label>
|
|
</form>
|
|
</div>
|
|
<?php
|
|
// add disk_check_exclude.txt lines into an array for grepping
|
|
$fp = @fopen($home."/BirdNET-Pi/scripts/disk_check_exclude.txt", 'r');
|
|
if ($fp) {
|
|
$disk_check_exclude_arr = explode("\n", fread($fp, filesize($home."/BirdNET-Pi/scripts/disk_check_exclude.txt")));
|
|
} else {
|
|
$disk_check_exclude_arr = [];
|
|
}
|
|
|
|
$name = htmlspecialchars_decode($_GET['species'], ENT_QUOTES);
|
|
if(isset($_SESSION['date'])) {
|
|
$date = $_SESSION['date'];
|
|
if(isset($_GET['sort']) && $_GET['sort'] == "confidence") {
|
|
$statement2 = $db->prepare("SELECT * FROM detections where Com_Name == \"$name\" AND Date == \"$date\" ORDER BY Confidence DESC");
|
|
} else {
|
|
$statement2 = $db->prepare("SELECT * FROM detections where Com_Name == \"$name\" AND Date == \"$date\" ORDER BY Time DESC");
|
|
}
|
|
} else {
|
|
if(isset($_GET['sort']) && $_GET['sort'] == "confidence") {
|
|
$statement2 = $db->prepare("SELECT * FROM detections where Com_Name == \"$name\" ORDER BY Confidence DESC");
|
|
} else {
|
|
$statement2 = $db->prepare("SELECT * FROM detections where Com_Name == \"$name\" ORDER BY Date DESC, Time DESC");
|
|
}
|
|
}
|
|
ensure_db_ok($statement2);
|
|
$result2 = $statement2->execute();
|
|
$num_rows = 0;
|
|
while ($result2->fetchArray(SQLITE3_ASSOC)) {
|
|
$num_rows++;
|
|
}
|
|
$result2->reset(); // reset the pointer to the beginning of the result set
|
|
echo "<table>
|
|
<tr>
|
|
<th>$name</th>
|
|
</tr>";
|
|
$iter=0;
|
|
while($results=$result2->fetchArray(SQLITE3_ASSOC))
|
|
{
|
|
$comname = preg_replace('/ /', '_', $results['Com_Name']);
|
|
$comname = preg_replace('/\'/', '', $comname);
|
|
$date = $results['Date'];
|
|
$filename = "/By_Date/".$date."/".$comname."/".$results['File_Name'];
|
|
$filename_shifted = "/By_Date/shifted/".$date."/".$comname."/".$results['File_Name'];
|
|
$filename_png = $filename . ".png";
|
|
$sciname = preg_replace('/ /', '_', $results['Sci_Name']);
|
|
$sci_name = $results['Sci_Name'];
|
|
$time = $results['Time'];
|
|
$confidence = round((float)round($results['Confidence'],2) * 100 ) . '%';
|
|
$filename_formatted = $date."/".$comname."/".$results['File_Name'];
|
|
|
|
// file was deleted by disk check, no need to show the detection in recordings
|
|
if(!file_exists($home."/BirdSongs/Extracted/".$filename)) {
|
|
continue;
|
|
}
|
|
if(!in_array($filename_formatted, $disk_check_exclude_arr) && isset($_GET['only_excluded'])) {
|
|
continue;
|
|
}
|
|
$iter++;
|
|
|
|
if($num_rows < 100){
|
|
$imageelem = "<video onplay='setLiveStreamVolume(0)' onended='setLiveStreamVolume(1)' onpause='setLiveStreamVolume(1)' controls poster=\"$filename_png\" preload=\"none\" title=\"$filename\"><source src=\"$filename\"></video>";
|
|
} else {
|
|
$imageelem = "<a href=\"$filename\"><img src=\"$filename_png\"></a>";
|
|
}
|
|
|
|
if($config["FULL_DISK"] == "purge") {
|
|
if(!in_array($filename_formatted, $disk_check_exclude_arr)) {
|
|
$imageicon = "images/unlock.svg";
|
|
$title = "This file will be deleted when disk space needs to be freed (>95% usage).";
|
|
$type = "add";
|
|
} else {
|
|
$imageicon = "images/lock.svg";
|
|
$title = "This file is excluded from being purged.";
|
|
$type = "del";
|
|
}
|
|
|
|
if(file_exists($shifted_path.$filename_formatted)) {
|
|
$shiftImageIcon = "images/unshift.svg";
|
|
$shiftTitle = "This file has been shifted down in frequency.";
|
|
$shiftAction = "unshift";
|
|
$filename = $filename_shifted;
|
|
} else {
|
|
$shiftImageIcon = "images/shift.svg";
|
|
$shiftTitle = "This file is not shifted in frequency.";
|
|
$shiftAction = "shift";
|
|
}
|
|
|
|
echo "<tr>
|
|
<td class=\"relative\">
|
|
|
|
<img style='cursor:pointer;right:120px' src='images/delete.svg' onclick='deleteDetection(\"".$filename_formatted."\")' class=\"copyimage\" width=25 title='Delete Detection'>
|
|
<img style='cursor:pointer;right:85px' src='images/bird.svg' onclick='changeDetection(\"".$filename_formatted."\")' class=\"copyimage\" width=25 title='Change Detection'>
|
|
<img style='cursor:pointer;right:45px' onclick='toggleLock(\"".$filename_formatted."\",\"".$type."\", this)' class=\"copyimage\" width=25 title=\"".$title."\" src=\"".$imageicon."\">
|
|
<img style='cursor:pointer' onclick='toggleShiftFreq(\"".$filename_formatted."\",\"".$shiftAction."\", this)' class=\"copyimage\" width=25 title=\"".$shiftTitle."\" src=\"".$shiftImageIcon."\"> $date $time<br>$confidence<br>
|
|
|
|
".$imageelem."
|
|
</td>
|
|
</tr>";
|
|
} else {
|
|
echo "<tr>
|
|
<td class=\"relative\">$date $time<br>$confidence
|
|
<img style='cursor:pointer' src='images/delete.svg' onclick='deleteDetection(\"".$filename_formatted."\")' class=\"copyimage\" width=25 title='Delete Detection'><br>
|
|
".$imageelem."
|
|
</td>
|
|
</tr>";
|
|
}
|
|
|
|
}if($iter == 0){ echo "<tr><td><b>No recordings were found.</b><br><br><span style='font-size:medium'>They may have been deleted to make space for new recordings. You can prevent this from happening in the future by clicking the <img src='images/unlock.svg' style='width:20px'> icon in the top right of a recording.<br>You can also modify this behavior globally under \"Full Disk Behavior\" <a href='views.php?view=Advanced'>here.</a></span></td></tr>";}echo "</table>";}
|
|
|
|
if(isset($_GET['filename'])){
|
|
$name = $_GET['filename'];
|
|
$statement2 = $db->prepare("SELECT * FROM detections where File_name == \"$name\" ORDER BY Date DESC, Time DESC");
|
|
ensure_db_ok($statement2);
|
|
$result2 = $statement2->execute();
|
|
echo "<table>
|
|
<tr>
|
|
<th>$name</th>
|
|
</tr>";
|
|
while($results=$result2->fetchArray(SQLITE3_ASSOC))
|
|
{
|
|
$comname = preg_replace('/ /', '_', $results['Com_Name']);
|
|
$comname = preg_replace('/\'/', '', $comname);
|
|
$date = $results['Date'];
|
|
$filename = "/By_Date/".$date."/".$comname."/".$results['File_Name'];
|
|
$filename_shifted = "/By_Date/shifted/".$date."/".$comname."/".$results['File_Name'];
|
|
$filename_png = $filename . ".png";
|
|
$sciname = preg_replace('/ /', '_', $results['Sci_Name']);
|
|
$sci_name = $results['Sci_Name'];
|
|
$time = $results['Time'];
|
|
$confidence = round((float)round($results['Confidence'],2) * 100 ) . '%';
|
|
$filename_formatted = $date."/".$comname."/".$results['File_Name'];
|
|
|
|
// add disk_check_exclude.txt lines into an array for grepping
|
|
$fp = @fopen($home."/BirdNET-Pi/scripts/disk_check_exclude.txt", 'r');
|
|
if ($fp) {
|
|
$disk_check_exclude_arr = explode("\n", fread($fp, filesize($home."/BirdNET-Pi/scripts/disk_check_exclude.txt")));
|
|
} else {
|
|
$disk_check_exclude_arr = [];
|
|
}
|
|
|
|
if($config["FULL_DISK"] == "purge") {
|
|
if(!in_array($filename_formatted, $disk_check_exclude_arr)) {
|
|
$imageicon = "images/unlock.svg";
|
|
$title = "This file will be deleted when disk space needs to be freed (>95% usage).";
|
|
$type = "add";
|
|
} else {
|
|
$imageicon = "images/lock.svg";
|
|
$title = "This file is excluded from being purged.";
|
|
$type = "del";
|
|
}
|
|
|
|
if(file_exists($shifted_path.$filename_formatted)) {
|
|
$shiftImageIcon = "images/unshift.svg";
|
|
$shiftTitle = "This file has been shifted down in frequency.";
|
|
$shiftAction = "unshift";
|
|
$filename = $filename_shifted;
|
|
} else {
|
|
$shiftImageIcon = "images/shift.svg";
|
|
$shiftTitle = "This file is not shifted in frequency.";
|
|
$shiftAction = "shift";
|
|
}
|
|
|
|
echo "<tr>
|
|
<td class=\"relative\">
|
|
|
|
<img style='cursor:pointer;right:120px' src='images/delete.svg' onclick='deleteDetection(\"".$filename_formatted."\", true)' class=\"copyimage\" width=25 title='Delete Detection'>
|
|
<img style='cursor:pointer;right:85px' src='images/bird.svg' onclick='changeDetection(\"".$filename_formatted."\")' class=\"copyimage\" width=25 title='Change Detection'>
|
|
<img style='cursor:pointer;right:45px' onclick='toggleLock(\"".$filename_formatted."\",\"".$type."\", this)' class=\"copyimage\" width=25 title=\"".$title."\" src=\"".$imageicon."\">
|
|
<img style='cursor:pointer' onclick='toggleShiftFreq(\"".$filename_formatted."\",\"".$shiftAction."\", this)' class=\"copyimage\" width=25 title=\"".$shiftTitle."\" src=\"".$shiftImageIcon."\">$date $time<br>$confidence<br>
|
|
|
|
<video onplay='setLiveStreamVolume(0)' onended='setLiveStreamVolume(1)' onpause='setLiveStreamVolume(1)' controls poster=\"$filename_png\" preload=\"none\" title=\"$filename\"><source src=\"$filename\"></video></td>
|
|
</tr>";
|
|
} else {
|
|
echo "<tr>
|
|
<td class=\"relative\">$date $time<br>$confidence
|
|
<img style='cursor:pointer' src='images/delete.svg' onclick='deleteDetection(\"".$filename_formatted."\", true)' class=\"copyimage\" width=25 title='Delete Detection'><br>
|
|
<video onplay='setLiveStreamVolume(0)' onended='setLiveStreamVolume(1)' onpause='setLiveStreamVolume(1)' controls poster=\"$filename_png\" preload=\"none\" title=\"$filename\"><source src=\"$filename\"></video></td>
|
|
</tr>";
|
|
}
|
|
|
|
}echo "</table>";}
|
|
echo "</div>";
|
|
if (get_included_files()[0] === __FILE__) {
|
|
echo '</html>';
|
|
}
|