##// END OF EJS Templates
integrations: refactor/cleanup + features, fixes #4181...
integrations: refactor/cleanup + features, fixes #4181 * added scopes on integrations, scopes are: - repo only - repogroup children only - root repos only - global (any repo) * integrations schemas now have separate section for the settings (eg. slack) and options (eg. scope/enabled) * added descriptions to integration types * added icons to integration types * added 'create new' integration page * added scope of integration to integrations list * added breadcrumbs for each repo/repogroup/global integrations pages * added sorting to integrations list * added pagination to integrations list * added icons to integrations list * added type filter to integrations list * added message to integrations list if none we found * added extra permissions check on integrations views * db migration from 56 => 57 - adds child_repos_only field * added tests for integrations triggered on events * added tests for integrations schemas * added tests for integrations views for repo/repogroup/admin

File last commit:

r566:884904c0 default
r731:7a6d3636 default
Show More
repo_group.py
80 lines | 2.7 KiB | text/x-python | PythonLexer
# Copyright (C) 2016-2016 RhodeCode GmbH
#
# 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
from rhodecode.events.base import RhodecodeEvent
log = logging.getLogger(__name__)
class RepoGroupEvent(RhodecodeEvent):
"""
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
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
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')