forked from sqozz/sem6000
Merge branch 'improved_reconnect' of cfr34k/sem6000 into master
This commit is contained in:
commit
60199338bf
22
example.py
22
example.py
|
@ -1,23 +1,35 @@
|
|||
import time
|
||||
from sem6000 import SEMSocket
|
||||
|
||||
import bluepy
|
||||
|
||||
socket = None
|
||||
|
||||
while True:
|
||||
time.sleep(1)
|
||||
try:
|
||||
if socket == None:
|
||||
print("Connecting...")
|
||||
|
||||
# auto_reconnect_timeout enabled auto reconnect if sending a command fails. Valid values:
|
||||
# None (default): everything that fails throws NotConnectedException's
|
||||
# -1: infinite retries
|
||||
# integer: seconds before exception is thrown
|
||||
|
||||
socket = SEMSocket('f0:c7:7f:0d:e7:17', auto_reconnect_timeout=None)
|
||||
print("Connected.")
|
||||
|
||||
#socket.login("1337")
|
||||
#socket.changePassword("1234")
|
||||
#socket.login("1234")
|
||||
|
||||
while True:
|
||||
time.sleep(1)
|
||||
try:
|
||||
socket.getStatus()
|
||||
socket.setStatus(True)
|
||||
print("=== {} ({}) ===".format(socket.mac_address, "on" if socket.powered else "off"))
|
||||
print("\t{}V {}A → {}W@{}Hz".format(socket.voltage, socket.current, socket.power, socket.frequency))
|
||||
except SEMSocket.NotConnectedException:
|
||||
socket.reconnect(-1) #infinite reconnect attempts
|
||||
except (SEMSocket.NotConnectedException, bluepy.btle.BTLEDisconnectError):
|
||||
print("Restarting...")
|
||||
if socket != None:
|
||||
socket.disconnect()
|
||||
socket = None
|
||||
|
||||
|
|
Loading…
Reference in a new issue