##// END OF EJS Templates
- fixed issue with mark all read button for notifications and listeners on delete buttons...
- fixed issue with mark all read button for notifications and listeners on delete buttons - hide mark all read if notification inbox is empty

File last commit:

r1791:2aee0dc1 beta
r1817:523b1011 beta
Show More
notifications.py
115 lines | 4.5 KiB | text/x-python | PythonLexer
Notification system improvements...
r1712 import logging
Tests updates, Session refactoring
r1713 import traceback
Notification system improvements...
r1712
mark all read button for notifications
r1791 from pylons import request
Tests updates, Session refactoring
r1713 from pylons import tmpl_context as c, url
- refactoring to overcome poor usage of global pylons config...
r1723 from pylons.controllers.util import redirect
Notification system improvements...
r1712
from rhodecode.lib.base import BaseController, render
from rhodecode.model.db import Notification
from rhodecode.model.notification import NotificationModel
forbid notifications view for anonymous users
r1739 from rhodecode.lib.auth import LoginRequired, NotAnonymous
Notification system improvements...
r1712 from rhodecode.lib import helpers as h
Tests updates, Session refactoring
r1713 from rhodecode.model.meta import Session
- refactoring to overcome poor usage of global pylons config...
r1723
Notification system improvements...
r1712
log = logging.getLogger(__name__)
mark all read button for notifications
r1791
Notification system improvements...
r1712 class NotificationsController(BaseController):
"""REST Controller styled on the Atom Publishing Protocol"""
# To properly map this controller, ensure your config/routing.py
# file has a resource setup:
# map.resource('notification', 'notifications', controller='_admin/notifications',
# path_prefix='/_admin', name_prefix='_admin_')
@LoginRequired()
forbid notifications view for anonymous users
r1739 @NotAnonymous()
Notification system improvements...
r1712 def __before__(self):
super(NotificationsController, self).__before__()
def index(self, format='html'):
"""GET /_admin/notifications: All items in the collection"""
# url('notifications')
c.user = self.rhodecode_user
c.notifications = NotificationModel()\
.get_for_user(self.rhodecode_user.user_id)
return render('admin/notifications/notifications.html')
mark all read button for notifications
r1791 def mark_all_read(self):
if request.environ.get('HTTP_X_PARTIAL_XHR'):
nm = NotificationModel()
# mark all read
nm.mark_all_read_for_user(self.rhodecode_user.user_id)
Session.commit()
c.user = self.rhodecode_user
c.notifications = nm.get_for_user(self.rhodecode_user.user_id)
return render('admin/notifications/notifications_data.html')
Notification system improvements...
r1712 def create(self):
"""POST /_admin/notifications: Create a new item"""
# url('notifications')
def new(self, format='html'):
"""GET /_admin/notifications/new: Form to create a new item"""
# url('new_notification')
def update(self, notification_id):
"""PUT /_admin/notifications/id: Update an existing item"""
# Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="PUT" />
# Or using helpers:
# h.form(url('notification', notification_id=ID),
# method='put')
# url('notification', notification_id=ID)
def delete(self, notification_id):
"""DELETE /_admin/notifications/id: Delete an existing item"""
# Forms posted to this method should contain a hidden field:
# <input type="hidden" name="_method" value="DELETE" />
# Or using helpers:
# h.form(url('notification', notification_id=ID),
# method='delete')
# url('notification', notification_id=ID)
Tests updates, Session refactoring
r1713 try:
no = Notification.get(notification_id)
owner = lambda: (no.notifications_to_users.user.user_id
== c.rhodecode_user.user_id)
if h.HasPermissionAny('hg.admin', 'repository.admin')() or owner:
NotificationModel().delete(c.rhodecode_user.user_id, no)
Session.commit()
return 'ok'
except Exception:
Session.rollback()
log.error(traceback.format_exc())
Notification system improvements...
r1712 return 'fail'
def show(self, notification_id, format='html'):
"""GET /_admin/notifications/id: Show a specific item"""
# url('notification', notification_id=ID)
c.user = self.rhodecode_user
Tests updates, Session refactoring
r1713 no = Notification.get(notification_id)
owner = lambda: (no.notifications_to_users.user.user_id
== c.user.user_id)
if no and (h.HasPermissionAny('hg.admin', 'repository.admin')() or owner):
unotification = NotificationModel()\
.get_user_notification(c.user.user_id, no)
Notification system improvements...
r1712
Tests updates, Session refactoring
r1713 # if this association to user is not valid, we don't want to show
# this message
if unotification:
if unotification.read is False:
unotification.mark_as_read()
Session.commit()
c.notification = no
Notification system improvements...
r1712
Tests updates, Session refactoring
r1713 return render('admin/notifications/show_notification.html')
Notification system improvements...
r1712
Tests updates, Session refactoring
r1713 return redirect(url('notifications'))
Notification system improvements...
r1712
def edit(self, notification_id, format='html'):
"""GET /_admin/notifications/id/edit: Form to edit an existing item"""
# url('edit_notification', notification_id=ID)