mirror of
https://github.com/JoelBender/bacpypes
synced 2025-09-28 22:15:23 +08:00
read the BDT or FDT (issue #446)
This commit is contained in:
parent
27ab4f18aa
commit
7cd1a1a175
103
samples/ReadBBMD.py
Executable file
103
samples/ReadBBMD.py
Executable file
|
@ -0,0 +1,103 @@
|
|||
#!/usr/bin/env python
|
||||
|
||||
"""
|
||||
This application presents a 'console' prompt to the user asking for read commands
|
||||
to read the BDT and FDT from a BBMD.
|
||||
"""
|
||||
|
||||
from bacpypes.debugging import bacpypes_debugging, ModuleLogger
|
||||
from bacpypes.consolecmd import ConsoleCmd
|
||||
from bacpypes.consolelogging import ArgumentParser
|
||||
|
||||
from bacpypes.comm import bind, Client
|
||||
from bacpypes.core import run, enable_sleeping
|
||||
|
||||
from bacpypes.pdu import Address
|
||||
from bacpypes.bvll import ReadBroadcastDistributionTable, \
|
||||
ReadBroadcastDistributionTableAck, ReadForeignDeviceTable, \
|
||||
ReadForeignDeviceTableAck, Result
|
||||
from bacpypes.bvllservice import AnnexJCodec, UDPMultiplexer
|
||||
|
||||
# some debugging
|
||||
_debug = 0
|
||||
_log = ModuleLogger(globals())
|
||||
|
||||
# globals
|
||||
this_application = None
|
||||
|
||||
|
||||
@bacpypes_debugging
|
||||
class ReadBBMDConsoleClient(ConsoleCmd, Client):
|
||||
def do_readbdt(self, args):
|
||||
"""readbdt <addr>"""
|
||||
args = args.split()
|
||||
if _debug:
|
||||
ReadBBMDConsoleClient._debug("do_readbdt %r", args)
|
||||
|
||||
# build a request and send it downstream
|
||||
read_bdt = ReadBroadcastDistributionTable(destination=Address(args[0]))
|
||||
self.request(read_bdt)
|
||||
|
||||
def do_readfdt(self, args):
|
||||
"""readfdt <addr>"""
|
||||
args = args.split()
|
||||
if _debug:
|
||||
ReadBBMDConsoleClient._debug("do_readfdt %r", args)
|
||||
|
||||
# build a request and send it downstream
|
||||
read_fdt = ReadForeignDeviceTable(destination=Address(args[0]))
|
||||
self.request(read_fdt)
|
||||
|
||||
def confirmation(self, pdu):
|
||||
"""Filter for the acks and errors."""
|
||||
if _debug:
|
||||
ReadBBMDConsoleClient._debug("confirmation %r", pdu)
|
||||
|
||||
if isinstance(pdu, (ReadBroadcastDistributionTableAck, ReadForeignDeviceTableAck, Result)):
|
||||
pdu.debug_contents()
|
||||
|
||||
|
||||
def main():
|
||||
global this_application
|
||||
|
||||
# parse the command line arguments
|
||||
parser = ArgumentParser(description=__doc__)
|
||||
parser.add_argument(
|
||||
"local_address",
|
||||
help="IPv4 address",
|
||||
)
|
||||
args = parser.parse_args()
|
||||
|
||||
if _debug:
|
||||
_log.debug("initialization")
|
||||
_log.debug(" - args: %r", args)
|
||||
|
||||
local_address = Address(args.local_address)
|
||||
if _debug:
|
||||
_log.debug(" - local_address: %r", local_address)
|
||||
|
||||
# make a console
|
||||
this_console = ReadBBMDConsoleClient()
|
||||
if _debug:
|
||||
_log.debug(" - this_console: %r", this_console)
|
||||
|
||||
# create an Annex J codec, bound to the Annex J server
|
||||
# of the UDP multiplexer
|
||||
annexj = AnnexJCodec()
|
||||
mux = UDPMultiplexer(local_address)
|
||||
|
||||
# bind the layers
|
||||
bind(this_console, annexj, mux.annexJ)
|
||||
|
||||
# enable sleeping will help with threads
|
||||
enable_sleeping()
|
||||
|
||||
_log.debug("running")
|
||||
|
||||
run()
|
||||
|
||||
_log.debug("fini")
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
Loading…
Reference in New Issue
Block a user