-
Notifications
You must be signed in to change notification settings - Fork 54
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
Send messages from Elixir to Tortoise.Connection #131
Comments
Maybe just my state of mind right now, after a stressful morning, but unfortunately I am finding this request hard to follow. :-( You are talking about outgoing messages, right? Or are you talking about something else? I might have some ideas to help, but first I have to be able to understand the problem :-). |
That's quite alright, I can't explain all that well, but I tried. My initial problem was that receiving events from MQTT is a concern that you handle with functions in the Tortoise handler (i.e., implement the right The thing I did not notice right away is that sending a message is just a function call ( |
The module you use for your tortoise handler is supposed to do very little, because it is running in the tortoise controller process, which means that an error in this part of the code would result in a tortoise crash, and while the code is running the controller is blocked: While most MQTT connections are not high volume I recommend doing as little as possible in the tortoise controller, and just route the messages to a process where you have all your logic for your application. Would that work for you ? |
For myself[1], I ended up creating a process that receives subscribe requests from processes (e.g. scenic scenes, Phoenix live handlers, etc), and it routes the messages to the processes that have requested them. See https://github.com/brianmay/robotica-elixir/blob/master/robotica_plugins/lib/subscriptions.ex [2]. The tortoise handler is here: https://github.com/brianmay/robotica-elixir/blob/master/robotica/lib/robotica/client.ex#L84 It also keeps track on the last received message, and re-sends it on a new subscription. Ideally this probably should only happen for retained messages, but I couldn't work out how to tell them apart. For my use case all messages are retained. It also doesn't support wildcard subscriptions. I haven't needed them. Unfortunately, I couldn't get dynamic MQTT subscriptions to work reliably. See #130. So the mqtt subscriptions need to be hardwired into the initialization code. But regardless, this code still serves my purpose. The filtering of unwanted messages will occur in my code, not the mqtt server. If I ever got dynamic subscriptions working, I probably would want to listen to Thinking about what @gausby said, possible the Notes: [1] Code is "first working draft" status. It works, but readability probably can/should be improved now. |
Hi all,
I'm writing a system where I would like to process events coming from an MQTT server, through the Tortoise connection, into my regular Elixir code. From my regular Elixir code I would like to send commands back to the MQTT server.
So this would look something like this:
However, I notice that it doesn't seem possible to send messages from the application to the Tortoise connection handler.
I do know that you can manually send events directly to the connection using
Tortoise.publish/3
, but that, i think, splits the code concerned with MQTT communication in two. It would be nicer if all that logic would be contained within a single module.Currently the diagram looks more like this:
So perhaps adding support for
handle_info/2
or something would be useful?This is all under the assumption that I understand what I'm doing. I might as well be missing something?
The text was updated successfully, but these errors were encountered: