##// END OF EJS Templates
implements #330 api method for listing nodes at particular revision...
implements #330 api method for listing nodes at particular revision - improved filtering by files in file list

File last commit:

r1789:17caf4ef beta
r1810:203af055 beta
Show More
comment.py
143 lines | 5.1 KiB | text/x-python | PythonLexer
#77 code review...
r1670 # -*- coding: utf-8 -*-
"""
rhodecode.model.comment
~~~~~~~~~~~~~~~~~~~~~~~
comments model for RhodeCode
implements #308 rewrote diffs to enable displaying full diff on each file...
r1789
#77 code review...
r1670 :created_on: Nov 11, 2011
:author: marcink
:copyright: (C) 2009-2011 Marcin Kuzminski <marcin@python-works.com>
:license: GPLv3, see COPYING for more details.
"""
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
import logging
import traceback
Notification system improvements...
r1712 from pylons.i18n.translation import _
from sqlalchemy.util.compat import defaultdict
Tests updates, Session refactoring
r1713 from rhodecode.lib import extract_mentioned_users
Notification system improvements...
r1712 from rhodecode.lib import helpers as h
#77 code review...
r1670 from rhodecode.model import BaseModel
Notification system improvements...
r1712 from rhodecode.model.db import ChangesetComment, User, Repository, Notification
notification fixes and improvements
r1703 from rhodecode.model.notification import NotificationModel
#77 code review...
r1670
log = logging.getLogger(__name__)
class ChangesetCommentsModel(BaseModel):
Tests updates, Session refactoring
r1713 def __get_changeset_comment(self, changeset_comment):
notification to commit author + gardening
r1716 return self._get_instance(ChangesetComment, changeset_comment)
#77 code review...
r1670
Notification system improvements...
r1712 def _extract_mentions(self, s):
Tests updates, Session refactoring
r1713 user_objects = []
for username in extract_mentioned_users(s):
Notification system improvements...
r1712 user_obj = User.get_by_username(username, case_insensitive=True)
if user_obj:
Tests updates, Session refactoring
r1713 user_objects.append(user_obj)
return user_objects
Notification system improvements...
r1712
code refactoring
r1675 def create(self, text, repo_id, user_id, revision, f_path=None,
#77 code review...
r1670 line_no=None):
"""
Creates new comment for changeset
implements #308 rewrote diffs to enable displaying full diff on each file...
r1789
#77 code review...
r1670 :param text:
:param repo_id:
:param user_id:
code refactoring
r1675 :param revision:
#77 code review...
r1670 :param f_path:
:param line_no:
"""
#71 code-review...
r1677 if text:
Notification system improvements...
r1712 repo = Repository.get(repo_id)
notification to commit author + gardening
r1716 cs = repo.scm_instance.get_changeset(revision)
desc = cs.message
author = cs.author_email
#71 code-review...
r1677 comment = ChangesetComment()
Notification system improvements...
r1712 comment.repo = repo
#71 code-review...
r1677 comment.user_id = user_id
comment.revision = revision
comment.text = text
comment.f_path = f_path
comment.line_no = line_no
#77 code review...
r1670
#71 code-review...
r1677 self.sa.add(comment)
Notification system improvements...
r1712 self.sa.flush()
notification fixes and improvements
r1703
# make notification
Notification system improvements...
r1712 line = ''
if line_no:
line = _('on line %s') % line_no
subj = h.link_to('Re commit: %(commit_desc)s %(line)s' % \
implements #308 rewrote diffs to enable displaying full diff on each file...
r1789 {'commit_desc': desc, 'line': line},
Notification system improvements...
r1712 h.url('changeset_home', repo_name=repo.repo_name,
Tests updates, Session refactoring
r1713 revision=revision,
Notification fixes...
r1717 anchor='comment-%s' % comment.comment_id,
qualified=True,
Notification system improvements...
r1712 )
)
notification fixes and improvements
r1703 body = text
recipients = ChangesetComment.get_users(revision=revision)
notification to commit author + gardening
r1716 # add changeset author
recipients += [User.get_by_email(author)]
notification fixes and improvements
r1703 NotificationModel().create(created_by=user_id, subject=subj,
Tests updates, Session refactoring
r1713 body=body, recipients=recipients,
type_=Notification.TYPE_CHANGESET_COMMENT)
notification fixes and improvements
r1703
Notification fixes...
r1717 mention_recipients = set(self._extract_mentions(body))\
.difference(recipients)
notification to commit author + gardening
r1716 if mention_recipients:
subj = _('[Mention]') + ' ' + subj
NotificationModel().create(created_by=user_id, subject=subj,
Notification fixes...
r1717 body=body,
recipients=mention_recipients,
notification to commit author + gardening
r1716 type_=Notification.TYPE_CHANGESET_COMMENT)
#71 code-review...
r1677 return comment
#77 code review...
r1670
Tests updates, Session refactoring
r1713 def delete(self, comment):
#77 code review...
r1670 """
Deletes given comment
implements #308 rewrote diffs to enable displaying full diff on each file...
r1789
#77 code review...
r1670 :param comment_id:
"""
Tests updates, Session refactoring
r1713 comment = self.__get_changeset_comment(comment)
#77 code review...
r1670 self.sa.delete(comment)
Tests updates, Session refactoring
r1713
#77 code review...
r1670 return comment
code refactoring
r1675
def get_comments(self, repo_id, revision):
return ChangesetComment.query()\
.filter(ChangesetComment.repo_id == repo_id)\
.filter(ChangesetComment.revision == revision)\
.filter(ChangesetComment.line_no == None)\
.filter(ChangesetComment.f_path == None).all()
#71 code-review...
r1677 def get_inline_comments(self, repo_id, revision):
code refactoring
r1675 comments = self.sa.query(ChangesetComment)\
.filter(ChangesetComment.repo_id == repo_id)\
fixes inline comments double entries
r1681 .filter(ChangesetComment.revision == revision)\
.filter(ChangesetComment.line_no != None)\
.filter(ChangesetComment.f_path != None).all()
#71 code-review...
r1677
implements #308 rewrote diffs to enable displaying full diff on each file...
r1789 paths = defaultdict(lambda: defaultdict(list))
code refactoring
r1675
for co in comments:
#71 code-review...
r1677 paths[co.f_path][co.line_no].append(co)
return paths.items()