Community Tip - Learn all about PTC Community Badges. Engage with PTC and see how many you can earn! X
Hi,
I'm actually regarding to make a WebSocket connection between ThingWorx and a WebApp using Angular Node.JS (17), the objective is to retrive and display data in real time on the web interface.
After looking the ThingWorx Documentation and looking at all post on the Forum, I was thinking "Is this really possible ?", so I'm here to see if some other developers have already done that before ?
Thank you for all future person will give me some answer to my question.
Solved! Go to Solution.
My understanding is you want to use a angular web app to display data that you get from Thingworx. And that you want to use a websocket connection so that ThingWorx pushes data to the web app.
You can't reuse the existing web socket of ThingWorx as it runs a proprietary protocol (AlwaysOn). Even if you manage to connect to it technically, it is not supported. You can either develop your own extension which runs its own Websocket and pushes data on DataChangeEvent, or you can embed a Thingworx mashup (e.g. as an iframe) into your Angular App.
As a third way you could also have TWX publish changes to e.g. an MQTT queue and subscribe your WebApp to it.
I would suggest using ThingWorx mashup with GetProperties (also uses Websocket and can push values to the UI), and embed the added features you want to accomplish with Angular into the Mashup with the Web Frame widget.
Similar discussion - "Websocket connection between Thingworx and a websocket-server": https://community.ptc.com/t5/ThingWorx-Developers/Websocket-connection-between-Thingworx-and-a-websocket-server/td-p/527361
My understanding is you want to use a angular web app to display data that you get from Thingworx. And that you want to use a websocket connection so that ThingWorx pushes data to the web app.
You can't reuse the existing web socket of ThingWorx as it runs a proprietary protocol (AlwaysOn). Even if you manage to connect to it technically, it is not supported. You can either develop your own extension which runs its own Websocket and pushes data on DataChangeEvent, or you can embed a Thingworx mashup (e.g. as an iframe) into your Angular App.
As a third way you could also have TWX publish changes to e.g. an MQTT queue and subscribe your WebApp to it.
I would suggest using ThingWorx mashup with GetProperties (also uses Websocket and can push values to the UI), and embed the added features you want to accomplish with Angular into the Mashup with the Web Frame widget.