# -*- coding: utf-8 -*- # Copyright (C) 2016-2017 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 pyramid.httpexceptions import HTTPNotFound from pyramid.view import view_config from rhodecode.apps._base import BaseAppView from rhodecode.model.db import joinedload, UserLog from rhodecode.lib.user_log_filter import user_log_filter from rhodecode.lib.auth import LoginRequired, HasPermissionAllDecorator from rhodecode.lib.utils2 import safe_int from rhodecode.lib.helpers import Page log = logging.getLogger(__name__) class AdminAuditLogsView(BaseAppView): def load_default_context(self): c = self._get_local_tmpl_context() self._register_global_c(c) return c @LoginRequired() @HasPermissionAllDecorator('hg.admin') @view_config( route_name='admin_audit_logs', request_method='GET', renderer='rhodecode:templates/admin/admin_audit_logs.mako') def admin_audit_logs(self): c = self.load_default_context() users_log = UserLog.query()\ .options(joinedload(UserLog.user))\ .options(joinedload(UserLog.repository)) # FILTERING c.search_term = self.request.GET.get('filter') try: users_log = user_log_filter(users_log, c.search_term) except Exception: # we want this to crash for now raise users_log = users_log.order_by(UserLog.action_date.desc()) p = safe_int(self.request.GET.get('page', 1), 1) def url_generator(**kw): if c.search_term: kw['filter'] = c.search_term return self.request.current_route_path(_query=kw) c.audit_logs = Page(users_log, page=p, items_per_page=10, url=url_generator) return self._get_template_context(c) @LoginRequired() @HasPermissionAllDecorator('hg.admin') @view_config( route_name='admin_audit_log_entry', request_method='GET', renderer='rhodecode:templates/admin/admin_audit_log_entry.mako') def admin_audit_log_entry(self): c = self.load_default_context() audit_log_id = self.request.matchdict['audit_log_id'] c.audit_log_entry = UserLog.query()\ .options(joinedload(UserLog.user))\ .options(joinedload(UserLog.repository))\ .filter(UserLog.user_log_id == audit_log_id).scalar() if not c.audit_log_entry: raise HTTPNotFound() return self._get_template_context(c)