mirror of
https://github.com/jlu5/PyLink.git
synced 2024-12-25 12:12:53 +01:00
1ad8b2e539
Closes #245.
120 lines
4.3 KiB
Python
120 lines
4.3 KiB
Python
"""Networks plugin - allows you to manipulate connections to various configured networks."""
|
|
|
|
import sys
|
|
import os
|
|
sys.path.append(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))
|
|
|
|
import threading
|
|
|
|
import utils
|
|
import world
|
|
from log import log
|
|
import conf
|
|
import classes
|
|
|
|
@utils.add_cmd
|
|
def disconnect(irc, source, args):
|
|
"""<network>
|
|
|
|
Disconnects the network <network>. When all networks are disconnected, PyLink will automatically exit.
|
|
Note: This does not affect the autoreconnect settings of any network, so the network will likely just reconnect unless autoconnect is disabled (see the 'autoconnect' command)."""
|
|
irc.checkAuthenticated(source, allowOper=False)
|
|
try:
|
|
netname = args[0]
|
|
network = world.networkobjects[netname]
|
|
except IndexError: # No argument given.
|
|
irc.reply('Error: Not enough arguments (needs 1: network name (case sensitive)).')
|
|
return
|
|
except KeyError: # Unknown network.
|
|
irc.reply('Error: No such network "%s" (case sensitive).' % netname)
|
|
return
|
|
irc.reply("Done.")
|
|
|
|
# Abort the connection! Simple as that.
|
|
network.disconnect()
|
|
|
|
if network.serverdata["autoconnect"] < 1: # Remove networks if autoconnect is disabled.
|
|
del world.networkobjects[netname]
|
|
|
|
@utils.add_cmd
|
|
def connect(irc, source, args):
|
|
"""<network>
|
|
|
|
Initiates a connection to the network <network>."""
|
|
irc.checkAuthenticated(source, allowOper=False)
|
|
try:
|
|
netname = args[0]
|
|
network = world.networkobjects[netname]
|
|
except IndexError: # No argument given.
|
|
irc.reply('Error: Not enough arguments (needs 1: network name (case sensitive)).')
|
|
return
|
|
except KeyError: # Unknown network.
|
|
irc.reply('Error: No such network "%s" (case sensitive).' % netname)
|
|
return
|
|
if network.connection_thread.is_alive():
|
|
irc.reply('Error: Network "%s" seems to be already connected.' % netname)
|
|
else: # Recreate the IRC object.
|
|
proto = utils.getProtocolModule(network.serverdata.get("protocol"))
|
|
world.networkobjects[netname] = classes.Irc(netname, proto, conf.conf)
|
|
|
|
irc.reply("Done.")
|
|
|
|
@utils.add_cmd
|
|
def autoconnect(irc, source, args):
|
|
"""<network> <seconds>
|
|
|
|
Sets the autoconnect time for <network> to <seconds>.
|
|
You can disable autoconnect for a network by setting <seconds> to a negative value."""
|
|
irc.checkAuthenticated(source)
|
|
try:
|
|
netname = args[0]
|
|
seconds = float(args[1])
|
|
network = world.networkobjects[netname]
|
|
except IndexError: # Arguments not given.
|
|
irc.reply('Error: Not enough arguments (needs 2: network name (case sensitive), autoconnect time (in seconds)).')
|
|
return
|
|
except KeyError: # Unknown network.
|
|
irc.reply('Error: No such network "%s" (case sensitive).' % netname)
|
|
return
|
|
except ValueError:
|
|
irc.reply('Error: Invalid argument "%s" for <seconds>.' % seconds)
|
|
return
|
|
network.serverdata['autoconnect'] = seconds
|
|
irc.reply("Done.")
|
|
|
|
@utils.add_cmd
|
|
def remote(irc, source, args):
|
|
"""<network> <command>
|
|
|
|
Runs <command> on the remote network <network>. No replies are sent back due to protocol limitations."""
|
|
irc.checkAuthenticated(source, allowOper=False)
|
|
|
|
try:
|
|
netname = args[0]
|
|
cmd_args = ' '.join(args[1:]).strip()
|
|
remoteirc = world.networkobjects[netname]
|
|
except IndexError: # Arguments not given.
|
|
irc.reply('Error: Not enough arguments (needs 2 or more: network name (case sensitive), command name & arguments).')
|
|
return
|
|
except KeyError: # Unknown network.
|
|
irc.reply('Error: No such network "%s" (case sensitive).' % netname)
|
|
return
|
|
|
|
if not cmd_args:
|
|
irc.reply('No text entered!')
|
|
return
|
|
|
|
# Force remoteirc.called_by to something private in order to prevent
|
|
# accidental information leakage from replies.
|
|
remoteirc.called_by = remoteirc.pseudoclient.uid
|
|
|
|
# Set PyLink's identification to admin.
|
|
remoteirc.pseudoclient.identified = "<PyLink networks.remote override>"
|
|
|
|
try: # Remotely call the command (use the PyLink client as a dummy user).
|
|
remoteirc.callCommand(remoteirc.pseudoclient.uid, cmd_args)
|
|
finally: # Remove the identification override after we finish.
|
|
remoteirc.pseudoclient.identified = ''
|
|
|
|
irc.reply("Done.")
|