Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Updated the MQTT component to optionally filter its messages by topic paths #1503

Open
wants to merge 1 commit into
base: develop
Choose a base branch
from

Conversation

JohnVidler
Copy link

@JohnVidler JohnVidler commented Jun 4, 2021

The current implementation of MQTT can turn in to a bit of a fire hose of data for situations where you only want some of the fields possible. This patch adds a filter function which inhibits certain topics from actually sending to the broker, instead they silently complete, doing nothing.

A single new configuration string has been added, into which a semicolon-delimited set of topic filters can be written allowing only topics which match these specifications to pass.

The topic filters use the same syntax as normal MQTT client subscriptions, so can use the + and # specifiers to indicate single, or multi-level paths.

An example path might be edge/fems33/channel/meter+/+ which would pull all metrics in meter0, meter1, etc. paths, but exclude any other topics.

THIS NEEDS TESTING - Please can someone with an otherwise working setup please check that this works, as I'm currently unable to, as I don't have access to our test hardware.

@JohnVidler JohnVidler marked this pull request as ready for review June 4, 2021 10:52
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant