cdp-edge 1.23.3 → 1.24.1

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 (24) hide show
  1. package/README.md +44 -2
  2. package/bin/cdp-edge.js +10 -1
  3. package/contracts/types.ts +81 -0
  4. package/dist/commands/install.js +6 -1
  5. package/docs/whatsapp-ctwa.md +3 -2
  6. package/package.json +7 -4
  7. package/server-edge-tracker/{index.js → index.ts} +91 -82
  8. package/server-edge-tracker/modules/{db.js → db.ts} +116 -76
  9. package/server-edge-tracker/modules/dispatch/{ga4.js → ga4.ts} +12 -10
  10. package/server-edge-tracker/modules/dispatch/{meta.js → meta.ts} +35 -28
  11. package/server-edge-tracker/modules/dispatch/{platforms.js → platforms.ts} +58 -56
  12. package/server-edge-tracker/modules/dispatch/{tiktok.js → tiktok.ts} +22 -20
  13. package/server-edge-tracker/modules/dispatch/{whatsapp.js → whatsapp.ts} +59 -25
  14. package/server-edge-tracker/modules/{intelligence.js → intelligence.ts} +175 -60
  15. package/server-edge-tracker/modules/ml/{bidding.js → bidding.ts} +37 -35
  16. package/server-edge-tracker/modules/ml/{fraud.js → fraud.ts} +48 -40
  17. package/server-edge-tracker/modules/ml/{logistic.js → logistic.ts} +44 -19
  18. package/server-edge-tracker/modules/ml/{ltv.js → ltv.ts} +135 -90
  19. package/server-edge-tracker/modules/ml/{matchquality.js → matchquality.ts} +70 -26
  20. package/server-edge-tracker/modules/ml/{segmentation.js → segmentation.ts} +109 -48
  21. package/server-edge-tracker/modules/{utils.js → utils.ts} +41 -22
  22. package/server-edge-tracker/types.ts +251 -0
  23. package/server-edge-tracker/wrangler.toml +2 -2
  24. package/docs/PixelBuilder-Documentacao-Completa (2).docx +0 -0
package/README.md CHANGED
@@ -2,7 +2,9 @@
2
2
 
3
3
  **Padrão Quantum Tracking: 100% Cloudflare Edge.** Sem GTM. Sem Stape. Sem cookies de terceiros.
4
4
 
5
- > **v2.2.0** — Granite 4.0 Micro · K-means Vetorial Real (bge-m3) · Sem emails descartáveis · Cloudflare Workers · Meta CAPI v22.0 · GA4 MP · TikTok Events API v1.3
5
+ > **v2.3.0** — TypeScript Nativo · Worker 100% tipado · `types.ts` centralizado · `tsconfig.json` · `tsc --noEmit` zero erros · Cloudflare Workers · Meta CAPI v22.0 · GA4 MP · TikTok Events API v1.3
6
+
7
+ > ⚠️ **REGRA DE OURO (SQUAD):** Todas as atualizações, correções ou novas features devem OBRIGATORIAMENTE ser documentadas de forma sincronizada neste `README.md`, no arquivo de instruções `CLAUDE.md` e no dossiê de diretoria `CDP-EDGE-BUSINESS-BOOK.md`. Nenhuma alteração passa sem esse tripé.
6
8
 
7
9
  ---
8
10
 
@@ -25,6 +27,46 @@ Meu ecossistema opera como um Cérebro de Conversão Privado na borda. Quando um
25
27
 
26
28
  ---
27
29
 
