I recently completed an app that simulates Robert's Rules by having each user's client emit event. I did this through the javascript EventSource which works perfectly when hosted locally. However, when trying to host it on the web, I ran into a million issues.
Here is a snapshot of the code:
onMount(() => {
const source = new EventSource(`/rooms/${roomId}/activity`, {
withCredentials: false
});
const event = SSEvents[roomId as keyof typeof SSEvents];
source.addEventListener(event, (e) => {
const message = JSON.parse(e.data);
const membername: string = message.name;
delete message.name;
if (message.type === 'set') {
messageStore.update(($messageStore) => $messageStore.set(membername, message));
if (membername === $user?.toString()) {
selectedValue = message.status;
}
}
if (message.type === 'delete') {
messageStore.update(($messageStore) => {
$messageStore.delete(membername);
return $messageStore;
});
}
});
return () => {
source.close();
};
});
How can I host a SSE app on the web?
It is not possible to use sse on vercel, netlify or cloudflare because these providers are serverless. The server will not remain on and any request will timeout after 10 secs. They might have implemented protection when the response has the stream content type
You will have to build your application with the node adapter and host it on a non serverless provider.