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

  1. In Ihrem Brevo-Konto einloggen
  2. Zu Account & Plan > API-Schlüssel gehen
  3. Neuen API-Schlüssel generieren klicken
  4. Ihn “Tajo Integration” nennen
  5. Schlüssel kopieren und sicher aufbewahren
Terminal window
# In Umgebungsvariablen speichern
export BREVO_API_KEY="xkeysib-your-api-key-here"
export TAJO_WEBHOOK_SECRET="your-webhook-secret"

Tajo-Integration konfigurieren

In Ihrem Tajo-Dashboard:

  1. Zu Einstellungen > Integrationen gehen
  2. Brevo aus der Liste auswählen
  3. Ihren Brevo-API-Schlüssel eingeben
  4. 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 synchronisieren
async 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 synchronisieren
async 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-Upgrades
app.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-Endpunkt
app.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ösung
async 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

  1. Webhooks einrichten für Echtzeit-Synchronisierung
  2. E-Mail-Vorlagen erstellen für Treuekampagnen
  3. SMS-Automatisierung konfigurieren für dringende Benachrichtigungen
  4. Analytics einrichten zur Leistungsverfolgung

Support und Ressourcen

AI-Assistent

Hallo! Fragen Sie mich alles über die Dokumentation.

Kostenlos mit Brevo starten