You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I know SSE and Websockets don't work well on serverless architecture such as Vercel, but I was hoping to host the areas that require these things on a stateful server, then the rest of the app remains in the Vercel environment.
I'm testing locally, and all seems well, but the /events request is throwing a CORS error. I have created a Svelte API with the OPTIONS verb setting it to allow everything essentially, but still getting the error. Do you know if SSE can work across domains?
EventCoordinator Service:
import type { RequestHandler } from './$types';
import { json } from '@sveltejs/kit';
import { produce } from 'sveltekit-sse';
import sessions from '$lib';
export const POST: RequestHandler = async ({ request }) => {
const sessionId = request.headers.get('X-User-ID') ?? '';
console.log('EVENTS REQUESTED FOR ', sessionId);
return produce(
async function start({ emit }) {
const cancel = (message?: string) => {
console.log('SSE Connection Cancelled');
if (message) {
console.error(message);
}
sessions.delete(sessionId);
};
if (!sessionId) {
cancel('Client Session Id not found');
}
// Give the session it's own emitter, also tells us the client is "online"
sessions.set(sessionId, emit);
return () => cancel();
},
{
// When client goes offline, remove their session
stop() {
if (!sessionId) {
return;
}
console.log('Stopping Session', sessionId);
sessions.delete(sessionId);
}
}
);
};
export const PUT: RequestHandler = async ({ request }) => {
const sessionId = request.headers.get('X-User-ID') ?? '';
console.log('MESSAGE SENT TO ', sessionId);
const { event, payload } = (await request.json()) as {
event: string;
payload: object;
};
const session = sessions.get(sessionId);
if (session) {
session(event, JSON.stringify(payload));
return json({}, { status: 202 });
} else {
return json({}, { status: 204 });
}
};
export const OPTIONS: RequestHandler = async ({ request }) => {
return new Response(null, {
status: 204,
headers: {
'Access-Control-Allow-Origin': '*',
'Access-Control-Allow-Headers': '*',
'Access-Control-Allow-Methods': 'POST, PUT, OPTIONS',
'Access-Control-Max-Age': '86400'
}
});
};
Hi there,
I know SSE and Websockets don't work well on serverless architecture such as Vercel, but I was hoping to host the areas that require these things on a stateful server, then the rest of the app remains in the Vercel environment.
I'm testing locally, and all seems well, but the /events request is throwing a CORS error. I have created a Svelte API with the OPTIONS verb setting it to allow everything essentially, but still getting the error. Do you know if SSE can work across domains?
EventCoordinator Service:
Vercel Service:
Console errors in Vercel service:
data:image/s3,"s3://crabby-images/47608/47608562c6678317d7296e2cbb907c6b62d5de8a" alt="image"
The text was updated successfully, but these errors were encountered: