cdp-edge 1.18.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/README.md +308 -308
  2. package/bin/cdp-edge.js +61 -61
  3. package/dist/commands/analyze.js +52 -52
  4. package/dist/commands/infra.js +54 -54
  5. package/dist/commands/install.js +187 -0
  6. package/dist/commands/server.js +174 -174
  7. package/dist/commands/setup.js +19 -1
  8. package/dist/commands/validate.js +84 -84
  9. package/dist/index.js +12 -12
  10. package/extracted-skill/tracking-events-generator/advanced-matching.js +364 -364
  11. package/extracted-skill/tracking-events-generator/anti-blocking.js +285 -285
  12. package/extracted-skill/tracking-events-generator/cdpTrack.js +641 -641
  13. package/extracted-skill/tracking-events-generator/engagement-scoring.js +226 -226
  14. package/extracted-skill/tracking-events-generator/evals/evals.json +235 -235
  15. package/extracted-skill/tracking-events-generator/integration-test.js +497 -497
  16. package/extracted-skill/tracking-events-generator/micro-events.js +992 -992
  17. package/extracted-skill/tracking-events-generator/models/pinterest/conversions-api-template.js +144 -144
  18. package/extracted-skill/tracking-events-generator/models/pinterest/event-mappings.json +48 -48
  19. package/extracted-skill/tracking-events-generator/models/pinterest/tag-template.js +28 -28
  20. package/extracted-skill/tracking-events-generator/models/reddit/conversions-api-template.js +205 -205
  21. package/extracted-skill/tracking-events-generator/models/reddit/event-mappings.json +56 -56
  22. package/extracted-skill/tracking-events-generator/models/reddit/pixel-template.js +19 -19
  23. package/extracted-skill/tracking-events-generator/models/scenarios/behavior-engine.js +425 -425
  24. package/package.json +76 -76
  25. package/server-edge-tracker/schema.sql +265 -265
  26. package/server-edge-tracker/worker.js +4160 -4160
  27. package/server-edge-tracker/wrangler.toml +103 -103
  28. package/templates/pinterest/conversions-api-template.js +144 -144
  29. package/templates/pinterest/event-mappings.json +48 -48
  30. package/templates/pinterest/tag-template.js +28 -28
  31. package/templates/reddit/conversions-api-template.js +205 -205
  32. package/templates/reddit/event-mappings.json +56 -56
  33. package/templates/reddit/pixel-template.js +19 -19
  34. package/templates/scenarios/behavior-engine.js +425 -425
