bulk_sensor: New add_mux_endpoint() helper function in APIDumpHelper
Signed-off-by: Kevin O'Connor <kevin@koconnor.net>
This commit is contained in:
parent
ffd44c0219
commit
acde3720a4
|
@ -220,9 +220,9 @@ class ADXL345:
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(
|
self.api_dump = bulk_sensor.APIDumpHelper(
|
||||||
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
||||||
self.name = config.get_name().split()[-1]
|
self.name = config.get_name().split()[-1]
|
||||||
wh = self.printer.lookup_object('webhooks')
|
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
||||||
wh.register_mux_endpoint("adxl345/dump_adxl345", "sensor", self.name,
|
self.api_dump.add_mux_endpoint("adxl345/dump_adxl345", "sensor",
|
||||||
self._handle_dump_adxl345)
|
self.name, {'header': hdr})
|
||||||
def _build_config(self):
|
def _build_config(self):
|
||||||
cmdqueue = self.spi.get_command_queue()
|
cmdqueue = self.spi.get_command_queue()
|
||||||
self.query_adxl345_cmd = self.mcu.lookup_command(
|
self.query_adxl345_cmd = self.mcu.lookup_command(
|
||||||
|
@ -345,10 +345,6 @@ class ADXL345:
|
||||||
self._start_measurements()
|
self._start_measurements()
|
||||||
else:
|
else:
|
||||||
self._finish_measurements()
|
self._finish_measurements()
|
||||||
def _handle_dump_adxl345(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
def start_internal_client(self):
|
def start_internal_client(self):
|
||||||
cconn = self.api_dump.add_internal_client()
|
cconn = self.api_dump.add_internal_client()
|
||||||
return AccelQueryHelper(self.printer, cconn)
|
return AccelQueryHelper(self.printer, cconn)
|
||||||
|
|
|
@ -444,9 +444,9 @@ class Angle:
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(
|
self.api_dump = bulk_sensor.APIDumpHelper(
|
||||||
self.printer, self._api_update, self._api_startstop, 0.100)
|
self.printer, self._api_update, self._api_startstop, 0.100)
|
||||||
self.name = config.get_name().split()[1]
|
self.name = config.get_name().split()[1]
|
||||||
wh = self.printer.lookup_object('webhooks')
|
api_resp = {'header': ('time', 'angle')}
|
||||||
wh.register_mux_endpoint("angle/dump_angle", "sensor", self.name,
|
self.api_dump.add_mux_endpoint("angle/dump_angle", "sensor", self.name,
|
||||||
self._handle_dump_angle)
|
api_resp)
|
||||||
def _build_config(self):
|
def _build_config(self):
|
||||||
freq = self.mcu.seconds_to_clock(1.)
|
freq = self.mcu.seconds_to_clock(1.)
|
||||||
while float(TCODE_ERROR << self.time_shift) / freq < 0.002:
|
while float(TCODE_ERROR << self.time_shift) / freq < 0.002:
|
||||||
|
@ -553,10 +553,6 @@ class Angle:
|
||||||
self._start_measurements()
|
self._start_measurements()
|
||||||
else:
|
else:
|
||||||
self._finish_measurements()
|
self._finish_measurements()
|
||||||
def _handle_dump_angle(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('time', 'angle')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
def start_internal_client(self):
|
def start_internal_client(self):
|
||||||
return self.api_dump.add_internal_client()
|
return self.api_dump.add_internal_client()
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@ class APIDumpHelper:
|
||||||
self.update_interval = update_interval
|
self.update_interval = update_interval
|
||||||
self.update_timer = None
|
self.update_timer = None
|
||||||
self.clients = {}
|
self.clients = {}
|
||||||
|
self.webhooks_start_resp = {}
|
||||||
|
# Periodic batch processing
|
||||||
def _stop(self):
|
def _stop(self):
|
||||||
self.clients.clear()
|
self.clients.clear()
|
||||||
reactor = self.printer.get_reactor()
|
reactor = self.printer.get_reactor()
|
||||||
|
@ -52,16 +54,6 @@ class APIDumpHelper:
|
||||||
systime = reactor.monotonic()
|
systime = reactor.monotonic()
|
||||||
waketime = systime + self.update_interval
|
waketime = systime + self.update_interval
|
||||||
self.update_timer = reactor.register_timer(self._update, waketime)
|
self.update_timer = reactor.register_timer(self._update, waketime)
|
||||||
def add_client(self, web_request):
|
|
||||||
cconn = web_request.get_client_connection()
|
|
||||||
template = web_request.get_dict('response_template', {})
|
|
||||||
self.clients[cconn] = template
|
|
||||||
self._start()
|
|
||||||
def add_internal_client(self):
|
|
||||||
cconn = InternalDumpClient()
|
|
||||||
self.clients[cconn] = {}
|
|
||||||
self._start()
|
|
||||||
return cconn
|
|
||||||
def _update(self, eventtime):
|
def _update(self, eventtime):
|
||||||
try:
|
try:
|
||||||
msg = self.data_cb(eventtime)
|
msg = self.data_cb(eventtime)
|
||||||
|
@ -80,6 +72,23 @@ class APIDumpHelper:
|
||||||
tmp['params'] = msg
|
tmp['params'] = msg
|
||||||
cconn.send(tmp)
|
cconn.send(tmp)
|
||||||
return eventtime + self.update_interval
|
return eventtime + self.update_interval
|
||||||
|
# Internal clients
|
||||||
|
def add_internal_client(self):
|
||||||
|
cconn = InternalDumpClient()
|
||||||
|
self.clients[cconn] = {}
|
||||||
|
self._start()
|
||||||
|
return cconn
|
||||||
|
# Webhooks registration
|
||||||
|
def _add_api_client(self, web_request):
|
||||||
|
cconn = web_request.get_client_connection()
|
||||||
|
template = web_request.get_dict('response_template', {})
|
||||||
|
self.clients[cconn] = template
|
||||||
|
self._start()
|
||||||
|
web_request.send(self.webhooks_start_resp)
|
||||||
|
def add_mux_endpoint(self, path, key, value, webhooks_start_resp):
|
||||||
|
self.webhooks_start_resp = webhooks_start_resp
|
||||||
|
wh = self.printer.lookup_object('webhooks')
|
||||||
|
wh.register_mux_endpoint(path, key, value, self._add_api_client)
|
||||||
|
|
||||||
# An "internal webhooks" wrapper for using APIDumpHelper internally
|
# An "internal webhooks" wrapper for using APIDumpHelper internally
|
||||||
class InternalDumpClient:
|
class InternalDumpClient:
|
||||||
|
|
|
@ -66,9 +66,9 @@ class LIS2DW:
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(
|
self.api_dump = bulk_sensor.APIDumpHelper(
|
||||||
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
||||||
self.name = config.get_name().split()[-1]
|
self.name = config.get_name().split()[-1]
|
||||||
wh = self.printer.lookup_object('webhooks')
|
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
||||||
wh.register_mux_endpoint("lis2dw/dump_lis2dw", "sensor", self.name,
|
self.api_dump.add_mux_endpoint("lis2dw/dump_lis2dw", "sensor",
|
||||||
self._handle_dump_lis2dw)
|
self.name, {'header': hdr})
|
||||||
|
|
||||||
def _build_config(self):
|
def _build_config(self):
|
||||||
cmdqueue = self.spi.get_command_queue()
|
cmdqueue = self.spi.get_command_queue()
|
||||||
|
@ -193,10 +193,6 @@ class LIS2DW:
|
||||||
self._start_measurements()
|
self._start_measurements()
|
||||||
else:
|
else:
|
||||||
self._finish_measurements()
|
self._finish_measurements()
|
||||||
def _handle_dump_lis2dw(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
def start_internal_client(self):
|
def start_internal_client(self):
|
||||||
cconn = self.api_dump.add_internal_client()
|
cconn = self.api_dump.add_internal_client()
|
||||||
return adxl345.AccelQueryHelper(self.printer, cconn)
|
return adxl345.AccelQueryHelper(self.printer, cconn)
|
||||||
|
|
|
@ -14,9 +14,9 @@ class DumpStepper:
|
||||||
self.mcu_stepper = mcu_stepper
|
self.mcu_stepper = mcu_stepper
|
||||||
self.last_api_clock = 0
|
self.last_api_clock = 0
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(printer, self._api_update)
|
self.api_dump = bulk_sensor.APIDumpHelper(printer, self._api_update)
|
||||||
wh = self.printer.lookup_object('webhooks')
|
api_resp = {'header': ('interval', 'count', 'add')}
|
||||||
wh.register_mux_endpoint("motion_report/dump_stepper", "name",
|
self.api_dump.add_mux_endpoint("motion_report/dump_stepper", "name",
|
||||||
mcu_stepper.get_name(), self._add_api_client)
|
mcu_stepper.get_name(), api_resp)
|
||||||
def get_step_queue(self, start_clock, end_clock):
|
def get_step_queue(self, start_clock, end_clock):
|
||||||
mcu_stepper = self.mcu_stepper
|
mcu_stepper = self.mcu_stepper
|
||||||
res = []
|
res = []
|
||||||
|
@ -62,10 +62,6 @@ class DumpStepper:
|
||||||
"start_mcu_position": mcu_pos, "step_distance": step_dist,
|
"start_mcu_position": mcu_pos, "step_distance": step_dist,
|
||||||
"first_clock": first_clock, "first_step_time": first_time,
|
"first_clock": first_clock, "first_step_time": first_time,
|
||||||
"last_clock": last_clock, "last_step_time": last_time}
|
"last_clock": last_clock, "last_step_time": last_time}
|
||||||
def _add_api_client(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('interval', 'count', 'add')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
|
|
||||||
NEVER_TIME = 9999999999999999.
|
NEVER_TIME = 9999999999999999.
|
||||||
|
|
||||||
|
@ -77,9 +73,10 @@ class DumpTrapQ:
|
||||||
self.trapq = trapq
|
self.trapq = trapq
|
||||||
self.last_api_msg = (0., 0.)
|
self.last_api_msg = (0., 0.)
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(printer, self._api_update)
|
self.api_dump = bulk_sensor.APIDumpHelper(printer, self._api_update)
|
||||||
wh = self.printer.lookup_object('webhooks')
|
api_resp = {'header': ('time', 'duration', 'start_velocity',
|
||||||
wh.register_mux_endpoint("motion_report/dump_trapq", "name", name,
|
'acceleration', 'start_position', 'direction')}
|
||||||
self._add_api_client)
|
self.api_dump.add_mux_endpoint("motion_report/dump_trapq", "name", name,
|
||||||
|
api_resp)
|
||||||
def extract_trapq(self, start_time, end_time):
|
def extract_trapq(self, start_time, end_time):
|
||||||
ffi_main, ffi_lib = chelper.get_ffi()
|
ffi_main, ffi_lib = chelper.get_ffi()
|
||||||
res = []
|
res = []
|
||||||
|
@ -130,11 +127,6 @@ class DumpTrapQ:
|
||||||
return {}
|
return {}
|
||||||
self.last_api_msg = d[-1]
|
self.last_api_msg = d[-1]
|
||||||
return {"data": d}
|
return {"data": d}
|
||||||
def _add_api_client(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('time', 'duration', 'start_velocity', 'acceleration',
|
|
||||||
'start_position', 'direction')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
|
|
||||||
STATUS_REFRESH_TIME = 0.250
|
STATUS_REFRESH_TIME = 0.250
|
||||||
|
|
||||||
|
|
|
@ -83,9 +83,9 @@ class MPU9250:
|
||||||
self.api_dump = bulk_sensor.APIDumpHelper(
|
self.api_dump = bulk_sensor.APIDumpHelper(
|
||||||
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
self.printer, self._api_update, self._api_startstop, API_UPDATES)
|
||||||
self.name = config.get_name().split()[-1]
|
self.name = config.get_name().split()[-1]
|
||||||
wh = self.printer.lookup_object('webhooks')
|
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
||||||
wh.register_mux_endpoint("mpu9250/dump_mpu9250", "sensor", self.name,
|
self.api_dump.add_mux_endpoint("mpu9250/dump_mpu9250", "sensor",
|
||||||
self._handle_dump_mpu9250)
|
self.name, {'header': hdr})
|
||||||
def _build_config(self):
|
def _build_config(self):
|
||||||
cmdqueue = self.i2c.get_command_queue()
|
cmdqueue = self.i2c.get_command_queue()
|
||||||
self.mcu.add_config_cmd("config_mpu9250 oid=%d i2c_oid=%d"
|
self.mcu.add_config_cmd("config_mpu9250 oid=%d i2c_oid=%d"
|
||||||
|
@ -207,10 +207,6 @@ class MPU9250:
|
||||||
self._start_measurements()
|
self._start_measurements()
|
||||||
else:
|
else:
|
||||||
self._finish_measurements()
|
self._finish_measurements()
|
||||||
def _handle_dump_mpu9250(self, web_request):
|
|
||||||
self.api_dump.add_client(web_request)
|
|
||||||
hdr = ('time', 'x_acceleration', 'y_acceleration', 'z_acceleration')
|
|
||||||
web_request.send({'header': hdr})
|
|
||||||
def start_internal_client(self):
|
def start_internal_client(self):
|
||||||
cconn = self.api_dump.add_internal_client()
|
cconn = self.api_dump.add_internal_client()
|
||||||
return adxl345.AccelQueryHelper(self.printer, cconn)
|
return adxl345.AccelQueryHelper(self.printer, cconn)
|
||||||
|
|
Loading…
Reference in New Issue