blob: aa32dc10c09e3e78d35dbe061fc3e9b4df84063a [file] [log] [blame]
#!/usr/bin/env 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.
"""This module contains the GSoC Comment Model."""
from google.appengine.ext import db
from django.utils.translation import ugettext
import soc.models.profile
class GSoCComment(db.Model):
"""Model of a comment on a work.
A comment is usually associated with a Work or a Proposal,
for example a Document or a Student Proposal, and with a user, the author.
There are two types of comment, public (i.e. visible to the student),
or private (i.e. visible to programme/club staff). Neither type are
visible to people who are not connected to the work being commented on.
Parent:
soc.modules.gsoc.models.proposal.Proposal
"""
#: A required many:1 relationship with a comment entity indicating
#: the user who provided that comment.
author = db.ReferenceProperty(reference_class=soc.models.profile.Profile,
required=True, collection_name="commented")
#: The rich textual content of this comment
content = db.TextProperty(verbose_name='')
#: Indicated if the comment should be visible to the appropriate student
is_private = db.BooleanProperty(default=True,
verbose_name=ugettext('Private'))
is_private.help_text = ugettext(
'Whether this comment will only be seen by admins and mentors')
#: Date when the comment was added
created = db.DateTimeProperty(auto_now_add=True)