app/soc/logic/models/notification.py
author Sverre Rabbelier <srabbelier@gmail.com>
Tue, 27 Jan 2009 11:15:49 +0000
changeset 1009 7abbbfc79f3a
parent 997 d4ba019f1f8b
child 1106 e14b0995cf29
permissions -rw-r--r--
Added some very basic tests for the sidebar and access modules Also updated run.py to set the USER_EMAIL variable. Patch by: Sverre Rabbelier

#!/usr/bin/python2.5
#
# Copyright 2008 the Melange authors.
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

"""Notification (Model) query functions.
"""

__authors__ = [
  '"Lennard de Rijk" <ljvderijk@gmail.com>',
  ]


from google.appengine.ext import db

from soc.cache import sidebar
from soc.logic.helper import notifications
from soc.logic.models import base
from soc.logic.models import user as user_logic

import soc.models.notification


class Logic(base.Logic):
  """Logic methods for the Notification model.
  """

  def __init__(self):
    """Defines the name, key_name and model for this entity.
    """
    super(Logic, self).__init__(model=soc.models.notification.Notification,
         base_model=None, scope_logic=user_logic)

  def _onCreate(self, entity):
    """Sends out a message if there is only one unread notification.
    """

    # create a special query on which we can call count
    query = db.Query(self._model)
    query.filter('scope =', entity.scope)
    query.filter('unread = ', True)

    # count the number of results with a maximum of two
    unread_count = query.count(2)

    if unread_count == 1:
      # there is only one unread notification so send out an email
      notifications.sendNewNotificationMessage(entity)

    # flush the sidebar cache
    sidebar.flush(entity.scope.account)

  def _updateField(self, entity, name, value):
    """If unread changes we flush the sidebar cache.
    """

    if (name == 'unread') and (entity.unread != value):
      # in case that the unread value changes we flush the sidebar.
      sidebar.flush(entity.scope.account)

    return True


logic = Logic()