Changed to python3 compatability and PEP8 style guidelines.
This commit is contained in:
parent
a8f9e9d65c
commit
ec62f6f869
@ -22,10 +22,11 @@
|
||||
import socket
|
||||
import argparse
|
||||
|
||||
version = 0.1
|
||||
version = 0.2
|
||||
|
||||
|
||||
# Check if IP is valid
|
||||
def validIP(ip):
|
||||
"""Check if IP is valid"""
|
||||
try:
|
||||
socket.inet_pton(socket.AF_INET, ip)
|
||||
except socket.error:
|
||||
@ -34,45 +35,61 @@ def validIP(ip):
|
||||
|
||||
# Predefined Smart Plug Commands
|
||||
# For a full list of commands, consult tplink_commands.txt
|
||||
commands = {'info' : '{"system":{"get_sysinfo":{}}}',
|
||||
'on' : '{"system":{"set_relay_state":{"state":1}}}',
|
||||
'off' : '{"system":{"set_relay_state":{"state":0}}}',
|
||||
commands = {'info': '{"system":{"get_sysinfo":{}}}',
|
||||
'on': '{"system":{"set_relay_state":{"state":1}}}',
|
||||
'off': '{"system":{"set_relay_state":{"state":0}}}',
|
||||
'cloudinfo': '{"cnCloud":{"get_info":{}}}',
|
||||
'wlanscan' : '{"netif":{"get_scaninfo":{"refresh":0}}}',
|
||||
'time' : '{"time":{"get_time":{}}}',
|
||||
'schedule' : '{"schedule":{"get_rules":{}}}',
|
||||
'wlanscan': '{"netif":{"get_scaninfo":{"refresh":0}}}',
|
||||
'time': '{"time":{"get_time":{}}}',
|
||||
'schedule': '{"schedule":{"get_rules":{}}}',
|
||||
'countdown': '{"count_down":{"get_rules":{}}}',
|
||||
'antitheft': '{"anti_theft":{"get_rules":{}}}',
|
||||
'reboot' : '{"system":{"reboot":{"delay":1}}}',
|
||||
'reset' : '{"system":{"reset":{"delay":1}}}'
|
||||
}
|
||||
'reboot': '{"system":{"reboot":{"delay":1}}}',
|
||||
'reset': '{"system":{"reset":{"delay":1}}}'
|
||||
}
|
||||
|
||||
# Encryption and Decryption of TP-Link Smart Home Protocol
|
||||
# XOR Autokey Cipher with starting key = 171
|
||||
# def encrypt(string):
|
||||
# key = 171
|
||||
# result = "\0\0\0\0"
|
||||
# for i in string:
|
||||
# a = key ^ ord(i)
|
||||
# key = a
|
||||
# result += chr(a)
|
||||
# return result
|
||||
|
||||
|
||||
def encrypt(string):
|
||||
key = 171
|
||||
result = "\0\0\0\0"
|
||||
for i in string:
|
||||
a = key ^ ord(i)
|
||||
result = b"\0\0\0" + bytes([len(string)])
|
||||
for i in string.encode('latin-1'):
|
||||
a = key ^ i
|
||||
key = a
|
||||
result += chr(a)
|
||||
result += bytes([a])
|
||||
return result
|
||||
|
||||
|
||||
def decrypt(string):
|
||||
key = 171
|
||||
result = ""
|
||||
result = b""
|
||||
for i in string:
|
||||
a = key ^ ord(i)
|
||||
key = ord(i)
|
||||
result += chr(a)
|
||||
return result
|
||||
a = key ^ i
|
||||
key = i
|
||||
result += bytes([a])
|
||||
return result.decode('latin-1')
|
||||
|
||||
# Parse commandline arguments
|
||||
parser = argparse.ArgumentParser(description="TP-Link Wi-Fi Smart Plug Client v" + str(version))
|
||||
parser.add_argument("-t", "--target", metavar="<ip>", required=True, help="Target IP Address", type=validIP)
|
||||
parser = argparse.ArgumentParser(description="TP-Link Wi-Fi Smart Plug " +
|
||||
"Client v" + str(version))
|
||||
parser.add_argument("-t", "--target", metavar="<ip>", required=True,
|
||||
help="Target IP Address", type=validIP)
|
||||
group = parser.add_mutually_exclusive_group(required=True)
|
||||
group.add_argument("-c", "--command", metavar="<command>", help="Preset command to send. Choices are: "+", ".join(commands), choices=commands)
|
||||
group.add_argument("-j", "--json", metavar="<JSON string>", help="Full JSON string of command to send")
|
||||
group.add_argument("-c", "--command", metavar="<command>",
|
||||
help="Preset command to send. Choices are: " +
|
||||
", ".join(commands), choices=commands)
|
||||
group.add_argument("-j", "--json", metavar="<JSON string>",
|
||||
help="Full JSON string of command to send")
|
||||
args = parser.parse_args()
|
||||
|
||||
# Set target IP, port and command to send
|
||||
@ -83,9 +100,8 @@ if args.command is None:
|
||||
else:
|
||||
cmd = commands[args.command]
|
||||
|
||||
|
||||
|
||||
# Send command and receive reply
|
||||
|
||||
try:
|
||||
sock_tcp = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||
sock_tcp.connect((ip, port))
|
||||
@ -93,7 +109,7 @@ try:
|
||||
data = sock_tcp.recv(2048)
|
||||
sock_tcp.close()
|
||||
|
||||
print "Sent: ", cmd
|
||||
print "Received: ", decrypt(data[4:])
|
||||
print("Sent: ", cmd)
|
||||
print("Received: ", decrypt(data[4:]))
|
||||
except socket.error:
|
||||
quit("Cound not connect to host " + ip + ":" + str(port))
|
||||
|
Loading…
Reference in New Issue
Block a user