|
Server : LiteSpeed System : Linux srv526460274 5.15.0-164-generic #174-Ubuntu SMP Fri Nov 14 20:25:16 UTC 2025 x86_64 User : kerao9884 ( 1082) PHP Version : 8.0.30 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /usr/lib/python3/dist-packages/firewall/server/ |
Upload File : |
# -*- coding: utf-8 -*-
#
# SPDX-License-Identifier: GPL-2.0-or-later
import dbus
from firewall import config
class FirewallDBusException(dbus.DBusException):
"""FirewallDBusException"""
_dbus_error_name = "%s.Exception" % config.dbus.DBUS_INTERFACE
class NotAuthorizedException(dbus.DBusException):
def __init__(self, action_id, method, *args, **kwargs):
self._dbus_error_name = config.dbus.DBUS_INTERFACE + ".NotAuthorizedException"
super().__init__("Not Authorized({}): {}".format(method, action_id))
class DbusServiceObject(dbus.service.Object):
def __new__(cls, *args, **kwargs):
# Check each dbus method. If it does not have an explicit polkit auth
# then implicitly wrap it with the default
from firewall.server.decorators import dbus_polkit_require_auth
for attr_name in dir(cls):
method = getattr(cls, attr_name)
if hasattr(method, "_dbus_is_method") and \
not hasattr(method, "_polkit_auth_required"):
_decorator = dbus_polkit_require_auth(cls.default_polkit_auth_required)
setattr(cls, attr_name, _decorator(method))
return super().__new__(cls)