"""Networks plugin - allows you to manipulate connections to various configured networks.""" import threading from pylinkirc import utils, world from pylinkirc.log import log @utils.add_cmd def disconnect(irc, source, args): """ Disconnects the 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): """ Initiates a connection to the 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: # Reconnect the network! network.connection_thread = threading.Thread(target=network.connect) network.connection_thread.start() # And the plugins we have too. for plugin in world.plugins.values(): if hasattr(plugin, 'main'): log.debug('(%s) Calling main() function of plugin %r', irc.name, plugin) plugin.main(irc) irc.reply("Done.") @utils.add_cmd def autoconnect(irc, source, args): """ Sets the autoconnect time for to . You can disable autoconnect for a network by setting 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) return network.serverdata['autoconnect'] = seconds irc.reply("Done.") @utils.add_cmd def remote(irc, source, args): """ Runs on the remote 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 = "" 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.")