當前位置: 首頁>>代碼示例>>Python>>正文


Python dbus.DBusException方法代碼示例

本文整理匯總了Python中dbus.DBusException方法的典型用法代碼示例。如果您正苦於以下問題:Python dbus.DBusException方法的具體用法?Python dbus.DBusException怎麽用?Python dbus.DBusException使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在dbus的用法示例。


在下文中一共展示了dbus.DBusException方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: run

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def run(self):
            self.loop = GLib.MainLoop()

            if self.config.notifications:
                try:
                    notify2.init("pantalaimon", mainloop=self.loop)
                    self.notifications = True
                except dbus.DBusException:
                    logger.error(
                        "Notifications are enabled but no notification "
                        "server could be found, disabling notifications."
                    )
                    self.notifications = False

            GLib.timeout_add(100, self.message_callback)
            if not self.loop:
                return

            self.loop.run() 
開發者ID:matrix-org,項目名稱:pantalaimon,代碼行數:21,代碼來源:ui.py

示例2: all

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def all(cls):
        result = []

        for connection in NMSettings.ListConnections():
            try:
                conn_settings = connection.GetSettings()
            except DBusException as e:
                # NM throws an exception if we try to use GetSettings on a
                # connection owned by another user. We just ignore it.
                continue

            if '802-11-wireless' not in conn_settings:
                continue

            result.append(cls(connection))

        return OrderedDict(
            [(c.ssid, c) for c in sorted(result, key=attrgetter('ssid'))]) 
開發者ID:ideascube,項目名稱:ideascube,代碼行數:20,代碼來源:wifi.py

示例3: VideoPosWrapper

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def VideoPosWrapper(self,args):
        timeout=3
        try:
            # Neither get_object nor start_service_by_name support a timeout. As a workaround you can directly use call_blocking before.
            #This call is just for forcing a shorter timeout then default in case bus is not ready or available
            logger.debug("DBusConnection: start TESTING if bus " + self._dbus_name + " is ready to accept videopos commands")
            self._bus.call_blocking(self._dbus_name, '/org/mpris/MediaPlayer2',
                                    'org.mpris.MediaPlayer2.Player',
                                    'VideoPos',
                                    None, (args), timeout=timeout)

            logger.debug("DBusConnection: bus: " + self._dbus_name + " is ready to accept videopos commands")

            #The previous call_blocking directly is kind of a hack to be able to set the timeout, if this stops working in the future use below to set the VideoPos
            #self.player_interface.VideoPos(args)
        except dbus.DBusException as e:
            logger.debug("DBusConnection: The bus: " + self._dbus_name + " is NOT ready to accept videopos commands: %s", e)

# The python dbus bindings don't provide property access via the
# 'org.freedesktop.DBus.Properties' interface so we wrap the access of
# properties using 
開發者ID:SvenVD,項目名稱:rpisurv,代碼行數:23,代碼來源:dbus_connection.py

示例4: emit

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def emit(self, record):
        app_icon = self.app_icons[
            max(level for level in self.app_icons if level <= record.levelno)]

        try:
            # https://developer.gnome.org/notification-spec/#command-notify
            self._notify_object.Notify(
                'Qubes',    # STRING app_name
                0,          # UINT32 replaces_id
                app_icon,   # STRING app_icon
                record.msg, # STRING summary
                '',         # STRING body
                (),         # ARRAY actions
                {},         # DICT hints
                0,          # INT32 timeout
                dbus_interface='org.freedesktop.Notifications')
        except dbus.DBusException:
            pass 
開發者ID:QubesOS,項目名稱:qubes-core-admin,代碼行數:20,代碼來源:log.py

示例5: __exit__

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def __exit__(self, exception_type, value, traceback):
            """
            Checks the state of the connection.
            If something went wrong for the connection, notifies the user.

            @param exception_type: the type of exception that occurred, or
                                   None
            @param value: the instance of the exception occurred, or None
            @param traceback: the traceback of the error
            @returns: False if some exception must be re-raised.
            """
            if isinstance(value, dbus.DBusException) or \
                    not self.tomboy_connection_is_ok:
                self.tomboy_failed()
                return True
            else:
                return False 
開發者ID:getting-things-gnome,項目名稱:gtg,代碼行數:19,代碼來源:generictomboy.py

