54 lines
2.1 KiB
Python
54 lines
2.1 KiB
Python
#
|
|
# daemon.py
|
|
#
|
|
# Copyright (C) 2007 Andrew Resch ('andar') <andrewresch@gmail.com>
|
|
#
|
|
# Deluge is free software.
|
|
#
|
|
# You may 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.
|
|
#
|
|
# deluge 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 deluge. If not, write to:
|
|
# The Free Software Foundation, Inc.,
|
|
# 51 Franklin Street, Fifth Floor
|
|
# Boston, MA 02110-1301, USA.
|
|
#
|
|
# In addition, as a special exception, the copyright holders give
|
|
# permission to link the code of portions of this program with the OpenSSL
|
|
# library.
|
|
# You must obey the GNU General Public License in all respects for all of
|
|
# the code used other than OpenSSL. If you modify file(s) with this
|
|
# exception, you may extend this exception to your version of the file(s),
|
|
# but you are not obligated to do so. If you do not wish to do so, delete
|
|
# this exception statement from your version. If you delete this exception
|
|
# statement from all source files in the program, then also delete it here.
|
|
|
|
import dbus
|
|
from dbus.mainloop.glib import DBusGMainLoop
|
|
|
|
from deluge.core.core import Core
|
|
from deluge.log import LOG as log
|
|
|
|
class Daemon:
|
|
def __init__(self):
|
|
# Check to see if the daemon is already running and if not, start it
|
|
bus = dbus.SessionBus()
|
|
obj = bus.get_object("org.freedesktop.DBus", "/org/freedesktop/DBus")
|
|
iface = dbus.Interface(obj, "org.freedesktop.DBus")
|
|
if iface.NameHasOwner("org.deluge_torrent.Deluge"):
|
|
# Daemon is running so lets tell the user
|
|
log.info("Daemon is already running..")
|
|
else:
|
|
# Daemon is not running so lets start up the core
|
|
log.debug("Daemon is not running..")
|
|
self.core = Core()
|
|
|