Source code for stalker.models.message
# -*- coding: utf-8 -*-
# Stalker a Production Asset Management System
# Copyright (C) 2009-2013 Erkan Ozgur Yilmaz
#
# This file is part of Stalker.
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation;
# version 2.1 of the License.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with this library; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
from sqlalchemy import Column, Integer, ForeignKey
from stalker.models.entity import Entity
from stalker.models.mixins import StatusMixin
from stalker.log import logging_level
import logging
logger = logging.getLogger(__name__)
logger.setLevel(logging_level)
[docs]class Message(Entity, StatusMixin):
"""The base of the messaging system in Stalker
Messages are one of the ways to collaborate in Stalker. The model of the
messages is taken from the e-mail system. So it is pretty similar to an
e-mail message.
:param from: the :class:`~stalker.models.user.User` object sending the
message
:param to: the list of :class:`~stalker.models.user.User`\ s to
receive this message
:param subject: the subject of the message
:param body: the body of the message
:param in_reply_to: the :class:`~stalker.models.message.Message`
object which this message is a reply to.
:param replies: the list of :class:`~stalker.models.message.Message`
objects which are the direct replies of this message
:param attachments: a list of
:class:`~stalker.models.entity.SimpleEntity` objects attached to
this message (so anything can be attached to a message)
"""
__auto_name__ = True
__tablename__ = "Messages"
__mapper_args__ = {"polymorphic_identity": "Message"}
message_id = Column("id", Integer, ForeignKey("Entities.id"),
primary_key=True)
[docs] def __init__(self, **kwargs):
super(Message, self).__init__(**kwargs)