Mercure-Hub: Aan de slag met Mercure-hub
Deze documentatie maakt deel uit van de Aan de slag-gids. Bekijk de volledige gids hier: Hoe te beginnen met Mercure-hub.
👋 Welkom bij de Stackhero-documentatie!
Stackhero biedt een kant-en-klare Mercure-Hub cloud oplossing die tal van voordelen biedt, waaronder:
- Onbeperkte verzoeken en berichtgroottes.
- Aanpasbare domeinnaam beveiligd met HTTPS (bijvoorbeeld, https://real-time.uw-bedrijf.com).
- Moeiteloze updates met slechts één klik.
- Optimale prestaties en robuuste beveiliging aangedreven door een privé en dedicated VM.
- Beschikbaar in 🇪🇺 Europa en 🇺🇸 USA.
Bespaar tijd en vereenvoudig uw leven: het kost slechts 5 minuten om de Mercure-Hub cloud hosting oplossing van Stackhero te proberen!
Aan de clientzijde (je front-end) is eenvoudige JavaScript-code die gebruikmaakt van de HTML5 SSE API alles wat je nodig hebt.
Opmerking: In dit voorbeeld is de abonnee niet geauthenticeerd. Om dit voorbeeld te laten werken, moet je anonieme abonnees toestaan op het Stackhero-dashboard.
const endpoint = '<XXXXXX>.stackhero-network.com';
const url = new URL('https://' + endpoint + '/.well-known/mercure');
// Voeg onderwerpen toe om naar te luisteren
url.searchParams.append('topic', `https://${endpoint}/users/1234`);
url.searchParams.append('topic', `https://${endpoint}/books/1`);
const eventSource = new EventSource(url);
// De callback wordt aangeroepen elke keer dat een update wordt gepubliceerd
eventSource.onmessage = e => console.log(e);
Aan de serverzijde (je back-end), wanneer je een update wilt verzenden, stuur je eenvoudig een POST-verzoek naar de Mercure-hub API. Hieronder is een voorbeeld met Node.js samen met de JsonWebToken en Request bibliotheken:
const jwt = require('jsonwebtoken');
const request = require('request');
const endpoint = '<XXXXXX>.stackhero-network.com';
const publisherJwtKey = '<your publisher JWT key>';
// Definieer de gegevens om te verzenden
const data = {
// Het onderwerp waar de gegevens naar worden gepusht
topic: `https://${endpoint}/books/1`,
// De gegevens die naar het onderwerp worden verzonden
data: JSON.stringify({
available: false,
date: new Date()
})
};
// Genereer de bearer token
const bearer = jwt.sign(
{ mercure: { publish: [ data.topic ] } },
publisherJwtKey,
{
expiresIn: 60, // Token verloopt in één minuut
noTimestamp: true // Geen 'uitgegeven op' tijdstempel opnemen om "Token gebruikt voordat uitgegeven" fouten te voorkomen
}
);
// Stuur de gegevens naar Mercure-hub zodat het de update naar clients verzendt
request.post(
{
url: `https://${endpoint}/.well-known/mercure`,
auth: { bearer },
form: data
},
(err, res) => err ? console.error(err) : console.log(res)
);
Dat is alles! Je hebt nu een abonnee aan de front-end en een uitgever aan de back-end die naadloos samenwerken.