mirror of
https://github.com/softScheck/tplink-smartplug
synced 2026-01-11 23:38:46 +01:00
Dropped Python2 support; improved code style
This commit is contained in:
@@ -19,12 +19,11 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
#
|
#
|
||||||
|
|
||||||
import sys
|
|
||||||
import socket
|
|
||||||
import argparse
|
import argparse
|
||||||
|
import socket
|
||||||
from struct import pack
|
from struct import pack
|
||||||
|
|
||||||
version = 0.3
|
version = 0.4
|
||||||
|
|
||||||
# Check if hostname is valid
|
# Check if hostname is valid
|
||||||
def validHostname(hostname):
|
def validHostname(hostname):
|
||||||
@@ -67,11 +66,10 @@ commands = { 'info' : '{"system":{"get_sysinfo":{}}}',
|
|||||||
|
|
||||||
# Encryption and Decryption of TP-Link Smart Home Protocol
|
# Encryption and Decryption of TP-Link Smart Home Protocol
|
||||||
# XOR Autokey Cipher with starting key = 171
|
# XOR Autokey Cipher with starting key = 171
|
||||||
# Python 3.x Version
|
|
||||||
if sys.version_info[0] > 2:
|
|
||||||
def encrypt(string):
|
def encrypt(string):
|
||||||
key = 171
|
key = 171
|
||||||
result = pack('>I', len(string))
|
result = pack(">I", len(string))
|
||||||
for i in string:
|
for i in string:
|
||||||
a = key ^ ord(i)
|
a = key ^ ord(i)
|
||||||
key = a
|
key = a
|
||||||
@@ -87,35 +85,22 @@ if sys.version_info[0] > 2:
|
|||||||
result += chr(a)
|
result += chr(a)
|
||||||
return result
|
return result
|
||||||
|
|
||||||
# Python 2.x Version
|
|
||||||
else:
|
|
||||||
def encrypt(string):
|
|
||||||
key = 171
|
|
||||||
result = pack('>I', len(string))
|
|
||||||
for i in string:
|
|
||||||
a = key ^ ord(i)
|
|
||||||
key = a
|
|
||||||
result += chr(a)
|
|
||||||
return result
|
|
||||||
|
|
||||||
def decrypt(string):
|
|
||||||
key = 171
|
|
||||||
result = ""
|
|
||||||
for i in string:
|
|
||||||
a = key ^ ord(i)
|
|
||||||
key = ord(i)
|
|
||||||
result += chr(a)
|
|
||||||
return result
|
|
||||||
|
|
||||||
# Parse commandline arguments
|
# Parse commandline arguments
|
||||||
parser = argparse.ArgumentParser(description="TP-Link Wi-Fi Smart Plug Client v" + str(version))
|
parser = argparse.ArgumentParser(description=f"TP-Link Wi-Fi Smart Plug Client v{version}")
|
||||||
parser.add_argument("-t", "--target", metavar="<hostname>", required=True, help="Target hostname or IP address", type=validHostname)
|
parser.add_argument("-t", "--target", metavar="<hostname>", required=True,
|
||||||
parser.add_argument("-p", "--port", metavar="<port>", default=9999, required=False, help="Target port", type=validPort)
|
help="Target hostname or IP address", type=validHostname)
|
||||||
parser.add_argument("-q", "--quiet", dest='quiet', action='store_true', help="Only show result")
|
parser.add_argument("-p", "--port", metavar="<port>", default=9999,
|
||||||
parser.add_argument("--timeout", default=10, required=False, help="Timeout to establish connection")
|
required=False, help="Target port", type=validPort)
|
||||||
|
parser.add_argument("-q", "--quiet", dest="quiet", action="store_true",
|
||||||
|
help="Only show result")
|
||||||
|
parser.add_argument("--timeout", default=10, required=False,
|
||||||
|
help="Timeout to establish connection")
|
||||||
group = parser.add_mutually_exclusive_group(required=True)
|
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("-c", "--command", metavar="<command>",
|
||||||
group.add_argument("-j", "--json", metavar="<JSON string>", help="Full JSON string of command to send")
|
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()
|
args = parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
@@ -128,7 +113,6 @@ else:
|
|||||||
cmd = commands[args.command]
|
cmd = commands[args.command]
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
# Send command and receive reply
|
# Send command and receive reply
|
||||||
try:
|
try:
|
||||||
sock_tcp = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
sock_tcp = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
|
||||||
@@ -148,4 +132,4 @@ try:
|
|||||||
print("Received: ", decrypted)
|
print("Received: ", decrypted)
|
||||||
|
|
||||||
except socket.error:
|
except socket.error:
|
||||||
quit("Could not connect to host " + ip + ":" + str(port))
|
quit(f"Could not connect to host {ip}:{port}")
|
||||||
|
|||||||
Reference in New Issue
Block a user