Move dbus modules into own folder
- light refactor of the screensaver module
This commit is contained in:
parent
383e220e69
commit
cfd24b6d6c
|
@ -24,7 +24,7 @@ gi.require_version('Geoclue', '2.0')
|
||||||
from gi.repository import Geoclue
|
from gi.repository import Geoclue
|
||||||
from gi.repository import GLib
|
from gi.repository import GLib
|
||||||
|
|
||||||
log = logging.getLogger('gajim.c.location_listener')
|
log = logging.getLogger('gajim.c.dbus.location')
|
||||||
|
|
||||||
|
|
||||||
class LocationListener:
|
class LocationListener:
|
|
@ -24,7 +24,7 @@ import logging
|
||||||
from gi.repository import GObject
|
from gi.repository import GObject
|
||||||
from gi.repository import Gio, GLib
|
from gi.repository import Gio, GLib
|
||||||
|
|
||||||
log = logging.getLogger('gajim.music_track_listener')
|
log = logging.getLogger('gajim.c.dbus.music_track')
|
||||||
|
|
||||||
MPRIS_PLAYER_PREFIX = 'org.mpris.MediaPlayer2.'
|
MPRIS_PLAYER_PREFIX = 'org.mpris.MediaPlayer2.'
|
||||||
|
|
|
@ -0,0 +1,103 @@
|
||||||
|
# Copyright (C) 2018 André Apitzsch <git AT apitzsch.eu>
|
||||||
|
#
|
||||||
|
# This file is part of Gajim.
|
||||||
|
#
|
||||||
|
# Gajim is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published
|
||||||
|
# by the Free Software Foundation; version 3 only.
|
||||||
|
#
|
||||||
|
# Gajim 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 General Public License
|
||||||
|
# along with Gajim. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import logging
|
||||||
|
|
||||||
|
from gi.repository import Gio
|
||||||
|
|
||||||
|
from gajim.common import app
|
||||||
|
|
||||||
|
log = logging.getLogger('gajim.c.dbus.screensaver')
|
||||||
|
|
||||||
|
|
||||||
|
class ScreensaverListener:
|
||||||
|
_instance = None
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def get(cls):
|
||||||
|
if cls._instance is None:
|
||||||
|
cls._instance = cls()
|
||||||
|
return cls._instance
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
Gio.bus_watch_name(
|
||||||
|
Gio.BusType.SESSION,
|
||||||
|
'org.gnome.ScreenSaver',
|
||||||
|
Gio.BusNameWatcherFlags.NONE,
|
||||||
|
self._appeared,
|
||||||
|
None)
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def _signal_received(_connection, _sender_name, _object_path,
|
||||||
|
interface_name, _signal_name, parameters, *_user_data):
|
||||||
|
'''Signal handler for screensaver active change'''
|
||||||
|
|
||||||
|
log.info('Signal received: %s - %s', interface_name, parameters)
|
||||||
|
|
||||||
|
roster = app.interface.roster
|
||||||
|
|
||||||
|
if not parameters[0]:
|
||||||
|
for account in app.connections:
|
||||||
|
if app.account_is_connected(account) and \
|
||||||
|
app.sleeper_state[account] == 'autoaway-forced':
|
||||||
|
# We came back online after screensaver
|
||||||
|
# autoaway
|
||||||
|
roster.send_status(account, 'online',
|
||||||
|
app.status_before_autoaway[account])
|
||||||
|
app.status_before_autoaway[account] = ''
|
||||||
|
app.sleeper_state[account] = 'online'
|
||||||
|
return
|
||||||
|
if not app.config.get('autoaway'):
|
||||||
|
# Don't go auto away if user disabled the option
|
||||||
|
return
|
||||||
|
for account in app.connections:
|
||||||
|
if account not in app.sleeper_state or not app.sleeper_state[account]:
|
||||||
|
continue
|
||||||
|
if app.sleeper_state[account] == 'online':
|
||||||
|
if not app.account_is_connected(account):
|
||||||
|
continue
|
||||||
|
# we save our online status
|
||||||
|
app.status_before_autoaway[account] = \
|
||||||
|
app.connections[account].status
|
||||||
|
# we go away (no auto status) [we pass True to auto param]
|
||||||
|
auto_message = app.config.get('autoaway_message')
|
||||||
|
if not auto_message:
|
||||||
|
auto_message = app.connections[account].status
|
||||||
|
else:
|
||||||
|
auto_message = auto_message.replace('$S', '%(status)s')
|
||||||
|
auto_message = auto_message.replace('$T', '%(time)s')
|
||||||
|
auto_message = auto_message % {
|
||||||
|
'status': app.status_before_autoaway[account],
|
||||||
|
'time': app.config.get('autoxatime')}
|
||||||
|
roster.send_status(account, 'away', auto_message, auto=True)
|
||||||
|
app.sleeper_state[account] = 'autoaway-forced'
|
||||||
|
|
||||||
|
def _appeared(self, connection, name, _name_owner, *_user_data):
|
||||||
|
'''Set up a listener for screensaver signals'''
|
||||||
|
log.info('%s appeared', name)
|
||||||
|
connection.signal_subscribe(
|
||||||
|
'org.gnome.ScreenSaver',
|
||||||
|
'org.gnome.ScreenSaver',
|
||||||
|
'ActiveChanged',
|
||||||
|
'/org/gnome/ScreenSaver',
|
||||||
|
None,
|
||||||
|
Gio.DBusSignalFlags.NONE,
|
||||||
|
self._signal_received,
|
||||||
|
None)
|
||||||
|
|
||||||
|
|
||||||
|
def enable():
|
||||||
|
ScreensaverListener.get()
|
|
@ -56,11 +56,7 @@ except Exception:
|
||||||
|
|
||||||
from gajim.common import app
|
from gajim.common import app
|
||||||
from gajim.common import events
|
from gajim.common import events
|
||||||
|
from gajim.common import dbus
|
||||||
from gajim.music_track_listener import MusicTrackListener
|
|
||||||
|
|
||||||
if app.is_installed('GEOCLUE'):
|
|
||||||
from gajim.common import location_listener
|
|
||||||
|
|
||||||
from gajim import gtkgui_helpers
|
from gajim import gtkgui_helpers
|
||||||
from gajim import gui_menu_builder
|
from gajim import gui_menu_builder
|
||||||
|
@ -1118,7 +1114,7 @@ class Interface:
|
||||||
# enable location listener
|
# enable location listener
|
||||||
if (pep_supported and app.is_installed('GEOCLUE') and
|
if (pep_supported and app.is_installed('GEOCLUE') and
|
||||||
app.config.get_per('accounts', account, 'publish_location')):
|
app.config.get_per('accounts', account, 'publish_location')):
|
||||||
location_listener.enable()
|
dbus.location.enable()
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def show_httpupload_progress(file):
|
def show_httpupload_progress(file):
|
||||||
|
@ -2083,14 +2079,14 @@ class Interface:
|
||||||
|
|
||||||
|
|
||||||
def enable_music_listener(self):
|
def enable_music_listener(self):
|
||||||
listener = MusicTrackListener.get()
|
listener = dbus.music_track.MusicTrackListener.get()
|
||||||
if not self.music_track_changed_signal:
|
if not self.music_track_changed_signal:
|
||||||
self.music_track_changed_signal = listener.connect(
|
self.music_track_changed_signal = listener.connect(
|
||||||
'music-track-changed', self.music_track_changed)
|
'music-track-changed', self.music_track_changed)
|
||||||
listener.start()
|
listener.start()
|
||||||
|
|
||||||
def disable_music_listener(self):
|
def disable_music_listener(self):
|
||||||
listener = MusicTrackListener.get()
|
listener = dbus.music_track.MusicTrackListener.get()
|
||||||
listener.disconnect(self.music_track_changed_signal)
|
listener.disconnect(self.music_track_changed_signal)
|
||||||
self.music_track_changed_signal = None
|
self.music_track_changed_signal = None
|
||||||
listener.stop()
|
listener.stop()
|
||||||
|
@ -2726,7 +2722,7 @@ class Interface:
|
||||||
# Handle screensaver
|
# Handle screensaver
|
||||||
if sys.platform == 'linux':
|
if sys.platform == 'linux':
|
||||||
from gajim import logind_listener # pylint: disable=unused-variable
|
from gajim import logind_listener # pylint: disable=unused-variable
|
||||||
from gajim import screensaver_listener # pylint: disable=unused-variable
|
dbus.screensaver.enable()
|
||||||
|
|
||||||
self.show_vcard_when_connect = []
|
self.show_vcard_when_connect = []
|
||||||
|
|
||||||
|
|
|
@ -62,7 +62,7 @@ from gajim.common import i18n
|
||||||
from gajim.common.i18n import _
|
from gajim.common.i18n import _
|
||||||
from gajim.common.const import PEPEventType, AvatarSize, StyleAttr
|
from gajim.common.const import PEPEventType, AvatarSize, StyleAttr
|
||||||
if app.is_installed('GEOCLUE'):
|
if app.is_installed('GEOCLUE'):
|
||||||
from gajim.common import location_listener
|
from gajim.common import dbus
|
||||||
from gajim.common import ged
|
from gajim.common import ged
|
||||||
from gajim.message_window import MessageWindowMgr
|
from gajim.message_window import MessageWindowMgr
|
||||||
|
|
||||||
|
@ -3659,7 +3659,7 @@ class RosterWindow:
|
||||||
active = widget.get_active()
|
active = widget.get_active()
|
||||||
app.config.set_per('accounts', account, 'publish_location', active)
|
app.config.set_per('accounts', account, 'publish_location', active)
|
||||||
if active:
|
if active:
|
||||||
location_listener.enable()
|
dbus.location.enable()
|
||||||
else:
|
else:
|
||||||
app.connections[account].get_module('UserLocation').send(None)
|
app.connections[account].get_module('UserLocation').send(None)
|
||||||
|
|
||||||
|
|
|
@ -1,90 +0,0 @@
|
||||||
# Copyright (C) 2018 André Apitzsch <git AT apitzsch.eu>
|
|
||||||
#
|
|
||||||
# This file is part of Gajim.
|
|
||||||
#
|
|
||||||
# Gajim is free software; you can redistribute it and/or modify
|
|
||||||
# it under the terms of the GNU General Public License as published
|
|
||||||
# by the Free Software Foundation; version 3 only.
|
|
||||||
#
|
|
||||||
# Gajim 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 General Public License
|
|
||||||
# along with Gajim. If not, see <http://www.gnu.org/licenses/>.
|
|
||||||
|
|
||||||
import logging
|
|
||||||
|
|
||||||
from gi.repository import Gio
|
|
||||||
|
|
||||||
from gajim.common import app
|
|
||||||
|
|
||||||
log = logging.getLogger('gajim.screensaver_listener')
|
|
||||||
|
|
||||||
|
|
||||||
def signal_received(connection, sender_name, object_path,
|
|
||||||
interface_name, signal_name, parameters, *user_data):
|
|
||||||
'''Signal handler for screensaver active change'''
|
|
||||||
|
|
||||||
log.info('Signal received: %s - %s', interface_name, parameters)
|
|
||||||
|
|
||||||
roster = app.interface.roster
|
|
||||||
|
|
||||||
if not parameters[0]:
|
|
||||||
for account in app.connections:
|
|
||||||
if app.account_is_connected(account) and \
|
|
||||||
app.sleeper_state[account] == 'autoaway-forced':
|
|
||||||
# We came back online after screensaver
|
|
||||||
# autoaway
|
|
||||||
roster.send_status(account, 'online',
|
|
||||||
app.status_before_autoaway[account])
|
|
||||||
app.status_before_autoaway[account] = ''
|
|
||||||
app.sleeper_state[account] = 'online'
|
|
||||||
return
|
|
||||||
if not app.config.get('autoaway'):
|
|
||||||
# Don't go auto away if user disabled the option
|
|
||||||
return
|
|
||||||
for account in app.connections:
|
|
||||||
if account not in app.sleeper_state or not app.sleeper_state[account]:
|
|
||||||
continue
|
|
||||||
if app.sleeper_state[account] == 'online':
|
|
||||||
if not app.account_is_connected(account):
|
|
||||||
continue
|
|
||||||
# we save our online status
|
|
||||||
app.status_before_autoaway[account] = \
|
|
||||||
app.connections[account].status
|
|
||||||
# we go away (no auto status) [we pass True to auto param]
|
|
||||||
auto_message = app.config.get('autoaway_message')
|
|
||||||
if not auto_message:
|
|
||||||
auto_message = app.connections[account].status
|
|
||||||
else:
|
|
||||||
auto_message = auto_message.replace('$S', '%(status)s')
|
|
||||||
auto_message = auto_message.replace('$T', '%(time)s')
|
|
||||||
auto_message = auto_message % {
|
|
||||||
'status': app.status_before_autoaway[account],
|
|
||||||
'time': app.config.get('autoxatime')}
|
|
||||||
roster.send_status(account, 'away', auto_message, auto=True)
|
|
||||||
app.sleeper_state[account] = 'autoaway-forced'
|
|
||||||
|
|
||||||
|
|
||||||
def appeared(connection, name, name_owner, *user_data):
|
|
||||||
'''Set up a listener for screensaver signals'''
|
|
||||||
log.info('%s appeared', name)
|
|
||||||
connection.signal_subscribe(
|
|
||||||
'org.gnome.ScreenSaver',
|
|
||||||
'org.gnome.ScreenSaver',
|
|
||||||
'ActiveChanged',
|
|
||||||
'/org/gnome/ScreenSaver',
|
|
||||||
None,
|
|
||||||
Gio.DBusSignalFlags.NONE,
|
|
||||||
signal_received,
|
|
||||||
None)
|
|
||||||
|
|
||||||
|
|
||||||
Gio.bus_watch_name(
|
|
||||||
Gio.BusType.SESSION,
|
|
||||||
'org.gnome.ScreenSaver',
|
|
||||||
Gio.BusNameWatcherFlags.NONE,
|
|
||||||
appeared,
|
|
||||||
None)
|
|
Loading…
Reference in New Issue