示例6: get_records

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def get_records(self, task):
        """Get a list of hamster facts for a task"""
        ids = self.get_hamster_ids(task)
        records = []
        modified = False
        valid_ids = []
        for i in ids:
            try:
                d = self.hamster.GetFact(i)
                if d and i not in valid_ids:
                    records.append(d)
                    valid_ids.append(i)
                    continue
            except dbus.DBusException:
                pass
            modified = True
            print("Removing invalid fact", i)
        if modified:
            self.set_hamster_ids(task, valid_ids)
        return records 
開發者ID:getting-things-gnome,項目名稱:gtg,代碼行數:22,代碼來源:hamster.py

示例7: priority

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def priority(cls):
        if 'dbus' not in globals():
            raise RuntimeError('python-dbus not installed')
        try:
            bus = dbus.SessionBus(mainloop=DBusGMainLoop())
        except dbus.DBusException as exc:
            raise RuntimeError(exc.get_dbus_message())
        try:
            bus.get_object(cls.bus_name, cls.object_path)
        except dbus.DBusException:
            tmpl = 'cannot connect to {bus_name}'
            msg = tmpl.format(bus_name=cls.bus_name)
            raise RuntimeError(msg)
        if "KDE" in os.getenv("XDG_CURRENT_DESKTOP", "").split(":"):
            return 5.1
        return 4.9 
開發者ID:jaraco,項目名稱:keyring,代碼行數:18,代碼來源:kwallet.py

示例8: connected

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def connected(self, service):
        if self.handle >= 0:
            if self.iface.isOpen(self.handle):
                return True

        bus = dbus.SessionBus(mainloop=DBusGMainLoop())
        wId = 0
        try:
            remote_obj = bus.get_object(self.bus_name, self.object_path)
            self.iface = dbus.Interface(remote_obj, 'org.kde.KWallet')
            self.handle = self.iface.open(self.iface.networkWallet(), wId, self.appid)
        except dbus.DBusException as e:
            raise InitError('Failed to open keyring: %s.' % e)

        if self.handle < 0:
            return False
        self._migrate(service)
        return True 
開發者ID:jaraco,項目名稱:keyring,代碼行數:20,代碼來源:kwallet.py

示例9: _check_permission

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def _check_permission(self, sender, action):
        '''
        Verifies if the specified action is permitted, and raises
        an AccessDeniedException if not.

        The caller should use ObtainAuthorization() to get permission.
        '''

        try:
            if sender:
                kit = dbus.SystemBus().get_object('org.freedesktop.PolicyKit1', '/org/freedesktop/PolicyKit1/Authority')
                kit = dbus.Interface(kit, 'org.freedesktop.PolicyKit1.Authority')

                (granted, _, details) = kit.CheckAuthorization(
                                ('system-bus-name', {'name': sender}),
                                action, {}, dbus.UInt32(1), '', timeout=600)

                if not granted:
                    raise AccessDeniedException('Session not authorized by PolicyKit')

        except AccessDeniedException:
            raise

        except dbus.DBusException as ex:
            raise AccessDeniedException(ex.message) 
開發者ID:gerardpuig,項目名稱:ubuntu-cleaner,代碼行數:27,代碼來源:__init__.py

示例10: __verifyNotRunning

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def __verifyNotRunning(self):
        if os.path.exists(common.LOCK_FILE):
            pid = Application._read_pid_from_lock_file()

            # Check that the found PID is running and is autokey
            with subprocess.Popen(["ps", "-p", pid, "-o", "command"], stdout=subprocess.PIPE) as p:
                output = p.communicate()[0]

            if "autokey" in output.decode():
                logging.debug("AutoKey is already running as pid %s", pid)
                bus = dbus.SessionBus()

                try:
                    dbusService = bus.get_object("org.autokey.Service", "/AppService")
                    dbusService.show_configure(dbus_interface="org.autokey.Service")
                    sys.exit(0)
                except dbus.DBusException as e:
                    logging.exception("Error communicating with Dbus service")
                    self.show_error_dialog(_("AutoKey is already running as pid %s but is not responding") % pid, str(e))
                    sys.exit(1)

        return True 
開發者ID:autokey,項目名稱:autokey,代碼行數:24,代碼來源:gtkapp.py

