Source code for stalker.models.message

# -*- coding: utf-8 -*-
# Stalker a Production Asset Management System
# Copyright (C) 2009-2017 Erkan Ozgur Yilmaz
#
# This file is part of Stalker.
#
# Stalker is free software: you can redistribute it and/or modify
# it under the terms of the Lesser GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License.
#
# Stalker 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
# Lesser GNU General Public License for more details.
#
# You should have received a copy of the Lesser GNU General Public License
# along with Stalker.  If not, see <http://www.gnu.org/licenses/>

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:`.User` object sending the message. :param to: the list of :class:`.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:`.Message` object which this message is a reply to. :param replies: the list of :class:`.Message` objects which are the direct replies of this message :param attachments: a list of :class:`.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) def __init__(self, **kwargs): super(Message, self).__init__(**kwargs) StatusMixin.__init__(self, **kwargs)