Websockets
websockets
are a great way to add a two way instant data channel between server and client.
LNbits has a useful in built websocket tool. With a websocket client connect to (obv change somespecificid
) wss://demo.lnbits.com/api/v1/ws/somespecificid
(you can use an online websocket tester). Now make a get to https://demo.lnbits.com/api/v1/ws/somespecificid/somedata
. You can send data to that websocket by using from lnbits.core.services import websocketUpdater
and the function websocketUpdater("somespecificid", "somdata")
.
Example vue-js function for listening to the websocket:
initWs: async function () {
if (location.protocol !== 'http:') {
localUrl =
'wss://' +
document.domain +
':' +
location.port +
'/api/v1/ws/' +
self.item.id
} else {
localUrl =
'ws://' +
document.domain +
':' +
location.port +
'/api/v1/ws/' +
self.item.id
}
this.ws = new WebSocket(localUrl)
this.ws.addEventListener('message', async ({data}) => {
const res = JSON.parse(data.toString())
console.log(res)
})
},