30
+ ## 📋 CHANGELOG v2.3.0 — TypeScript Nativo (12 de Abril de 2026)
31
+
32
+ ### 🔷 Worker 100% TypeScript — Migração Completa
33
+
34
+ Todo o código server-side (`server-edge-tracker/`) foi migrado de JavaScript para **TypeScript nativo**. O Wrangler compila diretamente o `.ts` via esbuild — sem etapa de build separada, sem configuração extra.
35
+
36
+ **Por que TypeScript muda o jogo no CDP Edge:**
37
+ - **Env tipado** — typos em nomes de secrets (`META_ACCESS_TOKEN`, `GEO_CACHE`, `DB`) viram erros em build time, nunca em produção
38
+ - **TrackPayload contratado** — o shape do payload entre browser e Worker é garantido pelo compilador
39
+ - **Cloudflare types nativos** — D1, KV, R2, Workers AI com autocomplete e validação de métodos
40
+ - **Fraud Gate e ML seguros** — `checkFraudGate(env: Env, request: Request, payload: TrackPayload)` — nenhum `undefined` passa despercebido
41
+ - **Refatoração segura** — renomear qualquer campo do `TrackPayload` lista automaticamente todos os pontos de quebra
42
+
43
+ **Arquivos migrados (JS → TS) — 16 módulos:**
44
+ - `index.ts` — entry point do Worker
45
+ - `types.ts` — **novo** — contratos centralizados: `Env`, `TrackPayload`, `BehavioralData`, `HotmartWebhook`, `KiwifyWebhook`, `TictoWebhook`, `QueueMessage`, `PromiseResult<T>`
46
+ - `modules/utils.ts`, `modules/db.ts`, `modules/intelligence.ts`
47
+ - `modules/dispatch/` — `meta.ts`, `ga4.ts`, `tiktok.ts`, `platforms.ts`, `whatsapp.ts`
48
+ - `modules/ml/` — `ltv.ts`, `fraud.ts`, `bidding.ts`, `segmentation.ts`, `logistic.ts`, `matchquality.ts`
49
+
50
+ **Infraestrutura:**
51
+ - `tsconfig.json` — `target: ESNext`, `moduleResolution: "bundler"`, `strict: true`, `@cloudflare/workers-types`
52
+ - `wrangler.toml` — `main = "index.ts"` (TypeScript nativo via wrangler/esbuild)
53
+ - `contracts/types.ts` — tipos públicos exportados no pacote NPM: `QuantumEventPayload`, `AgencyContext`, `ApiVersionsConfig`
54
+ - `npm run typecheck` — `tsc --noEmit` (225 testes passando, zero erros de compilação)
55
+
56
+ **Breaking change:** nenhuma — API HTTP e comportamento em runtime são idênticos. TypeScript é invisível para o Cloudflare.
57
+
58
+ ---
59
+
60
+ ## 📋 CHANGELOG v2.2.5 (11 de Abril de 2026)
61
+
62
+ ### 🔧 Correção de Versão Dinâmica
63
+
64
+ - **Versão Dinâmica**: `bin/cdp-edge.js` e `dist/commands/install.js` agora leem a versão do `package.json` dinamicamente
65
+ - **Banner Corrigido**: O banner de instalação agora mostra sempre a versão correta (`cdp-edge --version`)
66
+ - **Compatibilidade**: Garante que a versão exibida no CLI e banner esteja sempre sincronizada com o `package.json`
67
+
68
+ ---
69
+
28
70
  ## 📋 CHANGELOG v2.2.0 (10 de Abril de 2026)
29
71
 
30
72
  ### 🤖 AI Engine Upgrade — Novos Modelos
@@ -55,7 +97,7 @@ Meu ecossistema opera como um Cérebro de Conversão Privado na borda. Quando um
55
97
  - **YouTube events**: `video_milestone`/`video_progress_25/50/75` → `video_25`/`video_50`/`video_75` (alinhado ao VALID_EVENT_NAMES do worker)
56
98
  - **LinkedIn CAPI**: endpoint `/rest/conversionEvents` + header `LinkedIn-Version: 202401` em `contracts/api-versions.json`
57
99
  - **Workers AI model**: `llama-3-8b-instruct` → `@cf/meta/llama-3.1-8b-instruct`
58
- - **worker.js**: Content-Length guard (413 se > 64KB), payload validation (allowlist 19 events, 512 chars, value range), PII removido dos logs
100
+ - **index.ts**: Content-Length guard (413 se > 64KB), payload validation (allowlist 19 events, 512 chars, value range), PII removido dos logs
59
101
  - **Testes**: bugs críticos em `deduplication.test.js` corrigidos (template literals escapados, prefixo errado)
60
102
  - **npm**: lodash 4.17.23 → 4.18.1, node-fetch removido
61
103
 
package/bin/cdp-edge.js CHANGED
@@ -5,6 +5,9 @@
5
5
  * Sistema multi-agente para tracking digital Quantum Tier
6
6
  */
