Typeform Connector
Poveži Typeform z Brevo prek Tajo za samodejno sinhronizacijo odgovorov obrazcev, zajemanje potencialnih strank iz pogovornih obrazcev in sprožanje marketinških avtomatizacij na osnovi oddaj anket in rezultatov kvizov.
Pregled
| Lastnost | Vrednost |
|---|---|
| Platforma | Typeform |
| Kategorija | Obrazci in ankete (po meri) |
| Zahtevnost nastavitve | Enostavna |
| Uradna integracija | Ne |
| Sinhronizirani podatki | Odgovori, stiki, dogodki, obrazci |
| Metoda avtentikacije | OAuth 2.0 / Personal Access Token |
Funkcionalnosti
- Sinhronizacija odgovorov v realnem času – samodejno zajemaj oddaje obrazcev prek webhooks
- Ustvarjanje stikov – ustvari ali posodobi stike Brevo iz odgovorov obrazcev
- Ocenjevanje potencialnih strank – za kvalifikacijo strank uporabi rezultate kvizov in podatke obrazcev
- Skrita polja – prek skritih polj posreduj podatke stranke za personalizirane obrazce
- Pogojno preslikavanje – preslikaj različna polja obrazca glede na logiko odgovorov
- Podpora za več obrazcev – poveži več typeformov z različnimi seznami Brevo
Predpogoji
Preden začneš, se prepričaj, da imaš:
- Račun Typeform (plan Basic ali višji za webhooks)
- Personal Access Token iz Nastavitev računa Typeform
- Brevo račun z dostopom do API
- Tajo račun z dovoljenji za konektorje
Avtentikacija
Personal Access Token
# Generate a token at https://admin.typeform.com/account#/section/tokensexport TYPEFORM_ACCESS_TOKEN=tfp_your_personal_access_tokenexport TAJO_API_KEY=your_tajo_api_keyexport BREVO_API_KEY=your_brevo_api_keyOAuth 2.0
// OAuth 2.0 Authorization Flowconst authUrl = 'https://api.typeform.com/oauth/authorize?' + new URLSearchParams({ client_id: process.env.TYPEFORM_CLIENT_ID, redirect_uri: 'https://your-app.com/callback', scope: 'forms:read responses:read webhooks:write accounts:read', state: generateState() });
// Exchange authorization code for access tokenconst tokenResponse = await fetch('https://api.typeform.com/oauth/token', { method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, body: new URLSearchParams({ grant_type: 'authorization_code', code: authorizationCode, client_id: process.env.TYPEFORM_CLIENT_ID, client_secret: process.env.TYPEFORM_CLIENT_SECRET, redirect_uri: 'https://your-app.com/callback' })});Konfiguracija
Osnovna nastavitev
connectors: typeform: enabled: true access_token: "${TYPEFORM_ACCESS_TOKEN}"
forms: - form_id: "abc123" list_id: 5 mapping: email_field: "email" name_field: "full_name" - form_id: "xyz789" list_id: 6 mapping: email_field: "work_email"
sync: responses: true contacts: true events: true
webhook: enabled: true secret: "${TYPEFORM_WEBHOOK_SECRET}"Preslikava polj
field_mapping: # Map Typeform field references to Brevo attributes email: email name: FIRSTNAME company: COMPANY phone: SMS score: LEAD_SCORE quiz_result: QUIZ_SCORE nps_rating: NPS_SCORE feedback: LAST_FEEDBACKKončne točke API
| Končna točka | Metoda | Opis |
|---|---|---|
https://api.typeform.com/forms | GET | Seznam vseh obrazcev |
https://api.typeform.com/forms/{form_id} | GET | Pridobi obrazec |
https://api.typeform.com/forms | POST | Ustvari obrazec |
https://api.typeform.com/forms/{form_id} | PUT | Posodobi obrazec |
https://api.typeform.com/forms/{form_id}/responses | GET | Pridobi odgovore |
https://api.typeform.com/forms/{form_id}/responses | DELETE | Izbriši odgovore |
https://api.typeform.com/forms/{form_id}/webhooks/{tag} | PUT | Ustvari/posodobi webhook |
https://api.typeform.com/forms/{form_id}/webhooks/{tag} | GET | Pridobi webhook |
https://api.typeform.com/forms/{form_id}/webhooks | GET | Seznam webhooks |
Primeri kode
Inicializacija konektorja
import { TajoClient } from '@tajo/sdk';
const tajo = new TajoClient({ apiKey: process.env.TAJO_API_KEY, brevoApiKey: process.env.BREVO_API_KEY});
await tajo.connectors.connect('typeform', { accessToken: process.env.TYPEFORM_ACCESS_TOKEN, forms: ['abc123', 'xyz789']});Pridobivanje odgovorov na obrazec
// Fetch responses using the Responses APIconst response = await fetch( 'https://api.typeform.com/forms/abc123/responses?' + new URLSearchParams({ page_size: 25, since: '2024-01-01T00:00:00Z', completed: 'true' }), { headers: { 'Authorization': `Bearer ${process.env.TYPEFORM_ACCESS_TOKEN}` } });
const data = await response.json();
// Sync each response to Brevofor (const item of data.items) { const answers = item.answers; const email = answers.find(a => a.field.ref === 'email')?.email;
if (email) { await tajo.contacts.sync({ email, attributes: { FIRSTNAME: answers.find(a => a.field.ref === 'name')?.text, LEAD_SCORE: item.calculated?.score || 0 }, listIds: [5] }); }}Nastavitev webhooks
// Register a webhook for real-time response notificationsawait fetch( 'https://api.typeform.com/forms/abc123/webhooks/tajo-sync', { method: 'PUT', headers: { 'Authorization': `Bearer ${process.env.TYPEFORM_ACCESS_TOKEN}`, 'Content-Type': 'application/json' }, body: JSON.stringify({ url: 'https://api.tajo.io/webhooks/typeform', enabled: true, secret: process.env.TYPEFORM_WEBHOOK_SECRET }) });Obravnava dogodkov Webhook
app.post('/webhooks/typeform', async (req, res) => { // Verify webhook signature const signature = req.headers['typeform-signature']; const isValid = verifyTypeformSignature( req.rawBody, signature, process.env.TYPEFORM_WEBHOOK_SECRET );
if (!isValid) return res.status(401).send('Unauthorized');
const { form_response } = req.body;
await tajo.connectors.handleWebhook('typeform', { topic: 'form_response', payload: form_response });
res.status(200).send('OK');});Omejitve hitrosti
| Končna točka | Omejitev hitrosti | Opombe |
|---|---|---|
| Create API | 2 zahtevka/s | Ustvarjanje in posodabljanje obrazcev |
| Responses API | 2 zahtevka/s | Pridobivanje odgovorov |
| Webhooks API | 2 zahtevka/s | Upravljanje webhooks |
| Vse končne točke | 120 zahtevkov/min | Globalna omejitev hitrosti |
Paginacija odgovorov
Responses API vrne največ 1.000 odgovorov na zahtevek. Za paginacijo pri pridobivanju velikih nizov odgovorov uporabi parametra kazalca before ali after.
Odpravljanje težav
| Težava | Vzrok | Rešitev |
|---|---|---|
| Webhook ni prejet | Webhook onemogočen | Omogoči webhook v nadzorni plošči Typeform |
| Manjkajoči odgovori | Uporabljen filter | Preveri parametre since/until in completed |
| Napaka avtentikacije 401 | Potekel žeton | Ustvari nov Personal Access Token |
| Omejitev hitrosti 429 | Preveč zahtevkov | Implementiraj omejevanje zahtevkov |
| Prazni odgovori | Neobvezna polja | Obravnavaj vrednosti null/undefined odgovorov |
Način odpravljanja napak
connectors: typeform: debug: true log_level: verbose log_webhooks: true log_responses: trueNajboljše prakse
- Uporabljaj webhooks – webhooks so boljši od anketiranja za zajem odgovorov v realnem času
- Potrjevanje podpisov – vedno preverjaj podpise webhooks za varnost
- Uporabi skrita polja – v obrazcih vnaprej zapolni znane podatke stranke
- Preslikuj reference polj – namesto ID-jev polj uporabi stabilne vrednosti
ref - Obravnavaj delne odgovore – upoštevaj neobvezna in preskočena vprašanja
- Nastavi logiko ponovnih poskusov – implementiraj idempotentno obdelavo webhooks
Varnost
- OAuth 2.0 – avtentikacija na osnovi obsegastih žetonov
- Podpisi webhooks – preverjanje podpisa SHA-256 HMAC
- Samo HTTPS – vse končne točke API zahtevajo TLS
- Obseg žetonov – zahtevaj minimalne zahtevane obsege OAuth
- Upravljanje skrivnosti – žetone shrani v spremenljivke okolja ali upravljalce skrivnosti
- Skladnost z GDPR – za zahteve po brisanju podatkov uporabi Delete Responses API