94 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
			
		
		
	
	
			94 lines
		
	
	
		
			2.8 KiB
		
	
	
	
		
			Python
		
	
	
	
| # -*- python-mode -*-
 | |
| # -*- coding: UTF-8 -*-
 | |
| 
 | |
| ## Copyright (C) 2012-2013  Daniel Pavel
 | |
| ##
 | |
| ## This program 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; either version 2 of the License, or
 | |
| ## (at your option) any later version.
 | |
| ##
 | |
| ## 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 General Public License along
 | |
| ## with this program; if not, write to the Free Software Foundation, Inc.,
 | |
| ## 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
 | |
| 
 | |
| from __future__ import absolute_import, division, print_function, unicode_literals
 | |
| 
 | |
| from logging import INFO as _INFO
 | |
| from logging import getLogger
 | |
| 
 | |
| _log = getLogger(__name__)
 | |
| del getLogger
 | |
| 
 | |
| #
 | |
| # As suggested here: http://stackoverflow.com/a/13548984
 | |
| #
 | |
| 
 | |
| _suspend_callback = None
 | |
| 
 | |
| 
 | |
| def _suspend():
 | |
|     if _suspend_callback:
 | |
|         if _log.isEnabledFor(_INFO):
 | |
|             _log.info('received suspend event')
 | |
|         _suspend_callback()
 | |
| 
 | |
| 
 | |
| _resume_callback = None
 | |
| 
 | |
| 
 | |
| def _resume():
 | |
|     if _resume_callback:
 | |
|         if _log.isEnabledFor(_INFO):
 | |
|             _log.info('received resume event')
 | |
|         _resume_callback()
 | |
| 
 | |
| 
 | |
| def _suspend_or_resume(suspend):
 | |
|     _suspend() if suspend else _resume()
 | |
| 
 | |
| 
 | |
| def watch(on_resume_callback=None, on_suspend_callback=None):
 | |
|     """Register callback for suspend/resume events.
 | |
|     They are called only if the system DBus is running, and the UPower daemon is available."""
 | |
|     global _resume_callback, _suspend_callback
 | |
|     _suspend_callback = on_suspend_callback
 | |
|     _resume_callback = on_resume_callback
 | |
| 
 | |
| 
 | |
| try:
 | |
|     import dbus
 | |
| 
 | |
|     _UPOWER_BUS = 'org.freedesktop.UPower'
 | |
|     _UPOWER_INTERFACE = 'org.freedesktop.UPower'
 | |
|     _LOGIND_BUS = 'org.freedesktop.login1'
 | |
|     _LOGIND_INTERFACE = 'org.freedesktop.login1.Manager'
 | |
| 
 | |
|     # integration into the main GLib loop
 | |
|     from dbus.mainloop.glib import DBusGMainLoop
 | |
|     DBusGMainLoop(set_as_default=True)
 | |
| 
 | |
|     bus = dbus.SystemBus()
 | |
|     assert bus
 | |
| 
 | |
|     bus.add_signal_receiver(_suspend, signal_name='Sleeping', dbus_interface=_UPOWER_INTERFACE, bus_name=_UPOWER_BUS)
 | |
| 
 | |
|     bus.add_signal_receiver(_resume, signal_name='Resuming', dbus_interface=_UPOWER_INTERFACE, bus_name=_UPOWER_BUS)
 | |
| 
 | |
|     bus.add_signal_receiver(_suspend_or_resume, 'PrepareForSleep', dbus_interface=_LOGIND_INTERFACE, bus_name=_LOGIND_BUS)
 | |
| 
 | |
|     if _log.isEnabledFor(_INFO):
 | |
|         _log.info('connected to system dbus, watching for suspend/resume events')
 | |
| 
 | |
| except Exception:
 | |
|     # Either:
 | |
|     # - the dbus library is not available
 | |
|     # - the system dbus is not running
 | |
|     _log.warn('failed to register suspend/resume callbacks')
 | |
|     pass
 |