7
7
 
8
+ import fs from 'fs';
9
+ import path from 'path';
10
+ import { fileURLToPath } from 'url';
8
11
  import { Command } from 'commander';
9
12
  import { runSetupWizard } from '../dist/commands/setup.js';
10
13
  import { runAnalyze } from '../dist/commands/analyze.js';
@@ -13,12 +16,18 @@ import { runValidate } from '../dist/commands/validate.js';
13
16
  import { runInfra } from '../dist/commands/infra.js';
14
17
  import { runInstall } from '../dist/commands/install.js';
15
18
 
19
+ // Ler versão do package.json
20
+ const __dirname = path.dirname(fileURLToPath(import.meta.url));
21
+ const packageJsonPath = path.join(__dirname, '..', 'package.json');
22
+ const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
23
+ const CDP_VERSION = packageJson.version;
24
+
16
25
  const program = new Command();
17
26
 
18
27
  program
19
28
  .name('cdp-edge')
20
29
  .description('CDP Edge Quantum Tier - Sistema multi-agente para tracking digital Cloudflare Native')
21
- .version('2.0.7');
30
+ .version(CDP_VERSION);
22
31
 
23
32
  // Comando padrão (wizard interativo)
24
33
  program
@@ -0,0 +1,81 @@
1
+ // CDP Edge Premium - API Contracts & Typings
2
+
3
+ export interface QuantumEventPayload {
4
+ eventName: string;
5
+ eventId: string;
6
+ userId: string;
7
+ email?: string | null;
8
+ phone?: string | null;
9
+ firstName?: string | null;
10
+ lastName?: string | null;
11
+ city?: string | null;
12
+ state?: string | null;
13
+ zip?: string | null;
14
+ country?: string | null;
15
+
16
+ // Identifiers
17
+ fbp?: string | null;
18
+ fbc?: string | null;
19
+ ttp?: string | null;
20
+ gaClientId?: string | null;
21
+
22
+ // Parameters
23
+ value?: number | null;
24
+ currency?: string;
25
+ contentIds?: string[];
26
+ contentName?: string;
27
+ contentType?: string;
28
+ pageUrl?: string;
29
+ orderId?: string;
30
+
31
+ // Quantum Tracking Details
32
+ intentScoreNum?: number | null;
33
+ metaSignal?: number;
34
+ distanceBucket?: string;
35
+ funnelLevel?: string;
36
+ botScore?: number;
37
+
38
+ // Any extra params
39
+ [key: string]: any;
40
+ }
41
+
42
+ export interface AgencyContext {
43
+ // Required Env mappings for specialists
44
+ META_ACCESS_TOKEN?: string;
45
+ META_PIXEL_ID?: string;
46
+ GA4_API_SECRET?: string;
47
+ GA4_MEASUREMENT_ID?: string;
48
+ TIKTOK_ACCESS_TOKEN?: string;
49
+ TIKTOK_PIXEL_ID?: string;
50
+ PINTEREST_ACCESS_TOKEN?: string;
51
+ PINTEREST_AD_ACCOUNT_ID?: string;
52
+ REDDIT_ACCESS_TOKEN?: string;
53
+ REDDIT_AD_ACCOUNT_ID?: string;
54
+ LINKEDIN_ACCESS_TOKEN?: string;
55
+ LINKEDIN_AD_ACCOUNT_ID?: string;
56
+ SPOTIFY_ACCESS_TOKEN?: string;
57
+ SPOTIFY_AD_ACCOUNT_ID?: string;
58
+
59
+ // Databases and Stores
60
+ DB?: any; // D1 Database
61
+ GEO_CACHE?: any; // KV Namespace
62
+ RATE_LIMITER?: any;
63
+ SITE_DOMAIN?: string;
64
+
65
+ [key: string]: any;
66
+ }
67
+
68
+ export interface ApiVersionsConfig {
69
+ metadata: {
70
+ version: string;
71
+ };
72
+ meta: any;
73
+ google: any;
74
+ tiktok: any;
75
+ pinterest: any;
76
+ reddit: any;
77
+ linkedin: any;
78
+ bing: any;
79
+ youtube: any;
80
+ spotify: any;
81
+ }
@@ -18,6 +18,11 @@ import chalk from 'chalk';
18
18
 
