OAuth 2.0
OAuth 2.0 bietet sichere, tokenbasierte Authentifizierung fuer Drittanbieter-Anwendungen, die im Namen von Benutzern auf Brevo zugreifen.
OAuth-Ablauf im Ueberblick
- Autorisierungsanfrage: Benutzer zu Brevo weiterleiten
- Benutzerautorisierung: Benutzer erteilt Berechtigungen
- Autorisierungscode: Brevo leitet mit Code zurueck
- Zugriffstoken-Austausch: Code gegen Tokens eintauschen
- API-Zugriff: Zugriffstoken fuer Anfragen verwenden
Autorisierungsendpunkt
https://app.brevo.com/oauth/authorize? response_type=code& client_id=YOUR_CLIENT_ID& redirect_uri=YOUR_REDIRECT_URI& scope=email%20contacts& state=random_stringToken-Austausch
curl -X POST "https://api.brevo.com/v3/oauth/token" \ -H "Content-Type: application/x-www-form-urlencoded" \ -d "grant_type=authorization_code&code=AUTH_CODE&client_id=YOUR_CLIENT_ID&client_secret=YOUR_CLIENT_SECRET&redirect_uri=YOUR_REDIRECT_URI"Verwendung des Zugriffstokens
const response = await fetch('https://api.brevo.com/v3/account', { headers: { 'Authorization': 'Bearer YOUR_ACCESS_TOKEN', 'Accept': 'application/json' }});Berechtigungsbereiche (Scopes)
email: Transaktionale E-Mails sendencontacts: Kontakte und Listen verwaltencampaigns: Kampagnen erstellen und sendensms: SMS-Nachrichten sendenwebhooks: Webhooks verwalten
Token-Aktualisierung
const refreshToken = async () => { const response = await fetch('https://api.brevo.com/v3/oauth/token', { method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, body: new URLSearchParams({ grant_type: 'refresh_token', refresh_token: 'YOUR_REFRESH_TOKEN', client_id: 'YOUR_CLIENT_ID', client_secret: 'YOUR_CLIENT_SECRET' }) }); return response.json();};