base.py
93 lines
| 2.7 KiB
| text/x-python
|
PythonLexer
r1271 | # Copyright (C) 2016-2017 RhodeCode GmbH | |||
r379 | # | |||
# 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/ | ||||
r1433 | import logging | |||
r379 | ||||
from datetime import datetime | ||||
from pyramid.threadlocal import get_current_request | ||||
from rhodecode.lib.utils2 import AttributeDict | ||||
r391 | # this is a user object to be used for events caused by the system (eg. shell) | |||
r379 | SYSTEM_USER = AttributeDict(dict( | |||
username='__SYSTEM__' | ||||
)) | ||||
r1433 | log = logging.getLogger(__name__) | |||
r379 | ||||
class RhodecodeEvent(object): | ||||
""" | ||||
Base event class for all Rhodecode events | ||||
""" | ||||
r649 | name = "RhodeCodeEvent" | |||
r379 | def __init__(self): | |||
self.request = get_current_request() | ||||
self.utc_timestamp = datetime.utcnow() | ||||
@property | ||||
r1431 | def auth_user(self): | |||
if not self.request: | ||||
return | ||||
user = getattr(self.request, 'user', None) | ||||
if user: | ||||
return user | ||||
api_user = getattr(self.request, 'rpc_user', None) | ||||
if api_user: | ||||
return api_user | ||||
@property | ||||
r389 | def actor(self): | |||
r1431 | auth_user = self.auth_user | |||
if auth_user: | ||||
return auth_user.get_instance() | ||||
r379 | return SYSTEM_USER | |||
@property | ||||
r389 | def actor_ip(self): | |||
r1431 | auth_user = self.auth_user | |||
if auth_user: | ||||
return auth_user.ip_addr | ||||
r379 | return '<no ip available>' | |||
r649 | @property | |||
def server_url(self): | ||||
r1433 | default = '<no server_url available>' | |||
r649 | if self.request: | |||
from rhodecode.lib import helpers as h | ||||
r1433 | try: | |||
return h.url('home', qualified=True) | ||||
except Exception: | ||||
log.exception('Failed to fetch URL for server') | ||||
return default | ||||
return default | ||||
r649 | ||||
r379 | def as_dict(self): | |||
r411 | data = { | |||
'name': self.name, | ||||
'utc_timestamp': self.utc_timestamp, | ||||
'actor_ip': self.actor_ip, | ||||
'actor': { | ||||
'username': self.actor.username | ||||
r649 | }, | |||
'server_url': self.server_url | ||||
r411 | } | |||
r649 | return data | |||