- require_once 'notifs.inc.php';
- $notifs = new Notifs($uid, true);
-
- $annivcat = false;
- foreach ($notifs->_cats as $cat) {
- if (preg_match('/anniv/i', $cat['short']))
- $annivcat = $cat['id'];
- }
-
- if ($annivcat !== false) {
- $annivs = array();
- foreach ($notifs->_data[$annivcat] as $promo) {
- foreach ($promo as $notif) {
- if ($all == 'all' || $notif['contact']) {
- $annivs[] = array(
- 'timestamp' => $notif['known'],
- 'date' => strtotime($notif['date']),
- 'tomorrow' => strtotime("+1 day", strtotime($notif['date'])),
- 'bestalias' => $notif['bestalias'],
- 'summary' => 'Anniversaire de '.$notif['prenom']
- .' '.$notif['nom'].' - x '.$notif['promo'],
- );
+ if (Env::has('flags_mail')) {
+ S::assert_xsrf_token();
+ XDB::execute('UPDATE watch
+ SET ' . XDB::changeFlag('flags', 'mail', Env::b('mail')) . '
+ WHERE uid = {?}', S::i('uid'));
+ }
+
+ $user = S::user();
+ $nonins = new UserFilter(new UFC_WatchRegistration($user));
+
+ $promo = XDB::fetchColumn('SELECT promo
+ FROM watch_promo
+ WHERE uid = {?}
+ ORDER BY promo', S::i('uid'));
+ $page->assign('promo_count', count($promo));
+ $ranges = array();
+ $range_start = null;
+ $range_end = null;
+ foreach ($promo as $p) {
+ if (is_null($range_start)) {
+ $range_start = $range_end = $p;
+ } else if ($p != $range_end + 1) {
+ $ranges[] = array($range_start, $range_end);
+ $range_start = $range_end = $p;
+ } else {
+ $range_end = $p;
+ }
+ }
+ $ranges[] = array($range_start, $range_end);
+ $page->assign('promo_ranges', $ranges);
+ $page->assign('nonins', $nonins->getUsers());
+
+ list($flags, $actions) = XDB::fetchOneRow('SELECT flags, actions
+ FROM watch
+ WHERE uid = {?}', S::i('uid'));
+ $flags = new PlFlagSet($flags);
+ $actions = new PlFlagSet($actions);
+ $page->assign('flags', $flags);
+ $page->assign('actions', $actions);
+ }
+
+ function handler_contacts(&$page, $action = null, $subaction = null, $ssaction = null)
+ {
+ $page->setTitle('Mes contacts');
+ $this->_add_rss_link($page);
+
+ $uid = S::v('uid');
+ $user = Env::v('user');
+
+ // For XSRF protection, checks both the normal xsrf token, and the special RSS token.
+ // It allows direct linking to contact adding in the RSS feed.
+ if (Env::v('action') && Env::v('token') !== S::v('token')) {
+ S::assert_xsrf_token();
+ }
+ switch (Env::v('action')) {
+ case 'retirer':
+ if (($user = User::get(Env::v('user')))) {
+ if (XDB::execute("DELETE FROM contacts
+ WHERE uid = {?} AND contact = {?}", $uid, $user->id())) {
+ $page->trigSuccess("Contact retiré !");
+ }
+ }
+ break;
+
+ case 'ajouter':
+ if (($user = User::get(Env::v('user')))) {
+ if (XDB::execute("REPLACE INTO contacts (uid, contact)
+ VALUES ({?}, {?})", $uid, $user->id())) {
+ $page->trigSuccess('Contact ajouté !');
+ } else {
+ $page->trigWarning('Contact déjà dans la liste !');