Skip to content

Commit

Permalink
Merge pull request #518 from jasonacox/v1.15.0
Browse files Browse the repository at this point in the history
Server - Add network configuration for force scan
  • Loading branch information
jasonacox authored Jul 8, 2024
2 parents e59d6bf + 2b495bc commit 2b84315
Showing 1 changed file with 21 additions and 7 deletions.
28 changes: 21 additions & 7 deletions server/server.py
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@
import urllib.parse
from http.server import BaseHTTPRequestHandler, HTTPServer
from socketserver import ThreadingMixIn
import ipaddress

# Terminal color capability for all platforms
try:
Expand Down Expand Up @@ -82,12 +83,20 @@
DEBUGMODE = os.getenv("DEBUGMODE", "no").lower() == "yes"
HOST = os.getenv("HOST", None)
BROADCAST = os.getenv("BROADCAST", None)

# Set up broadcast address
if HOST and not BROADCAST:
BROADCAST = HOST.split('.')
BROADCAST[3] = '255'
BROADCAST = '.'.join(BROADCAST)
NETWORK = None

# If HOST specified, set up broadcast address and calculate network
if HOST:
if not BROADCAST:
BROADCAST = HOST.split('.')
BROADCAST[3] = '255'
BROADCAST = '.'.join(BROADCAST)
host_ip = ipaddress.IPv4Address(HOST)
broadcast_ip = ipaddress.IPv4Address(BROADCAST)
host_bits = int(host_ip)
broadcast_bits = int(broadcast_ip)
mask_length = 32 - (broadcast_bits - host_bits).bit_length()
NETWORK = str(ipaddress.IPv4Network(f"{host_ip}/{mask_length}", strict=False))

# Logging
log = logging.getLogger(__name__)
Expand Down Expand Up @@ -677,6 +686,8 @@ def api(port):
print(" Using Host IP: %s%s%s" % (cyan, HOST, dim))
if BROADCAST:
print(" Using Broadcast IP: %s%s%s" % (cyan, BROADCAST, dim))
if NETWORK:
print(" Using Network: %s%s%s" % (cyan, NETWORK, dim))
print(" UDP Ports: %s%d%s, %s%d%s, %s%d%s" % (cyan, UDPPORT, dim, cyan, UDPPORTS, dim, cyan, UDPPORTAPP, dim))
print(" TCP Port: %s%d%s" % (cyan, TCPPORT, dim))
print(" API Port: %s%d%s" % (cyan, APIPORT, dim))
Expand Down Expand Up @@ -719,7 +730,10 @@ def api(port):
# discover=True, wantips=None, wantids=None, snapshot=None, assume_yes=False, tuyadevices=[],
# maxdevices=0)
try:
found = scanner.devices(forcescan=True, verbose=False, discover=False, assume_yes=True, tuyadevices=tuyadevices)
if NETWORK:
found = scanner.devices(forcescan=[NETWORK], verbose=False, discover=False, assume_yes=True, tuyadevices=tuyadevices)
else:
found = scanner.devices(forcescan=True, verbose=False, discover=False, assume_yes=True, tuyadevices=tuyadevices)
except Exception as err:
log.error(f"Error during scanner.devices() {err}")
found = []
Expand Down

0 comments on commit 2b84315

Please sign in to comment.