##// END OF EJS Templates
events: use a distinction between RhodeCodeEvent which is a base class and it used by all events, and...
events: use a distinction between RhodeCodeEvent which is a base class and it used by all events, and the events that are handled in addition by integration framework.

File last commit:

r2921:042146f6 default
r2921:042146f6 default
Show More
repo_group.py
80 lines | 2.7 KiB | text/x-python | PythonLexer
release: update copyright year to 2018
r2487 # Copyright (C) 2016-2018 RhodeCode GmbH
Martin Bornhold
events: Add events for repository groups....
r556 #
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License, version 3
# (only), as published by the Free Software Foundation.
#
# 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 Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# This program is dual-licensed. If you wish to learn more about the
# RhodeCode Enterprise Edition, including its added features, Support services,
# and proprietary license terms, please see https://rhodecode.com/licenses/
import logging
from rhodecode.translation import lazy_ugettext
events: use a distinction between RhodeCodeEvent which is a base class and it used by all events, and...
r2921 from rhodecode.events.base import RhodeCodeIntegrationEvent
Martin Bornhold
events: Add events for repository groups....
r556
Martin Bornhold
events: Implement the as_dict method for repository group events.
r565
Martin Bornhold
svn: Remove print statement and add __name__ to logger.
r566 log = logging.getLogger(__name__)
Martin Bornhold
events: Add events for repository groups....
r556
events: use a distinction between RhodeCodeEvent which is a base class and it used by all events, and...
r2921 class RepoGroupEvent(RhodeCodeIntegrationEvent):
Martin Bornhold
events: Add events for repository groups....
r556 """
Base class for events acting on a repository group.
:param repo: a :class:`RepositoryGroup` instance
"""
def __init__(self, repo_group):
super(RepoGroupEvent, self).__init__()
self.repo_group = repo_group
Martin Bornhold
events: Implement the as_dict method for repository group events.
r565 def as_dict(self):
data = super(RepoGroupEvent, self).as_dict()
data.update({
'repo_group': {
'group_id': self.repo_group.group_id,
'group_name': self.repo_group.group_name,
'group_parent_id': self.repo_group.group_parent_id,
'group_description': self.repo_group.group_description,
'user_id': self.repo_group.user_id,
'created_by': self.repo_group.user.username,
'created_on': self.repo_group.created_on,
'enable_locking': self.repo_group.enable_locking,
}
})
return data
Martin Bornhold
events: Add events for repository groups....
r556
class RepoGroupCreateEvent(RepoGroupEvent):
"""
An instance of this class is emitted as an :term:`event` whenever a
repository group is created.
"""
name = 'repo-group-create'
display_name = lazy_ugettext('repository group created')
class RepoGroupDeleteEvent(RepoGroupEvent):
"""
An instance of this class is emitted as an :term:`event` whenever a
repository group is deleted.
"""
name = 'repo-group-delete'
display_name = lazy_ugettext('repository group deleted')
class RepoGroupUpdateEvent(RepoGroupEvent):
"""
An instance of this class is emitted as an :term:`event` whenever a
repository group is updated.
"""
name = 'repo-group-update'
display_name = lazy_ugettext('repository group update')