@@ -1,235 +1,235 @@
1
- {
2
- "skill_name": "tracking-events-generator",
3
- "evals": [
4
- {
5
- "id": 1,
6
- "group": "browser-only",
7
- "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
8
- "prompt": "Cria os eventos de tracking para minha página de imóvel em SBC (São Bernardo do Campo), apartamento de 260m², 3 vagas de garagem, bairro nobre. Preciso rastrear para Meta Ads e Google Ads.",
9
- "expected_output": "Código completo com Meta Pixel base (PageView), ViewContent com parâmetros de imóvel (city: São Bernardo do Campo, region: SP, content_type: home_listing, property_size: 260), evento Lead para formulário, evento Contact para WhatsApp, Google Ads global tag com evento de conversão para lead, e instruções de implementação.",
10
- "assertions": [
11
- {
12
- "name": "contem_meta_pixel_base",
13
- "type": "contains",
14
- "value": "fbq('init'"
15
- },
16
- {
17
- "name": "contem_pageview",
18
- "type": "contains",
19
- "value": "PageView"
20
- },
21
- {
22
- "name": "contem_viewcontent",
23
- "type": "contains",
24
- "value": "ViewContent"
25
- },
26
- {
27
- "name": "contem_home_listing",
28
- "type": "contains",
29
- "value": "home_listing"
30
- },
31
- {
32
- "name": "contem_sbc_ou_sao_bernardo",
33
- "type": "contains_any",
34
- "value": ["São Bernardo", "sao_bernardo", "SBC", "s_o_bernardo"]
35
- },
36
- {
37
- "name": "contem_google_ads_tag",
38
- "type": "contains",
39
- "value": "gtag"
40
- },
41
- {
42
- "name": "contem_evento_lead",
43
- "type": "contains",
44
- "value": "Lead"
45
- },
46
- {
47
- "name": "contem_evento_contact",
48
- "type": "contains",
49
- "value": "Contact"
50
- },
51
- {
52
- "name": "contem_instrucoes_implementacao",
53
- "type": "contains_any",
54
- "value": ["implementar", "Implementar", "IMPLEMENTAR", "colar", "Colar", "head"]
55
- }
56
- ],
57
- "files": []
58
- },
59
- {
60
- "id": 2,
61
- "group": "browser-only",
62
- "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
63
- "prompt": "Preciso de tracking para uma página de vendas do meu curso online de Excel avançado, valor R$497. Quero rastrear Meta Pixel e Google Ads. A página tem um botão de compra que vai para o checkout da Hotmart.",
64
- "expected_output": "Código com Meta Pixel base, ViewContent para produto digital (content_type: product, value: 497, currency: BRL), InitiateCheckout no clique do botão de compra, Purchase na página de obrigado, Google Ads com evento de conversão de compra, e instruções sobre como capturar o Purchase na Hotmart.",
65
- "assertions": [
66
- {
67
- "name": "contem_meta_pixel",
68
- "type": "contains",
69
- "value": "fbq('init'"
70
- },
71
- {
72
- "name": "contem_viewcontent",
73
- "type": "contains",
74
- "value": "ViewContent"
75
- },
76
- {
77
- "name": "contem_initiate_checkout",
78
- "type": "contains",
79
- "value": "InitiateCheckout"
80
- },
81
- {
82
- "name": "contem_purchase",
83
- "type": "contains",
84
- "value": "Purchase"
85
- },
86
- {
87
- "name": "contem_valor_497",
88
- "type": "contains_any",
89
- "value": ["497", "497.00"]
90
- },
91
- {
92
- "name": "contem_currency_brl",
93
- "type": "contains",
94
- "value": "BRL"
95
- },
96
- {
97
- "name": "contem_google_ads",
98
- "type": "contains",
99
- "value": "gtag"
100
- },
101
- {
102
- "name": "menciona_hotmart",
103
- "type": "contains",
104
- "value": "Hotmart"
105
- }
106
- ],
107
- "files": []
108
- },
109
- {
110
- "id": 3,
111
- "group": "browser-only",
112
- "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
113
- "prompt": "Minha clínica de estética tem uma página de agendamento de consulta. Quero rastrear quando alguém visualiza a página, quando clica no WhatsApp e quando preenche o formulário de agendamento. Usa só o Meta Pixel por enquanto, não precisa do Google Ads.",
114
- "expected_output": "Código com Meta Pixel base, PageView, ViewContent para serviço, evento Contact no clique do WhatsApp, evento Schedule no envio do formulário de agendamento. Não deve incluir código do Google Ads (somente Meta Pixel conforme solicitado).",
115
- "assertions": [
116
- {
117
- "name": "contem_meta_pixel",
118
- "type": "contains",
119
- "value": "fbq('init'"
120
- },
121
- {
122
- "name": "contem_pageview",
123
- "type": "contains",
124
- "value": "PageView"
125
- },
126
- {
127
- "name": "contem_contact_whatsapp",
128
- "type": "contains",
129
- "value": "Contact"
130
- },
131
- {
132
- "name": "contem_schedule",
133
- "type": "contains",
134
- "value": "Schedule"
135
- },
136
- {
137
- "name": "nao_deve_ter_google_ads_obrigatorio",
138
- "type": "note",
139
- "value": "Google Ads não solicitado — verificar se o skill respeitou essa restrição ou ofereceu como opcional"
140
- }
141
- ],
142
- "files": []
143
- },
144
- {
145
- "id": 4,
146
- "group": "tier10",
147
- "note": "Eval Quantum Tier — verifica padrões Cloudflare Native (cdpTrack SDK + Worker server-side).",
148
- "prompt": "Cria o tracking completo Quantum Tier para uma página de vendas de curso online (R$997). Preciso de Meta CAPI v22.0 + GA4 + TikTok, com Worker Cloudflare. O botão de compra vai para o checkout da Hotmart.",
149
- "expected_output": "tracking.js com cdpTrack.track(), worker.js com endpoints /track e /webhook/hotmart, deduplicação por event_id, SHA-256 via crypto.subtle, D1 para persistência, event_id idêntico entre browser e servidor.",
150
- "assertions": [
151
- {
152
- "name": "usa_cdptrack_sdk",
153
- "type": "contains",
154
- "value": "cdpTrack.track("
155
- },
156
- {
157
- "name": "usa_worker_endpoint",
158
- "type": "contains_any",
159
- "value": ["/track", "cdpTrack"]
160
- },
161
- {
162
- "name": "contem_event_id_dedup",
163
- "type": "contains",
164
- "value": "event_id"
165
- },
166
- {
167
- "name": "contem_capi_v22",
168
- "type": "contains",
169
- "value": "v22.0"
170
- },
171
- {
172
- "name": "contem_sha256_webcrypto",
173
- "type": "contains",
174
- "value": "crypto.subtle"
175
- },
176
- {
177
- "name": "contem_purchase",
178
- "type": "contains",
179
- "value": "Purchase"
180
- },
181
- {
182
- "name": "contem_initiate_checkout",
183
- "type": "contains",
184
- "value": "InitiateCheckout"
185
- },
186
- {
187
- "name": "contem_currency_brl",
188
- "type": "contains",
189
- "value": "BRL"
190
- }
191
- ],
192
- "files": []
193
- },
194
- {
195
- "id": 5,
196
- "group": "tier10",
197
- "note": "Eval Quantum Tier — verifica tratamento correto de webhook de compra com D1 match.",
198
- "prompt": "Meu Worker Cloudflare recebe webhook da Kiwify. Preciso que ele recupere o fbp/fbc do D1 pelo email do comprador e dispare o Purchase para Meta CAPI v22.0 e TikTok Events API v1.3.",
199
- "expected_output": "Worker com handler /webhook/kiwify, lookup de user_profiles no D1 por email, payload com fbp/fbc recuperados, SHA-256 de email e telefone, event_id = kiwify_{order_id}, endpoint Meta v22.0, endpoint TikTok v1.3.",
200
- "assertions": [
201
- {
202
- "name": "contem_webhook_kiwify",
203
- "type": "contains",
204
- "value": "/webhook/kiwify"
205
- },
206
- {
207
- "name": "recupera_fbp_do_d1",
208
- "type": "contains_any",
209
- "value": ["profile?.fbp", "profile.fbp", "getProfileByEmail"]
210
- },
211
- {
212
- "name": "usa_capi_v22",
213
- "type": "contains",
214
- "value": "v22.0"
215
- },
216
- {
217
- "name": "usa_tiktok_v13",
218
- "type": "contains",
219
- "value": "v1.3"
220
- },
221
- {
222
- "name": "contem_sha256",
223
- "type": "contains",
224
- "value": "SHA-256"
225
- },
226
- {
227
- "name": "contem_event_id_kiwify",
228
- "type": "contains_any",
229
- "value": ["kiwify_", "order_id"]
230
- }
231
- ],
232
- "files": []
233
- }
234
- ]
235
- }
1
+ {
2
+ "skill_name": "tracking-events-generator",
3
+ "evals": [
4
+ {
5
+ "id": 1,
6
+ "group": "browser-only",
7
+ "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
8
+ "prompt": "Cria os eventos de tracking para minha página de imóvel em SBC (São Bernardo do Campo), apartamento de 260m², 3 vagas de garagem, bairro nobre. Preciso rastrear para Meta Ads e Google Ads.",
9
+ "expected_output": "Código completo com Meta Pixel base (PageView), ViewContent com parâmetros de imóvel (city: São Bernardo do Campo, region: SP, content_type: home_listing, property_size: 260), evento Lead para formulário, evento Contact para WhatsApp, Google Ads global tag com evento de conversão para lead, e instruções de implementação.",
10
+ "assertions": [
11
+ {
12
+ "name": "contem_meta_pixel_base",
13
+ "type": "contains",
14
+ "value": "fbq('init'"
15
+ },
16
+ {
17
+ "name": "contem_pageview",
18
+ "type": "contains",
19
+ "value": "PageView"
20
+ },
21
+ {
22
+ "name": "contem_viewcontent",
23
+ "type": "contains",
24
+ "value": "ViewContent"
25
+ },
26
+ {
27
+ "name": "contem_home_listing",
28
+ "type": "contains",
29
+ "value": "home_listing"
30
+ },
31
+ {
32
+ "name": "contem_sbc_ou_sao_bernardo",
33
+ "type": "contains_any",
34
+ "value": ["São Bernardo", "sao_bernardo", "SBC", "s_o_bernardo"]
35
+ },
36
+ {
37
+ "name": "contem_google_ads_tag",
38
+ "type": "contains",
39
+ "value": "gtag"
40
+ },
41
+ {
42
+ "name": "contem_evento_lead",
43
+ "type": "contains",
44
+ "value": "Lead"
45
+ },
46
+ {
47
+ "name": "contem_evento_contact",
48
+ "type": "contains",
49
+ "value": "Contact"
50
+ },
51
+ {
52
+ "name": "contem_instrucoes_implementacao",
53
+ "type": "contains_any",
54
+ "value": ["implementar", "Implementar", "IMPLEMENTAR", "colar", "Colar", "head"]
55
+ }
56
+ ],
57
+ "files": []
58
+ },
59
+ {
60
+ "id": 2,
61
+ "group": "browser-only",
62
+ "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
63
+ "prompt": "Preciso de tracking para uma página de vendas do meu curso online de Excel avançado, valor R$497. Quero rastrear Meta Pixel e Google Ads. A página tem um botão de compra que vai para o checkout da Hotmart.",
64
+ "expected_output": "Código com Meta Pixel base, ViewContent para produto digital (content_type: product, value: 497, currency: BRL), InitiateCheckout no clique do botão de compra, Purchase na página de obrigado, Google Ads com evento de conversão de compra, e instruções sobre como capturar o Purchase na Hotmart.",
65
+ "assertions": [
66
+ {
67
+ "name": "contem_meta_pixel",
68
+ "type": "contains",
69
+ "value": "fbq('init'"
70
+ },
71
+ {
72
+ "name": "contem_viewcontent",
73
+ "type": "contains",
74
+ "value": "ViewContent"
75
+ },
76
+ {
77
+ "name": "contem_initiate_checkout",
78
+ "type": "contains",
79
+ "value": "InitiateCheckout"
80
+ },
81
+ {
82
+ "name": "contem_purchase",
83
+ "type": "contains",
84
+ "value": "Purchase"
85
+ },
86
+ {
87
+ "name": "contem_valor_497",
88
+ "type": "contains_any",
89
+ "value": ["497", "497.00"]
90
+ },
91
+ {
92
+ "name": "contem_currency_brl",
93
+ "type": "contains",
94
+ "value": "BRL"
95
+ },
96
+ {
97
+ "name": "contem_google_ads",
98
+ "type": "contains",
99
+ "value": "gtag"
100
+ },
101
+ {
102
+ "name": "menciona_hotmart",
103
+ "type": "contains",
104
+ "value": "Hotmart"
105
+ }
106
+ ],
107
+ "files": []
108
+ },
109
+ {
110
+ "id": 3,
111
+ "group": "browser-only",
112
+ "note": "Eval legado — testa output browser-only (sem Cloudflare). Mantido para retrocompatibilidade.",
113
+ "prompt": "Minha clínica de estética tem uma página de agendamento de consulta. Quero rastrear quando alguém visualiza a página, quando clica no WhatsApp e quando preenche o formulário de agendamento. Usa só o Meta Pixel por enquanto, não precisa do Google Ads.",
114
+ "expected_output": "Código com Meta Pixel base, PageView, ViewContent para serviço, evento Contact no clique do WhatsApp, evento Schedule no envio do formulário de agendamento. Não deve incluir código do Google Ads (somente Meta Pixel conforme solicitado).",
115
+ "assertions": [
116
+ {
117
+ "name": "contem_meta_pixel",
118
+ "type": "contains",
119
+ "value": "fbq('init'"
120
+ },
121
+ {
122
+ "name": "contem_pageview",
123
+ "type": "contains",
124
+ "value": "PageView"
125
+ },
126
+ {
127
+ "name": "contem_contact_whatsapp",
128
+ "type": "contains",
129
+ "value": "Contact"
130
+ },
131
+ {
132
+ "name": "contem_schedule",
133
+ "type": "contains",
134
+ "value": "Schedule"
135
+ },
136
+ {
137
+ "name": "nao_deve_ter_google_ads_obrigatorio",
138
+ "type": "note",
139
+ "value": "Google Ads não solicitado — verificar se o skill respeitou essa restrição ou ofereceu como opcional"
140
+ }
141
+ ],
142
+ "files": []
143
+ },
144
+ {
145
+ "id": 4,
146
+ "group": "tier10",
147
+ "note": "Eval Quantum Tier — verifica padrões Cloudflare Native (cdpTrack SDK + Worker server-side).",
148
+ "prompt": "Cria o tracking completo Quantum Tier para uma página de vendas de curso online (R$997). Preciso de Meta CAPI v22.0 + GA4 + TikTok, com Worker Cloudflare. O botão de compra vai para o checkout da Hotmart.",
149
+ "expected_output": "tracking.js com cdpTrack.track(), worker.js com endpoints /track e /webhook/hotmart, deduplicação por event_id, SHA-256 via crypto.subtle, D1 para persistência, event_id idêntico entre browser e servidor.",
150
+ "assertions": [
151
+ {
152
+ "name": "usa_cdptrack_sdk",
153
+ "type": "contains",
154
+ "value": "cdpTrack.track("
155
+ },
156
+ {
157
+ "name": "usa_worker_endpoint",
158
+ "type": "contains_any",
159
+ "value": ["/track", "cdpTrack"]
160
+ },
161
+ {
162
+ "name": "contem_event_id_dedup",
163
+ "type": "contains",
164
+ "value": "event_id"
165
+ },
166
+ {
167
+ "name": "contem_capi_v22",
168
+ "type": "contains",
169
+ "value": "v22.0"
170
+ },
171
+ {
172
+ "name": "contem_sha256_webcrypto",
173
+ "type": "contains",
174
+ "value": "crypto.subtle"
175
+ },
176
+ {
177
+ "name": "contem_purchase",
178
+ "type": "contains",
179
+ "value": "Purchase"
180
+ },
181
+ {
182
+ "name": "contem_initiate_checkout",
183
+ "type": "contains",
184
+ "value": "InitiateCheckout"
185
+ },
186
+ {
187
+ "name": "contem_currency_brl",
188
+ "type": "contains",
189
+ "value": "BRL"
190
+ }
191
+ ],
192
+ "files": []
193
+ },
194
+ {
195
+ "id": 5,
196
+ "group": "tier10",
197
+ "note": "Eval Quantum Tier — verifica tratamento correto de webhook de compra com D1 match.",
198
+ "prompt": "Meu Worker Cloudflare recebe webhook da Kiwify. Preciso que ele recupere o fbp/fbc do D1 pelo email do comprador e dispare o Purchase para Meta CAPI v22.0 e TikTok Events API v1.3.",
199
+ "expected_output": "Worker com handler /webhook/kiwify, lookup de user_profiles no D1 por email, payload com fbp/fbc recuperados, SHA-256 de email e telefone, event_id = kiwify_{order_id}, endpoint Meta v22.0, endpoint TikTok v1.3.",
200
+ "assertions": [
201
+ {
202
+ "name": "contem_webhook_kiwify",
203
+ "type": "contains",
204
+ "value": "/webhook/kiwify"
205
+ },
206
+ {
207
+ "name": "recupera_fbp_do_d1",
208
+ "type": "contains_any",
209
+ "value": ["profile?.fbp", "profile.fbp", "getProfileByEmail"]
210
+ },
211
+ {
212
+ "name": "usa_capi_v22",
213
+ "type": "contains",
214
+ "value": "v22.0"
215
+ },
216
+ {
217
+ "name": "usa_tiktok_v13",
218
+ "type": "contains",
219
+ "value": "v1.3"
220
+ },
221
+ {
222
+ "name": "contem_sha256",
223
+ "type": "contains",
224
+ "value": "SHA-256"
225
+ },
226
+ {
227
+ "name": "contem_event_id_kiwify",
228
+ "type": "contains_any",
229
+ "value": ["kiwify_", "order_id"]
230
+ }
231
+ ],
232
+ "files": []
233
+ }
234
+ ]
235
+ }