Guia de Integração Tajo-Brevo
Este guia completo orienta-o através da integração da sua plataforma de fidelidade Tajo com o Brevo para criar campanhas de envolvimento com clientes poderosas e automatizadas.
Visão Geral
A integração Tajo-Brevo permite-lhe:
- Sincronizar dados de clientes em tempo real entre plataformas
- Automatizar campanhas de fidelidade com base no comportamento do cliente
- Rastrear envolvimento por e-mail, SMS e WhatsApp
- Segmentar clientes por nível de fidelidade e comportamento de compra
- Acionar mensagens personalizadas para eventos chave de fidelidade
Pré-requisitos
Antes de iniciar a integração, certifique-se de que tem:
- Conta Tajo com programa de fidelidade configurado
- Conta Brevo com acesso à API
- Chaves de API válidas para ambas as plataformas
- Endpoints de webhook configurados para sincronização em tempo real
- Certificado SSL para transmissão segura de dados
Passo 1: Configuração de Autenticação
Gerar Chave de API Brevo
- Faça login na sua conta Brevo
- Aceda a Conta e Plano > Chaves de API
- Clique em Gerar uma nova chave de API
- Nomeie-a “Integração Tajo”
- Copie e guarde a chave em segurança
# Guardar em variáveis de ambienteexport BREVO_API_KEY="xkeysib-your-api-key-here"export TAJO_WEBHOOK_SECRET="your-webhook-secret"Configurar Integração Tajo
No seu painel Tajo:
- Aceda a Definições > Integrações
- Selecione Brevo da lista
- Introduza a sua chave de API Brevo
- Configure as definições de sincronização
{ "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" ]}Passo 2: Sincronização de Dados de Clientes
Configuração de Sincronização de Contactos
Configure a sincronização automática de contactos para manter os dados de clientes atualizados:
// Sincronizar cliente no registoasync 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();}Sincronização de Eventos de Compra
Sincronize compras automaticamente para acionar campanhas de fidelidade:
// Sincronizar conclusão de pedidoasync function syncOrderToBrevo(order, customer) { // Criar pedido no Brevo 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) });
// Criar evento de fidelidade 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) });}Passo 3: Configuração de Campanhas Automatizadas
Campanha de Boas-vindas para Novos Clientes
Crie uma série de boas-vindas automatizada para novos membros de fidelidade:
{ "campaign_name": "Série de Boas-vindas Tajo Loyalty", "trigger": { "event": "Contact Created", "conditions": { "LOYALTY_ID": "exists", "SIGNUP_DATE": "today" } }, "emails": [ { "delay": "immediate", "template_id": 101, "subject": "Bem-vindo ao Tajo Loyalty! Aqui está o seu bónus de {{params.welcome_bonus}} pontos", "params": { "welcome_bonus": "500", "loyalty_tier": "Bronze", "next_tier_points": "1000" } }, { "delay": "3 days", "template_id": 102, "subject": "Não se esqueça de usar os seus {{params.welcome_bonus}} pontos de bónus!" }, { "delay": "1 week", "template_id": 103, "subject": "Eis como ganhar pontos mais rapidamente com o Tajo" } ]}Campanha de Upgrade de Nível
Celebre automaticamente upgrades de nível:
// Handler de webhook para upgrades de nívelapp.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 } };
// Enviar e-mail de parabéns sendBrevoEmail(campaignData);
// Adicionar à lista específica do nível addToBrevoList(customer.email, getTierListId(newTier));
res.status(200).json({ success: true });});Passo 4: Rastreamento de Eventos de Fidelidade
Eventos Chave a Rastrear
Configure o rastreamento para estes eventos essenciais de fidelidade:
const loyaltyEvents = { // Eventos de Conta 'Account Created': { properties: ['signup_source', 'referral_code', 'welcome_bonus'] }, 'Profile Updated': { properties: ['updated_fields', 'marketing_consent'] },
// Eventos de Compra 'Purchase Completed': { properties: ['order_total', 'points_earned', 'loyalty_tier', 'products'] }, 'Product Returned': { properties: ['return_reason', 'points_deducted', 'refund_amount'] },
// Eventos de Fidelidade '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'] },
// Eventos de Envolvimento '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'] }};Implementação de Rastreamento de Eventos
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; } }
// Métodos de conveniência para eventos comuns 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() }); }}Passo 5: Estratégia de Segmentação
Segmentos de Clientes
Crie segmentos direcionados no Brevo para campanhas personalizadas:
const loyaltySegments = [ // Segmentos baseados em nível { name: "Membros Bronze", conditions: { LOYALTY_TIER: "Bronze" }, campaigns: ["tier_upgrade_promotion", "engagement_boost"] }, { name: "Membros Silver", conditions: { LOYALTY_TIER: "Silver" }, campaigns: ["premium_offers", "early_access"] }, { name: "Membros Gold", conditions: { LOYALTY_TIER: "Gold" }, campaigns: ["vip_treatment", "exclusive_rewards"] }, { name: "Membros Platinum", conditions: { LOYALTY_TIER: "Platinum" }, campaigns: ["luxury_experiences", "personal_offers"] },
// Segmentos baseados em comportamento { name: "Grandes Gastadores", conditions: { TOTAL_SPENT: ">1000" }, campaigns: ["luxury_catalog", "big_spender_rewards"] }, { name: "Compradores Frequentes", conditions: { PURCHASE_FREQUENCY: "weekly" }, campaigns: ["convenience_offers", "bulk_discounts"] }, { name: "Clientes em Risco", conditions: { LAST_PURCHASE: ">90 days" }, campaigns: ["win_back", "special_incentives"] }, { name: "Mês de Aniversário", conditions: { BIRTHDAY: "this_month" }, campaigns: ["birthday_specials", "bonus_points"] }];Passo 6: Testes e Monitorização
Lista de Verificação de Testes de Integração
- Sincronização de Contactos: Novos clientes aparecem no Brevo
- Sincronização de Pedidos: As compras acionam eventos corretamente
- Rastreamento de Eventos: Todos os eventos de fidelidade são registados
- Acionadores de Campanha: Os e-mails automatizados são enviados corretamente
- Segmentação: Os clientes movem-se entre listas corretamente
- Entrega de Webhook: A sincronização em tempo real funciona de forma fiável
Configuração de Monitorização
// Endpoint de verificação de saúdeapp.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() });});Resolução de Problemas Comuns
Limites de Taxa de API
O Brevo tem limites de taxa, implemente lógica de retry:
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; }}Problemas de Sincronização de Dados
Monitorize e resolva conflitos de sincronização:
// Resolução de conflitos de sincronizaçãoasync function resolveSyncConflict(tajoData, brevoData) { // Usar o timestamp mais recente como fonte de verdade const tajoUpdated = new Date(tajoData.updatedAt); const brevoUpdated = new Date(brevoData.modifiedAt);
if (tajoUpdated > brevoUpdated) { // Atualizar Brevo com dados Tajo await updateBrevoContact(brevoData.id, tajoData); } else { // Atualizar Tajo com dados Brevo await updateTajoCustomer(tajoData.id, brevoData); }}Próximos Passos
- Configurar Webhooks para sincronização em tempo real
- Criar Templates de E-mail para campanhas de fidelidade
- Configurar Automação SMS para notificações urgentes
- Configurar Análise para monitorizar o desempenho
Suporte e Recursos
- Suporte de Integração: [email protected]
- Documentação da API Brevo: api.brevo.com
- Repositório de Código de Exemplo: github.com/tajo/brevo-integration
- Fórum da Comunidade: community.tajo.com