示例11: send_password_to_clipboard

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def send_password_to_clipboard(self, name):
        field = None
        if name.startswith("otp "):
            base_args = ["pass", "otp", "code"]
            name = name[4:]
        else:
            base_args = ["pass", "show"]
            if name.startswith(":"):
                field, name = name.split(" ", 1)
                field = field[1:]

        try:
            self.send_password_to_gpaste(base_args, name, field)
        except dbus.DBusException:
            # We couldn't join GPaste over D-Bus,
            # use pass native clipboard copy
            self.send_password_to_native_clipboard(base_args, name, field) 
開發者ID:jle64,項目名稱:gnome-pass-search-provider,代碼行數:19,代碼來源:gnome-pass-search-provider.py

示例12: notify

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def notify(self, message, body="", error=False):
        try:
            self.session_bus.get_object(
                "org.freedesktop.Notifications", "/org/freedesktop/Notifications"
            ).Notify(
                "Pass",
                0,
                "dialog-password",
                message,
                body,
                "",
                {"transient": False if error else True},
                0 if error else 3000,
                dbus_interface="org.freedesktop.Notifications",
            )
        except dbus.DBusException as err:
            print(f"Error {err} while trying to display {message}.") 
開發者ID:jle64,項目名稱:gnome-pass-search-provider,代碼行數:19,代碼來源:gnome-pass-search-provider.py

示例13: __init__

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def __init__(self):
        # Load up the DBus
        session_bus = _dbus.SessionBus()
        try:
            self._dbus = session_bus.get_object("org.razer", "/org/razer")
        except _dbus.DBusException:
            raise DaemonNotFound("Could not connect to daemon")

        # Get interface for daemon methods
        self._dbus_daemon = _dbus.Interface(self._dbus, "razer.daemon")

        # Get interface for devices methods
        self._dbus_devices = _dbus.Interface(self._dbus, "razer.devices")

        self._device_serials = self._dbus_devices.getDevices()
        self._devices = []

        self._daemon_version = self._dbus_daemon.version()

        for serial in self._device_serials:
            device = _RazerDeviceFactory.get_device(serial)
            self._devices.append(device) 
開發者ID:openrazer,項目名稱:openrazer,代碼行數:24,代碼來源:__init__.py

示例14: _create_proxy

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def _create_proxy(self):
        try:
            # introspection fails so it is disabled
            proxy = self._bus.get_object(self._dbus_name,
                                         '/org/mpris/MediaPlayer2',
                                         introspect=False)
            return proxy
        except dbus.DBusException:
            raise DBusConnectionError('Could not get proxy object') 
開發者ID:SvenVD,項目名稱:rpisurv,代碼行數:11,代碼來源:dbus_connection.py

示例15: set_dns_systemd_resolved

# 需要導入模塊: import dbus [as 別名]
# 或者: from dbus import DBusException [as 別名]
def set_dns_systemd_resolved(lease):
    # NOTE: if systemd-resolved is not already running, we might not want to
    # run it in case there's specific system configuration for other resolvers
    ipr = IPRoute()
    index = ipr.link_lookup(ifname=lease.interface)[0]
    # Construct the argument to pass to DBUS.
    # the equivalent argument for:
    # busctl call org.freedesktop.resolve1 /org/freedesktop/resolve1 \
    # org.freedesktop.resolve1.Manager SetLinkDNS 'ia(iay)' 2 1 2 4 1 2 3 4
    # is SetLinkDNS(2, [(2, [8, 8, 8, 8])]_
    iay = [(2, [int(b) for b in ns.split('.')])
           for ns in lease.name_server.split()]
    #        if '.' in ns
    #        else (10, [ord(x) for x in
    #            socket.inet_pton(socket.AF_INET6, ns)])
    bus = SystemBus()
    resolved = bus.get_object('org.freedesktop.resolve1',
                              '/org/freedesktop/resolve1')
    manager = Interface(resolved,
                        dbus_interface='org.freedesktop.resolve1.Manager')
    try:
        manager.SetLinkDNS(index, iay)
        return True
    except DBusException as e:
        logger.error(e)
        return False 
開發者ID:juga0,項目名稱:dhcpcanon,代碼行數:28,代碼來源:netutils.py


注:本文中的dbus.DBusException方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。