19
19
  const __dirname = path.dirname(fileURLToPath(import.meta.url));
20
20
 
21
+ // Ler versão do package.json
22
+ const packageJsonPath = path.join(__dirname, '..', '..', 'package.json');
23
+ const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf8'));
24
+ const CDP_VERSION = packageJson.version;
25
+
21
26
  // Raiz do pacote CDP Edge (2 níveis acima de dist/commands/)
22
27
  const CDP_EDGE_ROOT = path.resolve(__dirname, '..', '..');
23
28
 
@@ -32,7 +37,7 @@ function printBanner() {
32
37
  console.log(chalk.cyan('╚██████╗██████╔╝██║ ███████╗██████╔╝╚██████╔╝███████╗'));
33
38
  console.log(chalk.cyan(' ╚═════╝╚═════╝ ╚═╝ ╚══════╝╚═════╝ ╚═════╝╚══════╝'));
34
39
  console.log('');
35
- console.log(chalk.gray(' Customer Data Platform on the Edge · Global Edge Tracking · v2.0.9'));
40
+ console.log(chalk.gray(` Customer Data Platform on the Edge · Global Edge Tracking · v${CDP_VERSION}`));
36
41
  console.log('');
37
42
  console.log(chalk.gray('═'.repeat(68)));
38
43
  console.log('');
@@ -199,11 +199,12 @@ fetch('https://SEU_WORKER.SEU_USUARIO.workers.dev/track', {
199
199
 
200
200
  | Arquivo | Descrição |
201
201
  |---------|-----------|
202
- | `server-edge-tracker/worker.js` | Função `processWhatsAppWebhook()` (linha ~943) e rotas (linha ~2182) |
202
+ | `server-edge-tracker/modules/dispatch/whatsapp.ts` | Funções `processWhatsAppWebhook()`, `sendWhatsApp()`, `verifyHmac()` |
203
+ | `server-edge-tracker/index.ts` | Rotas `/webhook/whatsapp` (GET verify + POST mensagens) |
203
204
  | `server-edge-tracker/migrate-v6.sql` | Migration que criou a tabela `whatsapp_contacts` |
204
205
  | `server-edge-tracker/wrangler.toml` | Secret `WA_WEBHOOK_VERIFY_TOKEN` documentado |
205
206
  | `server-edge-tracker/schema.sql` | Schema completo do D1 (referência) |
206
207
 
207
208
  ---
208
209
 
209
- *Implementado em: 30 de março de 2026. CDP Edge v1.2 — WhatsApp CTWA Module.*
210
+ *Implementado em: 30 de março de 2026. CDP Edge v1.2 — WhatsApp CTWA Module. Migrado para TypeScript (`whatsapp.ts`) em 12 de abril de 2026 (v2.2.5+).*
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cdp-edge",
3
- "version": "1.23.3",
3
+ "version": "1.24.1",
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",
@@ -34,7 +34,8 @@
34
34
  "agents:check": "node scripts/validate-agents.js",
35
35
  "agents:sync": "node scripts/sync-agents.js",
36
36
  "agents:sync:list": "node scripts/sync-agents.js --list",
37
- "agents:sync:all": "node scripts/sync-agents.js --apply-all"
37
+ "agents:sync:all": "node scripts/sync-agents.js --apply-all",
38
+ "typecheck": "tsc --noEmit"
38
39
  },
39
40
  "keywords": [
40
41
  "pixel",
@@ -71,12 +72,14 @@
71
72
  "ora": "^8.0.0"
72
73
  },
73
74
  "devDependencies": {
75
+ "@cloudflare/workers-types": "^4.20260412.1",
74
76
  "@semantic-release/changelog": "^6.0.3",
75
77
  "@semantic-release/commit-analyzer": "^13.0.1",
76
78
  "@semantic-release/github": "^12.0.6",
77
79
  "@semantic-release/npm": "^13.1.5",
78
80
  "@semantic-release/release-notes-generator": "^14.1.0",
79
- "@types/node": "^20.0.0",
80
- "semantic-release": "^25.0.3"
81
+ "@types/node": "^20.19.39",
82
+ "semantic-release": "^25.0.3",
83
+ "typescript": "^6.0.2"
81
84
  }
82
85
  }