Skip to content
This repository has been archived by the owner on Nov 7, 2024. It is now read-only.

Commit

Permalink
Update 0.1.5
Browse files Browse the repository at this point in the history
  • Loading branch information
MikeDev101 authored Aug 21, 2021
1 parent f6a37c5 commit e106863
Showing 1 changed file with 13 additions and 9 deletions.
22 changes: 13 additions & 9 deletions cloudlink/cloudlink.py
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
#!/usr/bin/env python3

version = "0.1.5"

"""
### CloudLink Server ###
Expand Down Expand Up @@ -50,10 +52,6 @@ def host(self, port, ip=None): # runs the module in server mode, uses websocket-
self.serverThread.setDaemon(True)

# Run the server
if ip == None:
print("Now running in host mode on port {0}...".format(port))
else:
print("Now running in host mode on port {0} using IP {1}...".format(port, ip))
self.serverThread.start()

except Exception as e:
Expand All @@ -76,7 +74,6 @@ def client(self, ip, on_new_packet=None, on_connect=None, on_error=None): # runs
self.clientThread.setDaemon(True)

# Run the client
print("Now running in client mode, connecting to IP {0}...".format(ip))
self.clientThread.start()

except Exception as e:
Expand Down Expand Up @@ -113,13 +110,15 @@ def __init__(self): # Initializes the class
self.handlers = []
self.gdata = ""
self.mode = 0 # 1=Host, 2=Client
print("CloudLink v{0}".format(version))

def _newConnection(self, client, server): # Server: Handles new connections
if self.mode == 1:
print("New connection: {0}".format(client['id']))
self.users[str(client)] = {"name": "", "id": str(client['id'])}
self._relayUserList(server, True, client)
self._sendPacket(server, True, {"cmd":"gmsg", "id":client, "val":str(self.gdata)})
self._sendPacket(server, True, {"cmd":"direct", "id":client, "val": {"cmd": "vers", "val": version}})

def _sendPacket(self, server, type, data): # Server: Transmits packets, False:Public, True:Private
if self.mode == 1:
Expand Down Expand Up @@ -161,6 +160,7 @@ def _gotPacket(self, client, server, message): # Server: Handles new packet even
err = False
try:
packet = json.loads(message)
print("Got packet: {0} bytes".format(len(str(packet))))
except Exception as e:
err = True
finally:
Expand All @@ -182,6 +182,10 @@ def _gotPacket(self, client, server, message): # Server: Handles new packet even
name = str(packet['name'])
else:
name = ""
if "origin" in packet:
origin = str(packet['origin'])
else:
origin = ""

if cmd == "clear": # Clears comms
self._sendPacket(server, False, {"cmd":"gmsg", "val":""})
Expand All @@ -202,12 +206,14 @@ def _gotPacket(self, client, server, message): # Server: Handles new packet even
self._sendPacket(server, False, {"cmd":"gmsg", "val":self.gdata})
if cmd == "pmsg": # Set private stream data values
if not id == "":
self._sendPacket(server, True, {"cmd":"pmsg", "id":id, "val":val})
if not origin == "":
self._sendPacket(server, True, {"cmd":"pmsg", "id":id, "val":val, "origin":origin})
if cmd == "gvar": # Set global variable data values
self._sendPacket(server, False, {"cmd":"gvar", "name":name, "val":val})
if cmd == "pvar": # Set private variable data values
if not id == "":
self._sendPacket(server, True, {"cmd":"pvar", "name":name, "id":id, "val":val})
if not origin == "":
self._sendPacket(server, True, {"cmd":"pvar", "name":name, "id":id, "val":val, "origin":origin})

def _set_fn_new_packet(self, fn): # Client: Defines API-friendly callback to new packet events
self.fn_msg = fn
Expand All @@ -225,13 +231,11 @@ def _on_message(self, ws, message): # Client: Defines callback to new packet eve
if not json.loads(message) == {"cmd": "ds"}:
self.fn_msg(json.loads(message))
else:
print("Server is shutting down, disconnecting.")
self.fn_ds()

def _on_error(self, ws, error): # Client: Defines callback to error events
self.fn_err(error)
self.fn_ds()

def _on_open(self, ws): # Client: Defines callback to connected event
print("Connected.")
self.fn_con()

0 comments on commit e106863

Please sign in to comment.