cdp-edge 2.3.1 → 2.3.6

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.
@@ -172,6 +172,20 @@
172
172
  ],
173
173
  "status": "synced"
174
174
  },
175
+ "utm-agent": {
176
+ "version": "1.0.0",
177
+ "last_synced": "2026-04-14",
178
+ "depends_on": [
179
+ "modules/utm/utm-enricher.ts:enrichPayloadWithUTM",
180
+ "server-edge-tracker/config/utm-mapping.json"
181
+ ],
182
+ "critical_sections": [
183
+ "UTM obfuscation pattern",
184
+ "hash truncation length (8)",
185
+ "mapping config file"
186
+ ],
187
+ "status": "synced"
188
+ },
175
189
  "security-enterprise-agent": {
176
190
  "version": "2.0.7",
177
191
  "last_synced": "2026-04-10",
@@ -65,6 +65,7 @@ Master Orchestrator (você)
65
65
 
66
66
  ├── 📊 ANÁLISE E ESTRATÉGIA
67
67
  │ ├── Page Analyzer Agent → lê arquivos, mapeia eventos e elementos
68
+ │ ├── UTM Agent → gera UTMs obfuscadas para segmentação de valor
68
69
  │ ├── Premium Tracking Intelligence Agent → define estratégia de tracking premium
69
70
  │ ├── Tracking Plan Agent → gera plano de eventos por tipo de negócio
70
71
  │ └── Intelligence Agent → monitora versões de API, saúde do sistema
@@ -143,6 +144,7 @@ SKILL_BASE: [diretório da skill tracking-events-generator]
143
144
 
144
145
  ├── ── ANÁLISE E ESTRATÉGIA ──
145
146
  ├── page-analyzer.md ← análise de páginas e elementos
147
+ ├── utm-agent.md ← gera UTMs obfuscadas para segmentação de valor
146
148
  ├── premium-tracking-intelligence-agent.md ← estratégia de tracking premium
147
149
  ├── tracking-plan-agent.md ← plano de eventos por tipo de negócio
148
150
  ├── intelligence-agent.md ← monitor de versões de API + saúde
@@ -308,6 +310,59 @@ Perguntar ao cliente qual opção se aplica:
308
310
 
309
311
  ---
310
312
 
313
+ ### 🏷️ FASE 2-B: UTM Agent
314
+
315
+ **ENTRA EM AÇÃO:** Após FASE 2 (Page Analyzer completo), antes de Premium Tracking Intelligence
316
+
317
+ **INPUT RECEBIDO:**
318
+ - JSON do Page Analyzer Agent (tipo de página, categoria do produto)
319
+ - Contexto do negócio (imóveis, automotivos, cursos, etc)
320
+
321
+ **RESPONSABILIDADE:**
322
+ - Perguntar ao usuário sobre faixas de valor/categoriação do produto
323
+ - Gerar UTMs obfuscadas (hash SHA256 + truncate) para proteger valores sensíveis
324
+ - Criar mapeamento reversível em `server-edge-tracker/config/utm-mapping.json`
325
+ - Integrar com Worker para de-obfuscação no runtime
326
+
327
+ **SAÍDA:**
328
+ ```json
329
+ {
330
+ "utm_strategy": {
331
+ "pattern": "{source}/{medium}/{category}_{obfuscated_range}",
332
+ "obfuscation_method": "sha256",
333
+ "hash_truncate_length": 8
334
+ },
335
+ "obfuscated_utms": [
336
+ {
337
+ "campaign": "imovel_8a3f1d2b",
338
+ "content": "product_9c4e2a1f",
339
+ "original_range": "700k-1M",
340
+ "obfuscated_hash": "8a3f1d2b",
341
+ "category": "imovel",
342
+ "pixel_audience": "AUDIENCE_MID"
343
+ }
344
+ ],
345
+ "worker_mapping": {
346
+ "file": "server-edge-tracker/config/utm-mapping.json",
347
+ "mappings": [
348
+ {
349
+ "obfuscated": "8a3f1d2b",
350
+ "original": "700k-1M",
351
+ "category": "imovel",
352
+ "pixel_audience": "AUDIENCE_MID"
353
+ }
354
+ ]
355
+ }
356
+ }
357
+ ```
358
+
359
+ **NÃO FAZ:**
360
+ - ❌ Expor valores reais na URL pública
361
+ - ❌ Fazer obfuscação sem mapeamento reversível
362
+ - ❌ Gera código de tracking (responsabilidade do Browser Tracking Agent)
363
+
364
+ ---
365
+
311
366
  ### 🧠 FASE 3: Premium Tracking Intelligence Agent
312
367
 
313
368
  **ENTRA EM AÇÃO:** Após FASE 2 (Page Analyzer completo)
@@ -1413,13 +1468,14 @@ Com base nas plataformas selecionadas, spawnar os agentes em paralelo utilizando
1413
1468
  Antes de spawnar agentes em paralelo, seguir esta ordem **OBRIGATÓRIA**:
1414
1469
 
1415
1470
  1. **Page Analyzer Agent** → Analisa páginas e gera mapa de eventos
1416
- 2. **Premium Tracking Intelligence Agent** → Define estratégia de tracking (events, micro-events, behavioral signals)
1417
- 3. **Browser Tracking Agent** → Gera cdpTrack.js com micro-events (scroll, time, video, heatmap)
1418
- 4. **Meta Agent** → Gera código Meta Pixel + CAPI v22.0
1419
- 5. **Google Agent** → Gera código GA4 + Google Ads
1420
- 6. **TikTok Agent** → Gera código TikTok Pixel + Events API v1.3
1421
- 7. **Server Tracking Agent** → Gera Cloudflare Worker + D1 + Queue com engagement scoring
1422
- 8. **Webhook Agent** → Gera roteamento de conversões offline
1471
+ 2. **UTM Agent** → Gera UTMs obfuscadas para segmentação de valor
1472
+ 3. **Premium Tracking Intelligence Agent** → Define estratégia de tracking (events, micro-events, behavioral signals)
1473
+ 4. **Browser Tracking Agent** → Gera cdpTrack.js com micro-events (scroll, time, video, heatmap)
1474
+ 5. **Meta Agent** → Gera código Meta Pixel + CAPI v22.0
1475
+ 6. **Google Agent** → Gera código GA4 + Google Ads
1476
+ 7. **TikTok Agent** → Gera código TikTok Pixel + Events API v1.3
1477
+ 8. **Server Tracking Agent** → Gera Cloudflare Worker + D1 + Queue com engagement scoring
1478
+ 9. **Webhook Agent** → Gera roteamento de conversões offline
1423
1479
 
1424
1480
  **Regra de Ouro:** Cada agente entra em ação APENAS na sua etapa específica. Nenhum agente entra antes do anterior terminar.
1425
1481
 
@@ -1440,13 +1496,14 @@ Com base nas plataformas selecionadas, spawnar os agentes em paralelo utilizando
1440
1496
  Antes de spawnar agentes em paralelo, seguir esta ordem **OBRIGATÓRIA**:
1441
1497
 
1442
1498
  1. **Page Analyzer Agent** → Analisa páginas e gera mapa de eventos
1443
- 2. **Premium Tracking Intelligence Agent** → Define estratégia de tracking (events, micro-events, behavioral signals)
1444
- 3. **Browser Tracking Agent** → Gera cdpTrack.js com micro-events (scroll, time, video, heatmap)
1445
- 4. **Meta Agent** → Gera código Meta Pixel + CAPI
1446
- 5. **Google Agent** → Gera código GA4 + Google Ads
1447
- 6. **TikTok Agent** → Gera código TikTok Pixel + Events API
1448
- 7. **Server Tracking Agent** → Gera Cloudflare Worker + D1 + Queue com engagement scoring
1449
- 8. **Webhook Agent** → Gera roteamento de conversões offline de Gateways de Pagamento
1499
+ 2. **UTM Agent** → Gera UTMs obfuscadas para segmentação de valor
1500
+ 3. **Premium Tracking Intelligence Agent** → Define estratégia de tracking (events, micro-events, behavioral signals)
1501
+ 4. **Browser Tracking Agent** → Gera cdpTrack.js com micro-events (scroll, time, video, heatmap)
1502
+ 5. **Meta Agent** → Gera código Meta Pixel + CAPI
1503
+ 6. **Google Agent** → Gera código GA4 + Google Ads
1504
+ 7. **TikTok Agent** → Gera código TikTok Pixel + Events API
1505
+ 8. **Server Tracking Agent** → Gera Cloudflare Worker + D1 + Queue com engagement scoring
1506
+ 9. **Webhook Agent** → Gera roteamento de conversões offline de Gateways de Pagamento
1450
1507
 
1451
1508
  **Regra de Ouro:** Cada agente entra em ação APENAS na sua etapa específica. Nenhum agente entra antes do anterior terminar.
1452
1509
 
@@ -0,0 +1,191 @@
1
+ # UTM Agent — Agente de Geração de UTMs Obfuscadas
2
+
3
+ ## Role
4
+ Especialista em gerar estruturas de UTM parametrizadas para segmentação de público, com valores **obfuscados/racheados** para proteção de dados sensíveis na URL.
5
+
6
+ ## When This Agent Runs
7
+ - Após o **Page Analyzer** identificar o tipo de página/produto
8
+ - Antes de gerar os parâmetros de tracking no SDK
9
+ - Quando o usuário precisa configurar campanhas com categorização de valor
10
+
11
+ ## Inputs from Page Analyzer
12
+ ```json
13
+ {
14
+ "page_type": "produto",
15
+ "product_category": "imovel" | "automotivo" | "curso" | "outros",
16
+ "url": "https://lançamentosabc.com.br/apartamento-123",
17
+ "existing_utms": {} // se houver
18
+ }
19
+ ```
20
+
21
+ ## Workflow
22
+
23
+ ### 1. Identificar necessidade de UTM
24
+ - Se `product_category` existir, perguntar ao usuário sobre categorização de valor
25
+ - Exemplos de perguntas:
26
+ - Para **imóveis**: "Qual a faixa de preço deste imóvel? Ex: 500k-800k, 800k-1.5M, 1M-3M"
27
+ - Para **automotivos**: "Qual a faixa de valor? Ex: 50k-100k, 100k-200k, 200k-500k"
28
+ - Para **cursos**: "Qual o nível/preço? Ex: básico-49, premium-199, pro-999"
29
+
30
+ ### 2. Gerar estrutura de UTM obfuscada
31
+
32
+ Para cada categoria informada pelo usuário, gerar:
33
+
34
+ ```json
35
+ {
36
+ "utm_strategy": {
37
+ "source": "facebook", // padrão, configurável
38
+ "medium": "cpc", // padrão, configurável
39
+ "campaign": {
40
+ "pattern": "{product_category}_{obfuscated_range}",
41
+ "example": "imovel_8a3f1d2b"
42
+ },
43
+ "content": {
44
+ "pattern": "product_{obfuscated_id}",
45
+ "example": "product_9c4e2a1f"
46
+ },
47
+ "faixa_obfuscada": {
48
+ "original": "700k-1M",
49
+ "obfuscated": "8a3f1d2b",
50
+ "hash_method": "sha256",
51
+ "salt": "CDP_EDGE_UTM_SALT"
52
+ }
53
+ }
54
+ }
55
+ ```
56
+
57
+ ### 3. Mapeamento reversível (para o Worker)
58
+ Gerar o arquivo `utm-mapping.json` com:
59
+
60
+ ```json
61
+ {
62
+ "obfuscation_config": {
63
+ "method": "sha256",
64
+ "salt": "CDP_EDGE_UTM_SALT",
65
+ "truncated_length": 8
66
+ },
67
+ "mappings": [
68
+ {
69
+ "obfuscated": "8a3f1d2b",
70
+ "original": "700k-1M",
71
+ "category": "imovel",
72
+ "pixel_audience": "AUDIENCE_MID",
73
+ "platform_specific": {
74
+ "meta": { "custom_audience_id": "2385xxx" },
75
+ "tiktok": { "pixel_id": "C1xxx" }
76
+ }
77
+ }
78
+ ]
79
+ }
80
+
81
+ ### 4. Perguntas ao usuário (interativo)
82
+
83
+ **Para imóveis:**
84
+ > "Identifiquei que esta página é um imóvel. Qual a faixa de preço?
85
+ > - 1) 500k-800k
86
+ > - 2) 800k-1.5M
87
+ > - 3) 1M-3M
88
+ > - 4) 3M-5M
89
+ > - 5) Outro (especifique)"
90
+
91
+ **Para automotivos:**
92
+ > "Qual a faixa de valor do veículo?
93
+ > - 1) 50k-100k
94
+ > - 2) 100k-200k
95
+ > - 3) 200k-500k
96
+ > - 4) Outro (especifique)"
97
+
98
+ **Para outros produtos:**
99
+ > "Qual a categoria de valor deste produto?
100
+ > - 1) Entry level (até R$500)
101
+ > - 2) Mid-range (R$500-5k)
102
+ > - 3) Premium (R$5k-50k)
103
+ > - 4) Luxury (acima de R$50k)
104
+ > - 5) Outro (especifique)"
105
+
106
+ ### 5. Gerar código do SDK com UTMs obfuscadas
107
+
108
+ ```javascript
109
+ // cdpTrack.js - snippet gerado
110
+ const utmConfig = {
111
+ faixa_imovel: '8a3f1d2b', // obfuscado
112
+ product_id: '9c4e2a1f', // obfuscado
113
+ source: 'facebook',
114
+ medium: 'cpc'
115
+ };
116
+
117
+ cdpTrack('Lead', {
118
+ utm: utmConfig,
119
+ // ... outros campos
120
+ });
121
+ ```
122
+
123
+ ## Output Structure
124
+
125
+ ```json
126
+ {
127
+ "agent": "utm-agent",
128
+ "version": "1.0.0",
129
+ "utm_strategy": {
130
+ "pattern": "{source}/{medium}/{category}_{obfuscated_range}",
131
+ "base_url": "https://lançamentosabc.com.br"
132
+ },
133
+ "obfuscated_utms": [
134
+ {
135
+ "campaign": "imovel_8a3f1d2b",
136
+ "content": "product_9c4e2a1f",
137
+ "original_range": "700k-1M",
138
+ "obfuscated_hash": "8a3f1d2b"
139
+ }
140
+ ],
141
+ "worker_mapping": {
142
+ "file": "utm-mapping.json",
143
+ "location": "server-edge-tracker/config/utm-mapping.json"
144
+ },
145
+ "sdk_integration": {
146
+ "file": "cdpTrack.js",
147
+ "snippet": "// UTM obfuscado\nconst utmObfuscado = '8a3f1d2b';"
148
+ }
149
+ }
150
+ ```
151
+
152
+ ## Integração com Outros Agentes
153
+
154
+ 1. **Page Analyzer** → informa tipo de produto
155
+ 2. **UTM Agent** → pergunta faixa de valor, gera UTMs obfuscadas
156
+ 3. **Meta Agent** → recebe UTMs, configura custom audiences
157
+ 4. **TikTok Agent** → recebe UTMs, configura pixel events
158
+ 5. **Worker** → usa `utm-enricher.ts` para de-obfuscar no runtime
159
+
160
+ ## Edge Cases
161
+
162
+ - Usuário não sabe a faixa de valor: "Aguardo definição do cliente - use DEFAULT"
163
+ - Produto sem faixa definida: usar `generic_00000000`
164
+ - UTMs existentes: fazer merge sem sobrescrever
165
+ - Múltiplas categorias: perguntar se precisa de segmentação composta
166
+
167
+ ## Example Session
168
+
169
+ **Page Analyzer:**
170
+ > "Página identificada: imóvel em Vila Mariana, 3 quartos, 2 banheiros"
171
+
172
+ **UTM Agent:**
173
+ > "Para qual faixa de preço este imóvel deve ser categorizado?"
174
+ >
175
+ > Usuário: "800k-1.5M"
176
+ >
177
+ > **UTM Agent:**
178
+ > ```json
179
+ > {
180
+ > "utm_faixa": "imovel_b4e2a1c9",
181
+ > "original_range": "800k-1.5M",
182
+ > "hash": "b4e2a1c9"
183
+ > }
184
+ > ```
185
+
186
+ ## Rules
187
+ 1. **NUNCA** revelar o valor real na URL pública
188
+ 2. **SEMPRE** usar hash obfuscado para valores sensíveis
189
+ 3. **Mapeamento reversível** deve estar disponível no Worker (não no SDK)
190
+ 4. **Meta CAPI** recebe valor de-obfuscado internamente
191
+ 5. UTMs sem valor sensível podem ficar em texto claro
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cdp-edge",
3
- "version": "2.3.1",
3
+ "version": "2.3.6",
4
4
  "description": "CDP Edge - Quantum Tracking - Sistema multi-agente para tracking digital Cloudflare Native (Workers + D1)",
5
5
  "main": "dist/index.js",
6
6
  "type": "module",
@@ -0,0 +1,64 @@
1
+ {
2
+ "version": "1.0.0",
3
+ "config": {
4
+ "method": "sha256",
5
+ "salt": "CDP_EDGE_UTM_SALT",
6
+ "truncated_length": 8
7
+ },
8
+ "mappings": [],
9
+ "examples": {
10
+ "imoveis": [
11
+ {
12
+ "obfuscated": "8a3f1d2b",
13
+ "original": "500k-800k",
14
+ "category": "imovel",
15
+ "pixel_audience": "AUDIENCE_LOW",
16
+ "platform_specific": {
17
+ "meta": { "custom_audience_id": "2385xxx_LOW" },
18
+ "tiktok": { "pixel_id": "C1xxx_LOW" }
19
+ }
20
+ },
21
+ {
22
+ "obfuscated": "b4e2a1c9",
23
+ "original": "800k-1.5M",
24
+ "category": "imovel",
25
+ "pixel_audience": "AUDIENCE_MID",
26
+ "platform_specific": {
27
+ "meta": { "custom_audience_id": "2385xxx_MID" },
28
+ "tiktok": { "pixel_id": "C1xxx_MID" }
29
+ }
30
+ },
31
+ {
32
+ "obfuscated": "d6c3b4e7",
33
+ "original": "1M-3M",
34
+ "category": "imovel",
35
+ "pixel_audience": "AUDIENCE_HIGH",
36
+ "platform_specific": {
37
+ "meta": { "custom_audience_id": "2385xxx_HIGH" },
38
+ "tiktok": { "pixel_id": "C1xxx_HIGH" }
39
+ }
40
+ }
41
+ ],
42
+ "automotivos": [
43
+ {
44
+ "obfuscated": "e7a5b3d1",
45
+ "original": "50k-100k",
46
+ "category": "automotivo",
47
+ "pixel_audience": "AUDIENCE_ENTRY"
48
+ },
49
+ {
50
+ "obfuscated": "f4c8d2a6",
51
+ "original": "100k-200k",
52
+ "category": "automotivo",
53
+ "pixel_audience": "AUDIENCE_MID"
54
+ },
55
+ {
56
+ "obfuscated": "a9b1e4c3",
57
+ "original": "200k-500k",
58
+ "category": "automotivo",
59
+ "pixel_audience": "AUDIENCE_PREMIUM"
60
+ }
61
+ ]
62
+ },
63
+ "instructions": "Preencha o array 'mappings' com as categorias do seu projeto. Use o comando 'node scripts/sync-agents.js' para sincronizar com o Agente UTM."
64
+ }
@@ -0,0 +1 @@
1
+ This folder contains the built output assets for the worker "server-edge-tracker" generated at 2026-04-14T21:31:47.480Z.