Tajo-Brevo-Integrationsleitfaden
Dieser umfassende Leitfaden führt Sie durch die Integration Ihrer Tajo-Treueplattform mit Brevo, um leistungsstarke automatisierte Customer-Engagement-Kampagnen zu erstellen.
Überblick
Die Tajo-Brevo-Integration ermöglicht Ihnen:
- Kundendaten in Echtzeit synchronisieren zwischen den Plattformen
- Treuekampagnen automatisieren basierend auf Kundenverhalten
- Engagement verfolgen über E-Mail, SMS und WhatsApp
- Kunden segmentieren nach Treuestufe und Kaufverhalten
- Personalisierte Nachrichten auslösen für wichtige Treue-Events
Voraussetzungen
Vor dem Start der Integration sicherstellen, dass Sie haben:
- Tajo-Konto mit konfiguriertem Treueprogramm
- Brevo-Konto mit API-Zugriff
- Gültige API-Schlüssel für beide Plattformen
- Webhook-Endpunkte für Echtzeit-Synchronisierung eingerichtet
- SSL-Zertifikat für sichere Datenübertragung
Schritt 1: Authentifizierungs-Einrichtung
Brevo-API-Schlüssel generieren
- In Ihrem Brevo-Konto einloggen
- Zu Account & Plan > API-Schlüssel gehen
- Neuen API-Schlüssel generieren klicken
- Ihn “Tajo Integration” nennen
- Schlüssel kopieren und sicher aufbewahren
# In Umgebungsvariablen speichernexport BREVO_API_KEY="xkeysib-your-api-key-here"export TAJO_WEBHOOK_SECRET="your-webhook-secret"Tajo-Integration konfigurieren
In Ihrem Tajo-Dashboard:
- Zu Einstellungen > Integrationen gehen
- Brevo aus der Liste auswählen
- Ihren Brevo-API-Schlüssel eingeben
- Synchronisierungseinstellungen konfigurieren
{ "brevo_api_key": "xkeysib-your-api-key-here", "sync_frequency": "real-time", "sync_contacts": true, "sync_orders": true, "sync_events": true, "loyalty_attributes": [ "LOYALTY_POINTS", "LOYALTY_TIER", "TOTAL_SPENT", "LAST_PURCHASE" ]}Schritt 2: Kundendatensynchronisierung
Kontakt-Sync-Konfiguration
Automatische Kontaktsynchronisierung einrichten, um Kundendaten aktuell zu halten:
// Kunde bei Registrierung synchronisierenasync function syncCustomerToBrevo(customer) { const brevoData = { email: customer.email, attributes: { FIRSTNAME: customer.firstName, LASTNAME: customer.lastName, PHONE: customer.phone, LOYALTY_ID: customer.loyaltyId, LOYALTY_POINTS: customer.points, LOYALTY_TIER: customer.tier, SIGNUP_DATE: customer.createdAt, TOTAL_SPENT: customer.totalSpent, PREFERRED_CATEGORIES: customer.categories, BIRTHDAY: customer.birthday }, listIds: [getListForTier(customer.tier)] };
const response = await fetch('https://api.brevo.com/v3/contacts', { method: 'POST', headers: { 'Content-Type': 'application/json', 'api-key': process.env.BREVO_API_KEY }, body: JSON.stringify(brevoData) });
return response.json();}Kauf-Event-Synchronisierung
Käufe automatisch synchronisieren, um Treuekampagnen auszulösen:
// Bestellabschluss synchronisierenasync function syncOrderToBrevo(order, customer) { // Bestellung in Brevo erstellen const orderData = { id: order.id, email: customer.email, products: order.items.map(item => ({ id: item.productId, name: item.name, quantity: item.quantity, price: item.price, category: item.category })), revenue: order.total, date: order.createdAt };
await fetch('https://api.brevo.com/v3/ecommerce/orders', { method: 'POST', headers: { 'Content-Type': 'application/json', 'api-key': process.env.BREVO_API_KEY }, body: JSON.stringify(orderData) });
// Treue-Event erstellen const eventData = { email: customer.email, event: 'Purchase Completed', properties: { order_id: order.id, amount: order.total, points_earned: order.pointsEarned, loyalty_tier: customer.tier, tier_upgraded: order.tierUpgraded, products: order.items.map(i => i.name).join(', ') } };
await fetch('https://api.brevo.com/v3/events', { method: 'POST', headers: { 'Content-Type': 'application/json', 'api-key': process.env.BREVO_API_KEY }, body: JSON.stringify(eventData) });}Schritt 3: Automatisierte Kampagnen einrichten
Willkommenskampagne für neue Kunden
Eine automatisierte Willkommensserie für neue Treuemitglieder erstellen:
{ "campaign_name": "Tajo Loyalty Welcome Series", "trigger": { "event": "Contact Created", "conditions": { "LOYALTY_ID": "exists", "SIGNUP_DATE": "today" } }, "emails": [ { "delay": "immediate", "template_id": 101, "subject": "Welcome to Tajo Loyalty! Here's your {{params.welcome_bonus}} points bonus", "params": { "welcome_bonus": "500", "loyalty_tier": "Bronze", "next_tier_points": "1000" } }, { "delay": "3 days", "template_id": 102, "subject": "Don't forget to use your {{params.welcome_bonus}} bonus points!" }, { "delay": "1 week", "template_id": 103, "subject": "Here's how to earn points faster with Tajo" } ]}Stufen-Upgrade-Kampagne
Stufen-Upgrades automatisch feiern:
// Webhook-Handler für Stufen-Upgradesapp.post('/webhook/tier-upgrade', (req, res) => { const { customer, previousTier, newTier } = req.body;
const campaignData = { email: customer.email, template_id: getTierUpgradeTemplate(newTier), params: { customer_name: customer.firstName, new_tier: newTier, previous_tier: previousTier, new_benefits: getTierBenefits(newTier), points_balance: customer.points } };
// Glückwunsch-E-Mail senden sendBrevoEmail(campaignData);
// Zur stufenspezifischen Liste hinzufügen addToBrevoList(customer.email, getTierListId(newTier));
res.status(200).json({ success: true });});Schritt 4: Treue-Event-Tracking
Wichtige zu verfolgende Events
Tracking für diese wesentlichen Treue-Events einrichten:
const loyaltyEvents = { // Konto-Events 'Account Created': { properties: ['signup_source', 'referral_code', 'welcome_bonus'] }, 'Profile Updated': { properties: ['updated_fields', 'marketing_consent'] },
// Kauf-Events 'Purchase Completed': { properties: ['order_total', 'points_earned', 'loyalty_tier', 'products'] }, 'Product Returned': { properties: ['return_reason', 'points_deducted', 'refund_amount'] },
// Treue-Events 'Points Earned': { properties: ['points_amount', 'earning_reason', 'total_balance'] }, 'Points Redeemed': { properties: ['points_used', 'reward_type', 'remaining_balance'] }, 'Tier Upgraded': { properties: ['previous_tier', 'new_tier', 'upgrade_benefits'] },
// Engagement-Events 'Email Opened': { properties: ['campaign_type', 'subject_line', 'device'] }, 'Reward Browsed': { properties: ['reward_category', 'reward_name', 'points_required'] }, 'Referral Made': { properties: ['referral_method', 'referee_email', 'referral_bonus'] }};Event-Tracking-Implementierung
class TajoBrevoEventTracker { constructor(apiKey) { this.apiKey = apiKey; this.baseUrl = 'https://api.brevo.com/v3'; }
async trackEvent(customerEmail, eventName, properties = {}) { const eventData = { email: customerEmail, event: eventName, properties: { timestamp: new Date().toISOString(), source: 'tajo_platform', ...properties } };
try { const response = await fetch(`${this.baseUrl}/events`, { method: 'POST', headers: { 'Content-Type': 'application/json', 'api-key': this.apiKey }, body: JSON.stringify(eventData) });
if (!response.ok) { throw new Error(`Event tracking failed: ${response.statusText}`); }
return await response.json(); } catch (error) { console.error('Brevo event tracking error:', error); throw error; } }
// Hilfsmethoden für häufige Events async trackPurchase(customer, order) { return this.trackEvent(customer.email, 'Purchase Completed', { order_id: order.id, order_total: order.total, currency: order.currency, points_earned: order.pointsEarned, loyalty_tier: customer.tier, items_count: order.items.length, first_purchase: customer.orderCount === 1 }); }
async trackTierUpgrade(customer, previousTier) { return this.trackEvent(customer.email, 'Tier Upgraded', { previous_tier: previousTier, new_tier: customer.tier, points_balance: customer.points, benefits_unlocked: getTierBenefits(customer.tier), upgrade_date: new Date().toISOString() }); }}Schritt 5: Segmentierungsstrategie
Kundensegmente
Gezielte Segmente in Brevo für personalisierte Kampagnen erstellen:
const loyaltySegments = [ // Stufenbasierte Segmente { name: "Bronze Members", conditions: { LOYALTY_TIER: "Bronze" }, campaigns: ["tier_upgrade_promotion", "engagement_boost"] }, { name: "Silver Members", conditions: { LOYALTY_TIER: "Silver" }, campaigns: ["premium_offers", "early_access"] }, { name: "Gold Members", conditions: { LOYALTY_TIER: "Gold" }, campaigns: ["vip_treatment", "exclusive_rewards"] }, { name: "Platinum Members", conditions: { LOYALTY_TIER: "Platinum" }, campaigns: ["luxury_experiences", "personal_offers"] },
// Verhaltensbasierte Segmente { name: "High Spenders", conditions: { TOTAL_SPENT: ">1000" }, campaigns: ["luxury_catalog", "big_spender_rewards"] }, { name: "Frequent Shoppers", conditions: { PURCHASE_FREQUENCY: "weekly" }, campaigns: ["convenience_offers", "bulk_discounts"] }, { name: "At-Risk Customers", conditions: { LAST_PURCHASE: ">90 days" }, campaigns: ["win_back", "special_incentives"] }, { name: "Birthday Month", conditions: { BIRTHDAY: "this_month" }, campaigns: ["birthday_specials", "bonus_points"] }];Schritt 6: Testen und Überwachen
Integrations-Test-Checkliste
- Kontakt-Sync: Neue Kunden erscheinen in Brevo
- Bestellungs-Sync: Käufe lösen Events korrekt aus
- Event-Tracking: Alle Treue-Events werden aufgezeichnet
- Kampagnen-Trigger: Automatisierte E-Mails werden korrekt gesendet
- Segmentierung: Kunden bewegen sich korrekt zwischen Listen
- Webhook-Zustellung: Echtzeit-Synchronisierung funktioniert zuverlässig
Überwachungs-Setup
// Healthcheck-Endpunktapp.get('/integration/health', async (req, res) => { const checks = { brevo_api: await checkBrevoConnection(), webhook_delivery: await checkWebhookDelivery(), event_tracking: await checkEventTracking(), campaign_triggers: await checkCampaignTriggers() };
const allHealthy = Object.values(checks).every(check => check.status === 'ok');
res.status(allHealthy ? 200 : 503).json({ status: allHealthy ? 'healthy' : 'degraded', checks, timestamp: new Date().toISOString() });});Häufige Probleme beheben
API-Ratenbegrenzungen
Brevo hat Ratenbegrenzungen – Wiederholungslogik implementieren:
async function makeBrevoRequest(url, options, retries = 3) { try { const response = await fetch(url, options);
if (response.status === 429) { const retryAfter = response.headers.get('Retry-After') || 60; await new Promise(resolve => setTimeout(resolve, retryAfter * 1000)); return makeBrevoRequest(url, options, retries - 1); }
return response; } catch (error) { if (retries > 0) { await new Promise(resolve => setTimeout(resolve, 5000)); return makeBrevoRequest(url, options, retries - 1); } throw error; }}Datensynchronisierungsprobleme
Synchronisierungskonflikte überwachen und lösen:
// Synchronisierungskonflikt-Auflösungasync function resolveSyncConflict(tajoData, brevoData) { // Aktuellsten Zeitstempel als Quelle der Wahrheit verwenden const tajoUpdated = new Date(tajoData.updatedAt); const brevoUpdated = new Date(brevoData.modifiedAt);
if (tajoUpdated > brevoUpdated) { // Brevo mit Tajo-Daten aktualisieren await updateBrevoContact(brevoData.id, tajoData); } else { // Tajo mit Brevo-Daten aktualisieren await updateTajoCustomer(tajoData.id, brevoData); }}Nächste Schritte
- Webhooks einrichten für Echtzeit-Synchronisierung
- E-Mail-Vorlagen erstellen für Treuekampagnen
- SMS-Automatisierung konfigurieren für dringende Benachrichtigungen
- Analytics einrichten zur Leistungsverfolgung
Support und Ressourcen
- Integrations-Support: [email protected]
- Brevo API-Dokumentation: api.brevo.com
- Beispielcode-Repository: github.com/tajo/brevo-integration
- Community-Forum: community.tajo.com