diff options
Diffstat (limited to 'mod/notifications.php')
-rw-r--r-- | mod/notifications.php | 98 |
1 files changed, 98 insertions, 0 deletions
diff --git a/mod/notifications.php b/mod/notifications.php new file mode 100644 index 000000000..1064729ff --- /dev/null +++ b/mod/notifications.php @@ -0,0 +1,98 @@ +<?php + +function notifications_post(&$a) { + + if((! x($_SESSION,'authenticated')) || (! (x($_SESSION,'uid')))) { + goaway($a->get_baseurl()); + } + + $request_id = (($a->argc > 1) ? $a->argv[0] : 0); + + if($request_id == "all") + return; + + if($request_id) { + + $r = q("SELECT `id` FROM `intro` + WHERE `request-id` = %d + AND `uid` = %d LIMIT 1", + intval($request_id), + intval($_SESSION['uid']) + ); + + if(count($r)) { + $intro_id = $r[0]['id']; + } + else { + $_SESSION['sysmsg'] .= "Invalid request identifier." . EOL; + return; + } + if($_POST['submit'] == 'Discard') { + $r = q("DELETE `intro` WHERE `id` = %d LIMIT 1", intval($intro_id)); + $r = q("DELETE `contact` WHERE `id` = %d AND `uid` = %d LIMIT 1", + intval($request_id), + intval($_SESSION['uid'])); + return; + } + if($_POST['submit'] == 'Ignore') { + $r = q("UPDATE `intro` SET `ignore` = 1 WHERE `id` = %d LIMIT 1", + intval($intro_id)); + return; + } + } +} + + + + + +function notifications_content(&$a) { + + $o = ''; + + if((! x($_SESSION,'authenticated')) || (! (x($_SESSION,'uid')))) { + goaway($a->get_baseurl()); + } + + if(($a->argc > 1) && ($a->argv[1] == 'all')) + $sql_extra = ''; + else + $sql_extra = " AND `ignore` = 0 "; + + + $tpl = file_get_contents('view/intros-top.tpl'); + $o .= replace_macros($tpl,array( + '$hide_url' => ((strlen($sql_extra)) ? 'notifications/all' : 'notifications' ), + '$hide_text' => ((strlen($sql_extra)) ? 'Show Ignored Requests' : 'Hide Ignored Requests') + )); +dbg(2); + $r = q("SELECT `intro`.`id` AS `intro-id`, `intro`.*, `contact`.* + FROM `intro` LEFT JOIN `contact` ON `intro`.`contact-id` = `contact`.`id` + WHERE `intro`.`uid` = %d $sql_extra AND `intro`.`blocked` = 0 ", + intval($_SESSION['uid'])); +dbg(0); + if(($r !== false) && (count($r))) { + + + $tpl = file_get_contents("view/intros.tpl"); + + foreach($r as $rr) { + + $o .= replace_macros($tpl,array( + '$intro_id' => $rr['intro-id'], + '$dfrn-id' => $rr['issued-id'], + '$uid' => $_SESSION['uid'], + '$contact-id' => $rr['contact-id'], + '$photo' => ((x($rr,'photo')) ? $rr['photo'] : "images/default-profile.jpg"), + '$fullname' => $rr['name'], + '$knowyou' => (($rr['knowyou']) ? 'yes' : 'no'), + '$url' => $rr['url'], + '$note' => $rr['note'] + )); + } + } + else + $_SESSION['sysmsg'] .= "No notifications." . EOL; + + return $o; +}
\ No newline at end of file |