mirror of
https://github.com/softScheck/tplink-smartplug
synced 2026-01-11 23:38:46 +01:00
Add "port" parameter
Add management for a new parameter : "port". Allows to modify the defalt port, and not use the default one : 9999 This is useful to send a command to a plug that is not on the local network
This commit is contained in:
@@ -33,6 +33,19 @@ def validHostname(hostname):
|
|||||||
parser.error("Invalid hostname.")
|
parser.error("Invalid hostname.")
|
||||||
return hostname
|
return hostname
|
||||||
|
|
||||||
|
# Check if port is valid
|
||||||
|
def validPort(port):
|
||||||
|
try:
|
||||||
|
port = int(port)
|
||||||
|
except ValueError:
|
||||||
|
parser.error("Invalid port number.")
|
||||||
|
|
||||||
|
if ((port <= 1024) or (port >65535)) :
|
||||||
|
parser.error("Invalid port number.")
|
||||||
|
|
||||||
|
return port
|
||||||
|
|
||||||
|
|
||||||
# Predefined Smart Plug Commands
|
# Predefined Smart Plug Commands
|
||||||
# For a full list of commands, consult tplink_commands.txt
|
# For a full list of commands, consult tplink_commands.txt
|
||||||
commands = {'info' : '{"system":{"get_sysinfo":{}}}',
|
commands = {'info' : '{"system":{"get_sysinfo":{}}}',
|
||||||
@@ -72,6 +85,7 @@ def decrypt(string):
|
|||||||
# Parse commandline arguments
|
# Parse commandline arguments
|
||||||
parser = argparse.ArgumentParser(description="TP-Link Wi-Fi Smart Plug Client v" + str(version))
|
parser = argparse.ArgumentParser(description="TP-Link Wi-Fi Smart Plug Client v" + str(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, help="Target hostname or IP address", type=validHostname)
|
||||||
|
parser.add_argument("-p", "--port", metavar="<port>", default=9999, required=False, help="Target port", type=validPort)
|
||||||
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>", 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("-j", "--json", metavar="<JSON string>", help="Full JSON string of command to send")
|
||||||
@@ -80,7 +94,7 @@ args = parser.parse_args()
|
|||||||
|
|
||||||
# Set target IP, port and command to send
|
# Set target IP, port and command to send
|
||||||
ip = args.target
|
ip = args.target
|
||||||
port = 9999
|
port = args.port
|
||||||
if args.command is None:
|
if args.command is None:
|
||||||
cmd = args.json
|
cmd = args.json
|
||||||
else:
|
else:
|
||||||
|
|||||||
Reference in New Issue
Block a user