2015-03-19 20:55:18 +01:00
|
|
|
#!/usr/bin/python3
|
|
|
|
|
|
|
|
import yaml
|
|
|
|
import imp
|
|
|
|
import os
|
2015-04-03 09:17:03 +02:00
|
|
|
import socket
|
2015-04-03 21:35:55 +02:00
|
|
|
import time
|
2015-04-25 07:37:07 +02:00
|
|
|
import sys
|
|
|
|
|
|
|
|
import proto
|
2015-03-19 20:55:18 +01:00
|
|
|
print('PyLink starting...')
|
|
|
|
|
|
|
|
with open("config.yml", 'r') as f:
|
|
|
|
conf = yaml.load(f)
|
|
|
|
|
|
|
|
# if conf['login']['password'] == 'changeme':
|
|
|
|
# print("You have not set the login details correctly! Exiting...")
|
|
|
|
|
2015-04-18 04:55:48 +02:00
|
|
|
class Irc():
|
|
|
|
def __init__(self):
|
2015-04-04 03:45:18 +02:00
|
|
|
# Initialize some variables
|
2015-04-03 09:17:03 +02:00
|
|
|
self.socket = socket.socket()
|
2015-04-18 04:55:48 +02:00
|
|
|
self.connected = False
|
2015-04-04 03:45:18 +02:00
|
|
|
self.users = {}
|
2015-04-18 07:11:49 +02:00
|
|
|
self.channels = {}
|
2015-04-18 04:55:48 +02:00
|
|
|
self.name = conf['server']['netname']
|
2015-04-25 07:37:07 +02:00
|
|
|
self.conf = conf
|
2015-05-31 07:15:19 +02:00
|
|
|
self.servers = {}
|
2015-04-03 09:17:03 +02:00
|
|
|
|
2015-04-18 04:55:48 +02:00
|
|
|
self.serverdata = conf['server']
|
2015-04-03 09:17:03 +02:00
|
|
|
ip = self.serverdata["ip"]
|
|
|
|
port = self.serverdata["port"]
|
|
|
|
self.sid = self.serverdata["sid"]
|
2015-04-18 04:55:48 +02:00
|
|
|
print("Connecting to network %r on %s:%s" % (self.name, ip, port))
|
2015-04-03 09:17:03 +02:00
|
|
|
|
|
|
|
self.socket = socket.socket()
|
|
|
|
self.socket.connect((ip, port))
|
2015-04-25 07:37:07 +02:00
|
|
|
proto.connect(self)
|
2015-04-18 04:55:48 +02:00
|
|
|
self.connected = True
|
2015-04-25 07:37:07 +02:00
|
|
|
self.loaded = []
|
|
|
|
self.load_plugins()
|
2015-04-18 04:55:48 +02:00
|
|
|
self.run()
|
2015-04-03 09:17:03 +02:00
|
|
|
|
2015-04-03 21:35:55 +02:00
|
|
|
def run(self):
|
2015-04-18 07:11:49 +02:00
|
|
|
buf = ""
|
|
|
|
data = ""
|
2015-04-18 04:55:48 +02:00
|
|
|
while self.connected:
|
2015-04-03 21:35:55 +02:00
|
|
|
try:
|
2015-05-31 07:15:19 +02:00
|
|
|
data = self.socket.recv(2048).decode("utf-8")
|
2015-04-25 07:37:07 +02:00
|
|
|
buf += data
|
2015-04-18 07:11:49 +02:00
|
|
|
if not data:
|
|
|
|
break
|
|
|
|
while '\n' in buf:
|
|
|
|
line, buf = buf.split('\n', 1)
|
|
|
|
print("<- {}".format(line))
|
2015-04-25 07:37:07 +02:00
|
|
|
proto.handle_events(self, line)
|
|
|
|
except socket.error as e:
|
2015-04-18 04:55:48 +02:00
|
|
|
print('Received socket.error: %s, exiting.' % str(e))
|
2015-04-25 07:37:07 +02:00
|
|
|
break
|
|
|
|
sys.exit(1)
|
2015-04-03 09:17:03 +02:00
|
|
|
|
|
|
|
def send(self, data):
|
|
|
|
data = data.encode("utf-8") + b"\n"
|
|
|
|
print("-> {}".format(data.decode("utf-8").strip("\n")))
|
|
|
|
self.socket.send(data)
|
2015-03-19 20:55:18 +01:00
|
|
|
|
2015-04-25 07:37:07 +02:00
|
|
|
def load_plugins(self):
|
|
|
|
to_load = conf['plugins']
|
|
|
|
plugins_folder = [os.path.join(os.getcwd(), 'plugins')]
|
|
|
|
# Here, we override the module lookup and import the plugins
|
|
|
|
# dynamically depending on which were configured.
|
|
|
|
for plugin in to_load:
|
|
|
|
moduleinfo = imp.find_module(plugin, plugins_folder)
|
|
|
|
self.loaded.append(imp.load_source(plugin, moduleinfo[1]))
|
|
|
|
print("loaded plugins: %s" % self.loaded)
|
|
|
|
|
|
|
|
|
2015-04-18 04:55:48 +02:00
|
|
|
irc_obj = Irc()
|