MastodonHelp/web/mustard/notifsh.php

62 lines
2.8 KiB
PHP
Raw Normal View History

2020-04-16 22:56:12 +02:00
<?php
header('Content-Type: application/json; charset=utf-8');
require('include/glob.php');
2020-05-01 06:51:22 +02:00
require('include/muoribenejson.php');
2020-04-16 22:56:12 +02:00
require('include/sessionstart.php');
2020-05-01 06:51:22 +02:00
require('include/myconn.php');
require('include/getadmacc.php');
if ($account['Level']=='guest')
muoribene('Sorry, you are not authorized.',true);
2020-04-16 22:56:12 +02:00
if (array_key_exists('act', $_GET) && $_GET['act'] == 'markread' && array_key_exists('id', $_GET) && preg_match('/^[0-9]+$/', $_GET['id']) === 1) {
$_GET['id'] += 0;
mysqli_query($link, 'UPDATE Notifications SET Seen=1 WHERE ID=' . $_GET['id'])
or muoribene(mysqli_error($link), true);
$res = mysqli_query($link, 'SELECT ID FROM Notifications WHERE Seen=0')
or muoribene(mysqli_error($link), true);
echo('{"hmunseen":' . mysqli_num_rows($res) . '}' . N);
} elseif (array_key_exists('act', $_GET) && $_GET['act'] == 'delete' && array_key_exists('id', $_GET) && preg_match('/^[0-9]+$/', $_GET['id']) === 1) {
$_GET['id'] += 0;
mysqli_query($link, 'UPDATE Notifications SET Deleted=1 WHERE ID=' . $_GET['id'])
or muoribene(mysqli_error($link), true);
echo('{"deleted":' . true . '}' . N);
} elseif (array_key_exists('act', $_GET) && $_GET['act'] == 'loadchunk' && array_key_exists('chunk', $_GET) && preg_match('/^[0-9]+$/', $_GET['chunk']) === 1) {
$_GET['chunk'] += 0;
$chunksize = 20; // questo dev'essere uguale in include/notifs.php
$res = mysqli_query($link, 'SELECT * FROM Notifications WHERE Deleted=0 ORDER BY Microtime DESC LIMIT ' . ($_GET['chunk'] * $chunksize) . ',' . $chunksize)
or muoribene(mysqli_error($link), true);
$buf = array();
while ($row = mysqli_fetch_assoc($res)) {
($row['Seen'] == 0) ? $notifclass = 'notifunseen' : $notifclass = 'notifseen';
$buf[] = '<div id="notif-' . $row['ID'] . '" class="' . $notifclass . '" onclick="markread(this)">' . strftime('%d/%m/%y %T', $row['Microtime']) . ': ' . $row['Notification'] . '</div>';
2020-04-16 22:56:12 +02:00
}
echo(json_encode($buf));
} elseif (array_key_exists('act',$_GET) && $_GET['act']=='loadnew' && array_key_exists('lmt',$_GET) && preg_match('/^[0-9]+(\.[0-9]+)?$/',$_GET['lmt'])===1) {
$_GET['lmt']+=0;
$newlmt=$_GET['lmt'];
$newunread=false;
2020-05-20 10:04:56 +02:00
$res=mysqli_query($link,'SELECT * FROM Notifications WHERE Microtime > '.$_GET['lmt'].' AND Deleted = 0 ORDER BY Microtime DESC')
2020-04-16 22:56:12 +02:00
or muoribene(mysqli_error($link),true);
$buf=array();
while ($row=mysqli_fetch_assoc($res)) {
if ($row['Seen']==0) {
$notifclass='notifunseen';
$newunread=true;
} else {
$notifclass='notifseen';
}
$buf[]='<div id="notif-'.$row['ID'].'" class="'.$notifclass.'" onclick="markread(this)">'.strftime('%d/%m/%y %T',$row['Microtime']).': '.$row['Notification'].'</div>';
if ($row['Microtime']+0>$newlmt) $newlmt=$row['Microtime'];
}
$buf=array('newlmt'=>$newlmt,'newunread'=>$newunread,'buf'=>$buf);
echo(json_encode($buf));
}
2020-05-01 06:51:22 +02:00
mysqli_close($link);
2020-04-16 22:56:12 +02:00
exit(0);
?>