Implement Ctrl-C handling and fix a large number of small bugs
This commit is contained in:
@@ -11,25 +11,31 @@ class DisableCommand:
|
||||
if not spl[1] in main.network.keys():
|
||||
failure("No such network: %s" % spl[1])
|
||||
return
|
||||
if not int(spl[2]) in main.network[spl[1]].relays.keys():
|
||||
if not spl[2].isdigit():
|
||||
failure("Must be integer, not %s" % spl[2])
|
||||
return
|
||||
relayNum = int(spl[2])
|
||||
name = spl[1]+spl[2]
|
||||
if not spl[1] in main.IRCPool.keys():
|
||||
info("Note - instance not running, proceeding anyway")
|
||||
if not relayNum in main.network[spl[1]].relays.keys():
|
||||
failure("No such relay: %s in network %s" % (spl[2], spl[1]))
|
||||
return
|
||||
|
||||
main.network[spl[1]].relays[int(spl[2])]["enabled"] = False
|
||||
user = main.network[spl[1]].aliases[int(spl[2])]
|
||||
main.network[spl[1]].relays[relayNum]["enabled"] = False
|
||||
user = main.network[spl[1]].aliases[relayNum]["nick"]
|
||||
network = spl[1]
|
||||
relay = main.network[spl[1]].relays[int(spl[2])]
|
||||
relay = main.network[spl[1]].relays[relayNum]
|
||||
commands = {"status": ["Disconnect"]}
|
||||
deliverRelayCommands(relay, commands, user=user+"/"+network)
|
||||
deliverRelayCommands(relayNum, commands, user=user+"/"+network)
|
||||
main.saveConf("network")
|
||||
if spl[1]+spl[2] in main.ReactorPool.keys():
|
||||
if spl[1]+spl[2] in main.FactoryPool.keys():
|
||||
main.FactoryPool[spl[1]+spl[2]].stopTrying()
|
||||
main.ReactorPool[spl[1]+spl[2]].disconnect()
|
||||
if name in main.ReactorPool.keys():
|
||||
if name in main.FactoryPool.keys():
|
||||
main.FactoryPool[name].stopTrying()
|
||||
main.ReactorPool[name].disconnect()
|
||||
if spl[1] in main.IRCPool.keys():
|
||||
del main.IRCPool[spl[1]+spl[2]]
|
||||
del main.ReactorPool[spl[1]+spl[2]]
|
||||
del main.FactoryPool[spl[1]+spl[2]]
|
||||
del main.IRCPool[name]
|
||||
del main.ReactorPool[name]
|
||||
del main.FactoryPool[name]
|
||||
success("Successfully disabled bot %s on network %s" % (spl[2], spl[1]))
|
||||
return
|
||||
else:
|
||||
|
||||
Reference in New Issue
Block a user