expxagents 0.12.2 → 0.13.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.
- package/dist/dashboard/assets/{BufferResource-DTKCcSRK.js → BufferResource-BMmxDv0X.js} +1 -1
- package/dist/dashboard/assets/{CanvasRenderer-RC-R9HHB.js → CanvasRenderer-C8lgY4Ra.js} +1 -1
- package/dist/dashboard/assets/{JarvisView-BxEaO5CE.js → JarvisView-CRecMJxY.js} +1 -1
- package/dist/dashboard/assets/{RenderTargetSystem-BNs6mZy_.js → RenderTargetSystem-DrrJs7jI.js} +1 -1
- package/dist/dashboard/assets/{WebGLRenderer-DZqhYwUo.js → WebGLRenderer-DzCm1r8W.js} +1 -1
- package/dist/dashboard/assets/{WebGPURenderer-DKvNGGnd.js → WebGPURenderer-DFAfTUvS.js} +1 -1
- package/dist/dashboard/assets/{browserAll-DpQDqd5Z.js → browserAll-D5H10uru.js} +1 -1
- package/dist/dashboard/assets/index-DHu3wE8e.css +1 -0
- package/dist/dashboard/assets/index-Dbrb96eX.js +400 -0
- package/dist/dashboard/assets/{webworkerAll-DKgN-y6e.js → webworkerAll-BuXYXspl.js} +1 -1
- package/dist/dashboard/index.html +2 -2
- package/dist/data/opensquad.db-shm +0 -0
- package/dist/data/opensquad.db-wal +0 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/graph-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/graph-routes.test.js +105 -0
- package/dist/server/api/__tests__/graph-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/integration-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/integration-routes.test.js +243 -0
- package/dist/server/api/__tests__/integration-routes.test.js.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts +2 -0
- package/dist/server/api/__tests__/team-routes.test.d.ts.map +1 -0
- package/dist/server/api/__tests__/team-routes.test.js +116 -0
- package/dist/server/api/__tests__/team-routes.test.js.map +1 -0
- package/dist/server/api/graph-routes.d.ts +24 -0
- package/dist/server/api/graph-routes.d.ts.map +1 -0
- package/dist/server/api/graph-routes.js +189 -0
- package/dist/server/api/graph-routes.js.map +1 -0
- package/dist/server/api/integration-routes.d.ts +23 -0
- package/dist/server/api/integration-routes.d.ts.map +1 -0
- package/dist/server/api/integration-routes.js +321 -0
- package/dist/server/api/integration-routes.js.map +1 -0
- package/dist/server/api/squads-routes.d.ts.map +1 -1
- package/dist/server/api/squads-routes.js +12 -1
- package/dist/server/api/squads-routes.js.map +1 -1
- package/dist/server/api/team-routes.d.ts +8 -0
- package/dist/server/api/team-routes.d.ts.map +1 -0
- package/dist/server/api/team-routes.js +55 -0
- package/dist/server/api/team-routes.js.map +1 -0
- package/dist/server/app.d.ts.map +1 -1
- package/dist/server/app.js +6 -0
- package/dist/server/app.js.map +1 -1
- package/dist/server/bridge/__tests__/claude-bridge.test.js +79 -11
- package/dist/server/bridge/__tests__/claude-bridge.test.js.map +1 -1
- package/dist/server/bridge/chat-handler.d.ts +6 -1
- package/dist/server/bridge/chat-handler.d.ts.map +1 -1
- package/dist/server/bridge/chat-handler.js +106 -5
- package/dist/server/bridge/chat-handler.js.map +1 -1
- package/dist/server/bridge/claude-bridge.d.ts +6 -0
- package/dist/server/bridge/claude-bridge.d.ts.map +1 -1
- package/dist/server/bridge/claude-bridge.js +90 -10
- package/dist/server/bridge/claude-bridge.js.map +1 -1
- package/dist/server/bridge/conversation.d.ts +1 -0
- package/dist/server/bridge/conversation.d.ts.map +1 -1
- package/dist/server/bridge/conversation.js +5 -0
- package/dist/server/bridge/conversation.js.map +1 -1
- package/dist/server/db/schema.d.ts +1 -1
- package/dist/server/db/schema.d.ts.map +1 -1
- package/dist/server/db/schema.js +18 -0
- package/dist/server/db/schema.js.map +1 -1
- package/dist/server/routes/__tests__/conversations.test.js +18 -1
- package/dist/server/routes/__tests__/conversations.test.js.map +1 -1
- package/dist/server/routes/conversations.d.ts.map +1 -1
- package/dist/server/routes/conversations.js +12 -1
- package/dist/server/routes/conversations.js.map +1 -1
- package/dist/server/ws/ws-handler.d.ts.map +1 -1
- package/dist/server/ws/ws-handler.js +17 -3
- package/dist/server/ws/ws-handler.js.map +1 -1
- package/package.json +1 -1
- package/dist/dashboard/assets/index-B-8_BLE5.css +0 -1
- package/dist/dashboard/assets/index-C_HJOTiO.js +0 -344
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
import fs from 'node:fs';
|
|
2
|
+
import path from 'node:path';
|
|
3
|
+
import { parse as parseYaml } from 'yaml';
|
|
4
|
+
function scanMarkdownLinks(filePath) {
|
|
5
|
+
try {
|
|
6
|
+
const content = fs.readFileSync(filePath, 'utf-8');
|
|
7
|
+
const links = [];
|
|
8
|
+
// Match markdown links [text](path) and wikilinks [[path]]
|
|
9
|
+
const mdLinkRegex = /\[([^\]]*)\]\(([^)]+\.md)\)/g;
|
|
10
|
+
const wikiLinkRegex = /\[\[([^\]]+\.md)\]\]/g;
|
|
11
|
+
let match;
|
|
12
|
+
while ((match = mdLinkRegex.exec(content)) !== null) {
|
|
13
|
+
links.push(match[2]);
|
|
14
|
+
}
|
|
15
|
+
while ((match = wikiLinkRegex.exec(content)) !== null) {
|
|
16
|
+
links.push(match[1]);
|
|
17
|
+
}
|
|
18
|
+
return links;
|
|
19
|
+
}
|
|
20
|
+
catch {
|
|
21
|
+
return [];
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
function buildGraph(squadsDir) {
|
|
25
|
+
const nodes = [];
|
|
26
|
+
const edges = [];
|
|
27
|
+
const nodeIds = new Set();
|
|
28
|
+
const skillUsers = new Map(); // skill -> node ids that use it
|
|
29
|
+
const memoryRefs = new Map(); // memory path -> node ids that ref it
|
|
30
|
+
if (!fs.existsSync(squadsDir))
|
|
31
|
+
return { nodes, edges };
|
|
32
|
+
const entries = fs.readdirSync(squadsDir, { withFileTypes: true });
|
|
33
|
+
for (const entry of entries) {
|
|
34
|
+
if (!entry.isDirectory() || entry.name.startsWith('.') || entry.name.startsWith('_'))
|
|
35
|
+
continue;
|
|
36
|
+
const squadDir = path.join(squadsDir, entry.name);
|
|
37
|
+
const yamlPath = path.join(squadDir, 'squad.yaml');
|
|
38
|
+
if (!fs.existsSync(yamlPath))
|
|
39
|
+
continue;
|
|
40
|
+
let parsed;
|
|
41
|
+
try {
|
|
42
|
+
parsed = parseYaml(fs.readFileSync(yamlPath, 'utf-8'));
|
|
43
|
+
}
|
|
44
|
+
catch {
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
const s = parsed?.squad;
|
|
48
|
+
if (!s)
|
|
49
|
+
continue;
|
|
50
|
+
const squadCode = s.code || entry.name;
|
|
51
|
+
const squadId = `squad:${squadCode}`;
|
|
52
|
+
// Squad node
|
|
53
|
+
nodes.push({ id: squadId, label: s.name || squadCode, type: 'squad' });
|
|
54
|
+
nodeIds.add(squadId);
|
|
55
|
+
// Skills
|
|
56
|
+
const skills = Array.isArray(s.skills) ? s.skills : [];
|
|
57
|
+
for (const skill of skills) {
|
|
58
|
+
const skillId = `skill:${skill}`;
|
|
59
|
+
if (!nodeIds.has(skillId)) {
|
|
60
|
+
nodes.push({ id: skillId, label: skill, type: 'skill' });
|
|
61
|
+
nodeIds.add(skillId);
|
|
62
|
+
}
|
|
63
|
+
edges.push({ source: squadId, target: skillId, type: 'uses_skill' });
|
|
64
|
+
if (!skillUsers.has(skill))
|
|
65
|
+
skillUsers.set(skill, []);
|
|
66
|
+
skillUsers.get(skill).push(squadId);
|
|
67
|
+
}
|
|
68
|
+
// Memory files
|
|
69
|
+
const memoryDir = path.join(squadDir, '_memory');
|
|
70
|
+
if (fs.existsSync(memoryDir)) {
|
|
71
|
+
const memFiles = fs.readdirSync(memoryDir).filter((f) => f.endsWith('.md'));
|
|
72
|
+
for (const mf of memFiles) {
|
|
73
|
+
const memId = `memory:${squadCode}/${mf}`;
|
|
74
|
+
nodes.push({ id: memId, label: mf.replace('.md', ''), type: 'memory', squad: squadCode });
|
|
75
|
+
nodeIds.add(memId);
|
|
76
|
+
edges.push({ source: squadId, target: memId, type: 'has_memory' });
|
|
77
|
+
const memPath = `_memory/${mf}`;
|
|
78
|
+
if (!memoryRefs.has(memPath))
|
|
79
|
+
memoryRefs.set(memPath, []);
|
|
80
|
+
memoryRefs.get(memPath).push(squadId);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
// Shared memory refs (company, preferences)
|
|
84
|
+
for (const ref of ['company', 'preferences', 'memory']) {
|
|
85
|
+
const refPath = s[ref];
|
|
86
|
+
if (typeof refPath === 'string' && refPath.includes('_expxagents/')) {
|
|
87
|
+
const sharedMemId = `memory:shared:${path.basename(refPath, '.md')}`;
|
|
88
|
+
if (!nodeIds.has(sharedMemId)) {
|
|
89
|
+
nodes.push({ id: sharedMemId, label: path.basename(refPath, '.md'), type: 'memory' });
|
|
90
|
+
nodeIds.add(sharedMemId);
|
|
91
|
+
}
|
|
92
|
+
edges.push({ source: squadId, target: sharedMemId, type: 'shared_memory' });
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
// Agents
|
|
96
|
+
const agents = Array.isArray(s.agents) ? s.agents : [];
|
|
97
|
+
const agentMap = new Map();
|
|
98
|
+
for (const agent of agents) {
|
|
99
|
+
const agentId = `agent:${squadCode}/${agent.id}`;
|
|
100
|
+
nodes.push({ id: agentId, label: agent.name || agent.id, type: 'agent', squad: squadCode });
|
|
101
|
+
nodeIds.add(agentId);
|
|
102
|
+
agentMap.set(agent.id, agentId);
|
|
103
|
+
edges.push({ source: squadId, target: agentId, type: 'contains' });
|
|
104
|
+
// Agent-level skills from frontmatter
|
|
105
|
+
if (agent.prompt) {
|
|
106
|
+
const promptPath = path.join(squadDir, agent.prompt);
|
|
107
|
+
if (fs.existsSync(promptPath)) {
|
|
108
|
+
try {
|
|
109
|
+
const content = fs.readFileSync(promptPath, 'utf-8');
|
|
110
|
+
const fmMatch = content.match(/^---\n([\s\S]*?)\n---/);
|
|
111
|
+
if (fmMatch) {
|
|
112
|
+
const fm = parseYaml(fmMatch[1]);
|
|
113
|
+
if (Array.isArray(fm?.skills)) {
|
|
114
|
+
for (const sk of fm.skills) {
|
|
115
|
+
const skId = `skill:${sk}`;
|
|
116
|
+
if (!nodeIds.has(skId)) {
|
|
117
|
+
nodes.push({ id: skId, label: sk, type: 'skill' });
|
|
118
|
+
nodeIds.add(skId);
|
|
119
|
+
}
|
|
120
|
+
edges.push({ source: agentId, target: skId, type: 'uses_skill' });
|
|
121
|
+
if (!skillUsers.has(sk))
|
|
122
|
+
skillUsers.set(sk, []);
|
|
123
|
+
skillUsers.get(sk).push(agentId);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
// base_agent reference
|
|
127
|
+
if (fm?.base_agent) {
|
|
128
|
+
const baseId = `skill:base:${fm.base_agent}`;
|
|
129
|
+
if (!nodeIds.has(baseId)) {
|
|
130
|
+
nodes.push({ id: baseId, label: fm.base_agent, type: 'skill' });
|
|
131
|
+
nodeIds.add(baseId);
|
|
132
|
+
}
|
|
133
|
+
edges.push({ source: agentId, target: baseId, type: 'uses_skill', label: 'base_agent' });
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
catch {
|
|
138
|
+
// skip
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
// Pipeline connections
|
|
144
|
+
const steps = s.pipeline?.steps;
|
|
145
|
+
if (Array.isArray(steps)) {
|
|
146
|
+
let prevAgentNodeId = null;
|
|
147
|
+
for (const step of steps) {
|
|
148
|
+
if (!step.agent)
|
|
149
|
+
continue;
|
|
150
|
+
const agentNodeId = agentMap.get(step.agent);
|
|
151
|
+
if (!agentNodeId)
|
|
152
|
+
continue;
|
|
153
|
+
if (step.deliverFrom) {
|
|
154
|
+
const fromNodeId = agentMap.get(step.deliverFrom);
|
|
155
|
+
if (fromNodeId) {
|
|
156
|
+
edges.push({ source: fromNodeId, target: agentNodeId, type: 'delivers', label: step.label });
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
else if (prevAgentNodeId && prevAgentNodeId !== agentNodeId) {
|
|
160
|
+
edges.push({ source: prevAgentNodeId, target: agentNodeId, type: 'pipeline' });
|
|
161
|
+
}
|
|
162
|
+
prevAgentNodeId = agentNodeId;
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
// Add shared_skill edges between squads that use the same skills
|
|
167
|
+
for (const [, users] of skillUsers) {
|
|
168
|
+
if (users.length <= 1)
|
|
169
|
+
continue;
|
|
170
|
+
const squadUsers = users.filter((u) => u.startsWith('squad:'));
|
|
171
|
+
for (let i = 0; i < squadUsers.length; i++) {
|
|
172
|
+
for (let j = i + 1; j < squadUsers.length; j++) {
|
|
173
|
+
const exists = edges.some((e) => e.type === 'shared_skill' && ((e.source === squadUsers[i] && e.target === squadUsers[j]) || (e.source === squadUsers[j] && e.target === squadUsers[i])));
|
|
174
|
+
if (!exists) {
|
|
175
|
+
edges.push({ source: squadUsers[i], target: squadUsers[j], type: 'shared_skill' });
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
return { nodes, edges };
|
|
181
|
+
}
|
|
182
|
+
export async function graphRoutes(app, opts) {
|
|
183
|
+
const { squadsDir } = opts;
|
|
184
|
+
app.get('/api/graph', { preHandler: [app.requireAuth] }, async () => {
|
|
185
|
+
return buildGraph(squadsDir);
|
|
186
|
+
});
|
|
187
|
+
}
|
|
188
|
+
export { buildGraph };
|
|
189
|
+
//# sourceMappingURL=graph-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph-routes.js","sourceRoot":"","sources":["../../src/api/graph-routes.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { FastifyInstance, FastifyPluginOptions } from 'fastify';
|
|
2
|
+
import type Database from 'better-sqlite3';
|
|
3
|
+
interface IntegrationRoutesOptions extends FastifyPluginOptions {
|
|
4
|
+
db: Database.Database;
|
|
5
|
+
}
|
|
6
|
+
export interface ProviderField {
|
|
7
|
+
key: string;
|
|
8
|
+
label: string;
|
|
9
|
+
type: 'text' | 'password' | 'url';
|
|
10
|
+
required?: boolean;
|
|
11
|
+
placeholder?: string;
|
|
12
|
+
}
|
|
13
|
+
export interface ProviderDefinition {
|
|
14
|
+
key: string;
|
|
15
|
+
name: string;
|
|
16
|
+
category: 'dev' | 'messaging' | 'ads' | 'crm' | 'support' | 'email' | 'sales' | 'pm' | 'monitoring' | 'cloud' | 'design';
|
|
17
|
+
description: string;
|
|
18
|
+
fields: ProviderField[];
|
|
19
|
+
}
|
|
20
|
+
export declare const PROVIDER_CATALOG: ProviderDefinition[];
|
|
21
|
+
export declare function integrationRoutes(app: FastifyInstance, opts: IntegrationRoutesOptions): Promise<void>;
|
|
22
|
+
export {};
|
|
23
|
+
//# sourceMappingURL=integration-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration-routes.d.ts","sourceRoot":"","sources":["../../src/api/integration-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AACrE,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAG3C,UAAU,wBAAyB,SAAQ,oBAAoB;IAC7D,EAAE,EAAE,QAAQ,CAAC,QAAQ,CAAC;CACvB;AAUD,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,MAAM,GAAG,UAAU,GAAG,KAAK,CAAC;IAClC,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,kBAAkB;IACjC,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,KAAK,GAAG,WAAW,GAAG,KAAK,GAAG,KAAK,GAAG,SAAS,GAAG,OAAO,GAAG,OAAO,GAAG,IAAI,GAAG,YAAY,GAAG,OAAO,GAAG,QAAQ,CAAC;IACzH,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,aAAa,EAAE,CAAC;CACzB;AAED,eAAO,MAAM,gBAAgB,EAAE,kBAAkB,EAoKhD,CAAC;AAgFF,wBAAsB,iBAAiB,CACrC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,wBAAwB,GAC7B,OAAO,CAAC,IAAI,CAAC,CAqHf"}
|
|
@@ -0,0 +1,321 @@
|
|
|
1
|
+
import { parseEnvFile, writeEnvFile } from './settings-routes.js';
|
|
2
|
+
export const PROVIDER_CATALOG = [
|
|
3
|
+
{ key: 'active_campaign', name: 'ActiveCampaign', category: 'email', description: 'Automação de marketing e CRM', fields: [
|
|
4
|
+
{ key: 'api_url', label: 'API URL', type: 'url', required: true, placeholder: 'https://myaccount.api-us1.com' },
|
|
5
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true },
|
|
6
|
+
] },
|
|
7
|
+
{ key: 'asaas', name: 'Asaas', category: 'sales', description: 'Cobranças, assinaturas e Pix para SaaS brasileiro', fields: [
|
|
8
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true, placeholder: '$aact_...' },
|
|
9
|
+
{ key: 'environment', label: 'Environment', type: 'text', placeholder: 'production ou sandbox' },
|
|
10
|
+
{ key: 'webhook_token', label: 'Webhook Token', type: 'password' },
|
|
11
|
+
] },
|
|
12
|
+
{ key: 'bitbucket', name: 'Bitbucket', category: 'dev', description: 'Repositórios Git e pipelines (Atlassian)', fields: [
|
|
13
|
+
{ key: 'username', label: 'Username', type: 'text', required: true },
|
|
14
|
+
{ key: 'app_password', label: 'App Password', type: 'password', required: true },
|
|
15
|
+
{ key: 'workspace', label: 'Workspace', type: 'text', required: true },
|
|
16
|
+
] },
|
|
17
|
+
{ key: 'brevo', name: 'Brevo', category: 'email', description: 'Email marketing e automação (ex-Sendinblue)', fields: [
|
|
18
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true, placeholder: 'xkeysib-...' },
|
|
19
|
+
] },
|
|
20
|
+
{ key: 'cloudflare', name: 'Cloudflare', category: 'cloud', description: 'DNS, CDN, Workers e segurança', fields: [
|
|
21
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
22
|
+
{ key: 'account_id', label: 'Account ID', type: 'text', required: true },
|
|
23
|
+
{ key: 'zone_id', label: 'Default Zone ID', type: 'text' },
|
|
24
|
+
] },
|
|
25
|
+
{ key: 'confluence', name: 'Confluence', category: 'pm', description: 'Documentação e wikis (Atlassian)', fields: [
|
|
26
|
+
{ key: 'base_url', label: 'Base URL', type: 'url', required: true, placeholder: 'https://mycompany.atlassian.net/wiki' },
|
|
27
|
+
{ key: 'email', label: 'Email', type: 'text', required: true },
|
|
28
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
29
|
+
{ key: 'space_key', label: 'Default Space Key', type: 'text' },
|
|
30
|
+
] },
|
|
31
|
+
{ key: 'discord', name: 'Discord', category: 'messaging', description: 'Bot e webhooks Discord', fields: [
|
|
32
|
+
{ key: 'bot_token', label: 'Bot Token', type: 'password', required: true },
|
|
33
|
+
{ key: 'webhook_url', label: 'Webhook URL', type: 'url', placeholder: 'https://discord.com/api/webhooks/...' },
|
|
34
|
+
{ key: 'server_id', label: 'Server ID', type: 'text' },
|
|
35
|
+
] },
|
|
36
|
+
{ key: 'eduzz', name: 'Eduzz', category: 'sales', description: 'Plataforma de venda de infoprodutos', fields: [
|
|
37
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true },
|
|
38
|
+
{ key: 'public_key', label: 'Public Key', type: 'password', required: true },
|
|
39
|
+
{ key: 'webhook_url', label: 'Webhook URL (receive)', type: 'url', placeholder: 'https://yourserver.com/webhooks/eduzz' },
|
|
40
|
+
] },
|
|
41
|
+
{ key: 'figma', name: 'Figma', category: 'design', description: 'Design de interfaces e handoff para devs', fields: [
|
|
42
|
+
{ key: 'access_token', label: 'Personal Access Token', type: 'password', required: true },
|
|
43
|
+
{ key: 'team_id', label: 'Team ID', type: 'text' },
|
|
44
|
+
{ key: 'default_file_key', label: 'Default File Key', type: 'text' },
|
|
45
|
+
] },
|
|
46
|
+
{ key: 'github', name: 'GitHub', category: 'dev', description: 'Repositórios, issues e pull requests', fields: [
|
|
47
|
+
{ key: 'token', label: 'Personal Access Token', type: 'password', required: true, placeholder: 'ghp_...' },
|
|
48
|
+
{ key: 'org', label: 'Organization', type: 'text', placeholder: 'my-org' },
|
|
49
|
+
{ key: 'default_repo', label: 'Default Repository', type: 'text', placeholder: 'my-repo' },
|
|
50
|
+
] },
|
|
51
|
+
{ key: 'gitlab', name: 'GitLab', category: 'dev', description: 'Repositórios, CI/CD e DevOps', fields: [
|
|
52
|
+
{ key: 'token', label: 'Personal Access Token', type: 'password', required: true, placeholder: 'glpat-...' },
|
|
53
|
+
{ key: 'base_url', label: 'Base URL', type: 'url', placeholder: 'https://gitlab.com (ou self-hosted)' },
|
|
54
|
+
{ key: 'default_project_id', label: 'Default Project ID', type: 'text' },
|
|
55
|
+
] },
|
|
56
|
+
{ key: 'google_ads', name: 'Google Ads', category: 'ads', description: 'Campanhas e anúncios Google', fields: [
|
|
57
|
+
{ key: 'client_id', label: 'Client ID', type: 'text', required: true },
|
|
58
|
+
{ key: 'client_secret', label: 'Client Secret', type: 'password', required: true },
|
|
59
|
+
{ key: 'developer_token', label: 'Developer Token', type: 'password', required: true },
|
|
60
|
+
{ key: 'customer_id', label: 'Customer ID', type: 'text', required: true, placeholder: '123-456-7890' },
|
|
61
|
+
{ key: 'refresh_token', label: 'Refresh Token', type: 'password', required: true },
|
|
62
|
+
] },
|
|
63
|
+
{ key: 'hotmart', name: 'Hotmart', category: 'sales', description: 'Plataforma de produtos digitais e afiliados', fields: [
|
|
64
|
+
{ key: 'client_id', label: 'Client ID', type: 'text', required: true },
|
|
65
|
+
{ key: 'client_secret', label: 'Client Secret', type: 'password', required: true },
|
|
66
|
+
{ key: 'basic_token', label: 'Basic Token', type: 'password', required: true },
|
|
67
|
+
{ key: 'hottok', label: 'Hottok (Webhook Token)', type: 'password', placeholder: 'Token para validar webhooks' },
|
|
68
|
+
] },
|
|
69
|
+
{ key: 'hubspot', name: 'HubSpot', category: 'crm', description: 'CRM, marketing e vendas', fields: [
|
|
70
|
+
{ key: 'access_token', label: 'Private App Access Token', type: 'password', required: true, placeholder: 'pat-...' },
|
|
71
|
+
{ key: 'portal_id', label: 'Portal ID', type: 'text' },
|
|
72
|
+
] },
|
|
73
|
+
{ key: 'instagram', name: 'Instagram', category: 'ads', description: 'Instagram Business API', fields: [
|
|
74
|
+
{ key: 'access_token', label: 'Access Token', type: 'password', required: true },
|
|
75
|
+
{ key: 'business_account_id', label: 'Business Account ID', type: 'text', required: true },
|
|
76
|
+
] },
|
|
77
|
+
{ key: 'intercom', name: 'Intercom', category: 'support', description: 'Engajamento e suporte ao cliente', fields: [
|
|
78
|
+
{ key: 'access_token', label: 'Access Token', type: 'password', required: true },
|
|
79
|
+
{ key: 'app_id', label: 'App ID', type: 'text' },
|
|
80
|
+
{ key: 'webhook_secret', label: 'Webhook Secret', type: 'password' },
|
|
81
|
+
] },
|
|
82
|
+
{ key: 'jira', name: 'Jira', category: 'dev', description: 'Gestão de projetos e tickets', fields: [
|
|
83
|
+
{ key: 'base_url', label: 'Base URL', type: 'url', required: true, placeholder: 'https://mycompany.atlassian.net' },
|
|
84
|
+
{ key: 'email', label: 'Email', type: 'text', required: true, placeholder: 'user@company.com' },
|
|
85
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
86
|
+
{ key: 'project_key', label: 'Default Project Key', type: 'text', placeholder: 'PROJ' },
|
|
87
|
+
] },
|
|
88
|
+
{ key: 'kiwify', name: 'Kiwify', category: 'sales', description: 'Plataforma de venda de cursos e infoprodutos', fields: [
|
|
89
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true },
|
|
90
|
+
{ key: 'webhook_secret', label: 'Webhook Secret', type: 'password', placeholder: 'Para validar webhooks recebidos' },
|
|
91
|
+
] },
|
|
92
|
+
{ key: 'lastlink', name: 'Lastlink', category: 'sales', description: 'Plataforma de monetização e assinaturas', fields: [
|
|
93
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
94
|
+
{ key: 'webhook_url', label: 'Webhook URL (receive)', type: 'url', placeholder: 'https://yourserver.com/webhooks/lastlink' },
|
|
95
|
+
] },
|
|
96
|
+
{ key: 'linear', name: 'Linear', category: 'pm', description: 'Gestão de projetos e issues para times de engenharia', fields: [
|
|
97
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true, placeholder: 'lin_api_...' },
|
|
98
|
+
{ key: 'team_id', label: 'Default Team ID', type: 'text' },
|
|
99
|
+
{ key: 'webhook_secret', label: 'Webhook Secret', type: 'password' },
|
|
100
|
+
] },
|
|
101
|
+
{ key: 'mercado_pago', name: 'Mercado Pago', category: 'sales', description: 'Pagamentos, Pix e checkout', fields: [
|
|
102
|
+
{ key: 'access_token', label: 'Access Token', type: 'password', required: true, placeholder: 'APP_USR-...' },
|
|
103
|
+
{ key: 'public_key', label: 'Public Key', type: 'text', required: true },
|
|
104
|
+
{ key: 'webhook_secret', label: 'Webhook Secret', type: 'password' },
|
|
105
|
+
] },
|
|
106
|
+
{ key: 'meta_ads', name: 'Meta Ads', category: 'ads', description: 'Facebook & Instagram Ads Manager', fields: [
|
|
107
|
+
{ key: 'access_token', label: 'Access Token', type: 'password', required: true },
|
|
108
|
+
{ key: 'ad_account_id', label: 'Ad Account ID', type: 'text', required: true, placeholder: 'act_123456' },
|
|
109
|
+
{ key: 'app_id', label: 'App ID', type: 'text', required: true },
|
|
110
|
+
{ key: 'app_secret', label: 'App Secret', type: 'password', required: true },
|
|
111
|
+
] },
|
|
112
|
+
{ key: 'movidesk', name: 'Movidesk', category: 'support', description: 'Helpdesk e atendimento ao cliente', fields: [
|
|
113
|
+
{ key: 'token', label: 'API Token', type: 'password', required: true },
|
|
114
|
+
{ key: 'base_url', label: 'Base URL', type: 'url', placeholder: 'https://mycompany.movidesk.com' },
|
|
115
|
+
] },
|
|
116
|
+
{ key: 'notion', name: 'Notion', category: 'pm', description: 'Docs, wikis e bases de conhecimento', fields: [
|
|
117
|
+
{ key: 'api_key', label: 'Integration Token', type: 'password', required: true, placeholder: 'secret_...' },
|
|
118
|
+
{ key: 'default_database_id', label: 'Default Database ID', type: 'text' },
|
|
119
|
+
] },
|
|
120
|
+
{ key: 'pipedrive', name: 'Pipedrive', category: 'crm', description: 'CRM e gestão de vendas', fields: [
|
|
121
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
122
|
+
{ key: 'company_domain', label: 'Company Domain', type: 'text', required: true, placeholder: 'mycompany' },
|
|
123
|
+
] },
|
|
124
|
+
{ key: 'rd_station', name: 'RD Station', category: 'crm', description: 'Marketing digital e CRM (líder no Brasil)', fields: [
|
|
125
|
+
{ key: 'client_id', label: 'Client ID', type: 'text', required: true },
|
|
126
|
+
{ key: 'client_secret', label: 'Client Secret', type: 'password', required: true },
|
|
127
|
+
{ key: 'access_token', label: 'Access Token', type: 'password' },
|
|
128
|
+
{ key: 'refresh_token', label: 'Refresh Token', type: 'password' },
|
|
129
|
+
] },
|
|
130
|
+
{ key: 'sentry', name: 'Sentry', category: 'monitoring', description: 'Monitoramento de erros e performance', fields: [
|
|
131
|
+
{ key: 'dsn', label: 'DSN', type: 'url', required: true, placeholder: 'https://xxx@sentry.io/123' },
|
|
132
|
+
{ key: 'auth_token', label: 'Auth Token', type: 'password', required: true },
|
|
133
|
+
{ key: 'org', label: 'Organization Slug', type: 'text', required: true },
|
|
134
|
+
{ key: 'project', label: 'Project Slug', type: 'text' },
|
|
135
|
+
] },
|
|
136
|
+
{ key: 'slack', name: 'Slack', category: 'messaging', description: 'Comunicação de time e notificações', fields: [
|
|
137
|
+
{ key: 'bot_token', label: 'Bot Token', type: 'password', required: true, placeholder: 'xoxb-...' },
|
|
138
|
+
{ key: 'signing_secret', label: 'Signing Secret', type: 'password', required: true },
|
|
139
|
+
{ key: 'default_channel', label: 'Default Channel', type: 'text', placeholder: '#general' },
|
|
140
|
+
{ key: 'webhook_url', label: 'Incoming Webhook URL', type: 'url' },
|
|
141
|
+
] },
|
|
142
|
+
{ key: 'stripe', name: 'Stripe', category: 'sales', description: 'Pagamentos e assinaturas internacionais', fields: [
|
|
143
|
+
{ key: 'secret_key', label: 'Secret Key', type: 'password', required: true, placeholder: 'sk_live_...' },
|
|
144
|
+
{ key: 'publishable_key', label: 'Publishable Key', type: 'text', required: true, placeholder: 'pk_live_...' },
|
|
145
|
+
{ key: 'webhook_secret', label: 'Webhook Secret', type: 'password', placeholder: 'whsec_...' },
|
|
146
|
+
] },
|
|
147
|
+
{ key: 'telegram', name: 'Telegram', category: 'messaging', description: 'Bot de mensagens Telegram', fields: [
|
|
148
|
+
{ key: 'bot_token', label: 'Bot Token', type: 'password', required: true, placeholder: '123456:ABC-DEF...' },
|
|
149
|
+
{ key: 'default_chat_id', label: 'Default Chat ID', type: 'text', placeholder: '-1001234567890' },
|
|
150
|
+
] },
|
|
151
|
+
{ key: 'vercel', name: 'Vercel', category: 'cloud', description: 'Deploy e hosting de aplicações web', fields: [
|
|
152
|
+
{ key: 'token', label: 'API Token', type: 'password', required: true },
|
|
153
|
+
{ key: 'team_id', label: 'Team ID', type: 'text' },
|
|
154
|
+
{ key: 'project_id', label: 'Default Project ID', type: 'text' },
|
|
155
|
+
] },
|
|
156
|
+
{ key: 'whatsapp', name: 'WhatsApp', category: 'messaging', description: 'Mensagens via WhatsApp Business API (Meta)', fields: [
|
|
157
|
+
{ key: 'api_key', label: 'API Key', type: 'password', required: true },
|
|
158
|
+
{ key: 'phone_number_id', label: 'Phone Number ID', type: 'text', required: true },
|
|
159
|
+
{ key: 'business_account_id', label: 'Business Account ID', type: 'text', required: true },
|
|
160
|
+
] },
|
|
161
|
+
{ key: 'zendesk', name: 'Zendesk', category: 'support', description: 'Helpdesk e atendimento ao cliente', fields: [
|
|
162
|
+
{ key: 'subdomain', label: 'Subdomain', type: 'text', required: true, placeholder: 'mycompany' },
|
|
163
|
+
{ key: 'email', label: 'Agent Email', type: 'text', required: true },
|
|
164
|
+
{ key: 'api_token', label: 'API Token', type: 'password', required: true },
|
|
165
|
+
] },
|
|
166
|
+
];
|
|
167
|
+
const PROVIDER_KEYS = new Set(PROVIDER_CATALOG.map((p) => p.key));
|
|
168
|
+
/** Mask a secret value — show first 4 and last 2 chars if long enough */
|
|
169
|
+
function maskValue(value) {
|
|
170
|
+
if (value.length <= 8)
|
|
171
|
+
return '••••••••';
|
|
172
|
+
return value.slice(0, 4) + '••••' + value.slice(-2);
|
|
173
|
+
}
|
|
174
|
+
/** Mask all password-type fields in a config object */
|
|
175
|
+
function maskConfig(provider, config) {
|
|
176
|
+
const def = PROVIDER_CATALOG.find((p) => p.key === provider);
|
|
177
|
+
if (!def)
|
|
178
|
+
return config;
|
|
179
|
+
const masked = {};
|
|
180
|
+
for (const [k, v] of Object.entries(config)) {
|
|
181
|
+
const field = def.fields.find((f) => f.key === k);
|
|
182
|
+
masked[k] = field?.type === 'password' && v ? maskValue(v) : v;
|
|
183
|
+
}
|
|
184
|
+
return masked;
|
|
185
|
+
}
|
|
186
|
+
/** Build env key from provider + field: github + token → GITHUB_TOKEN */
|
|
187
|
+
function envKey(provider, fieldKey) {
|
|
188
|
+
return `${provider}_${fieldKey}`.toUpperCase();
|
|
189
|
+
}
|
|
190
|
+
function getEnvPath() {
|
|
191
|
+
return process.env.DOTENV_PATH ?? new URL('../../../.env', import.meta.url).pathname;
|
|
192
|
+
}
|
|
193
|
+
/** Sync integration config values to .env so agents/squads can read them */
|
|
194
|
+
function syncToEnv(provider, config, enabled) {
|
|
195
|
+
try {
|
|
196
|
+
const envPath = getEnvPath();
|
|
197
|
+
const entries = parseEnvFile(envPath);
|
|
198
|
+
const def = PROVIDER_CATALOG.find((p) => p.key === provider);
|
|
199
|
+
if (!def)
|
|
200
|
+
return;
|
|
201
|
+
for (const field of def.fields) {
|
|
202
|
+
const key = envKey(provider, field.key);
|
|
203
|
+
const value = config[field.key];
|
|
204
|
+
if (enabled && value) {
|
|
205
|
+
entries.set(key, value);
|
|
206
|
+
process.env[key] = value;
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
entries.delete(key);
|
|
210
|
+
delete process.env[key];
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
writeEnvFile(envPath, entries);
|
|
214
|
+
}
|
|
215
|
+
catch {
|
|
216
|
+
// Non-fatal: env sync failure should not block the API response
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
/** Remove all env keys for a provider */
|
|
220
|
+
function removeFromEnv(provider) {
|
|
221
|
+
try {
|
|
222
|
+
const envPath = getEnvPath();
|
|
223
|
+
const entries = parseEnvFile(envPath);
|
|
224
|
+
const def = PROVIDER_CATALOG.find((p) => p.key === provider);
|
|
225
|
+
if (!def)
|
|
226
|
+
return;
|
|
227
|
+
for (const field of def.fields) {
|
|
228
|
+
const key = envKey(provider, field.key);
|
|
229
|
+
entries.delete(key);
|
|
230
|
+
delete process.env[key];
|
|
231
|
+
}
|
|
232
|
+
writeEnvFile(envPath, entries);
|
|
233
|
+
}
|
|
234
|
+
catch {
|
|
235
|
+
// Non-fatal
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
export async function integrationRoutes(app, opts) {
|
|
239
|
+
const { db } = opts;
|
|
240
|
+
// GET /api/integrations/catalog — list available providers with field definitions
|
|
241
|
+
app.get('/api/integrations/catalog', {
|
|
242
|
+
preHandler: [app.requireAuth],
|
|
243
|
+
}, async (_request, reply) => {
|
|
244
|
+
return reply.send({ providers: PROVIDER_CATALOG });
|
|
245
|
+
});
|
|
246
|
+
// GET /api/integrations — list all configured integrations (secrets masked)
|
|
247
|
+
app.get('/api/integrations', {
|
|
248
|
+
preHandler: [app.requireAuth],
|
|
249
|
+
}, async (_request, reply) => {
|
|
250
|
+
const rows = db.prepare('SELECT * FROM integrations ORDER BY provider ASC').all();
|
|
251
|
+
const integrations = rows.map((row) => {
|
|
252
|
+
const config = JSON.parse(row.config);
|
|
253
|
+
return {
|
|
254
|
+
provider: row.provider,
|
|
255
|
+
enabled: row.enabled === 1,
|
|
256
|
+
config: maskConfig(row.provider, config),
|
|
257
|
+
created_at: row.created_at,
|
|
258
|
+
updated_at: row.updated_at,
|
|
259
|
+
};
|
|
260
|
+
});
|
|
261
|
+
return reply.send({ integrations });
|
|
262
|
+
});
|
|
263
|
+
// PATCH /api/integrations/:provider — upsert config for a provider
|
|
264
|
+
app.patch('/api/integrations/:provider', {
|
|
265
|
+
preHandler: [app.requireAuth],
|
|
266
|
+
}, async (request, reply) => {
|
|
267
|
+
const { provider } = request.params;
|
|
268
|
+
if (!PROVIDER_KEYS.has(provider)) {
|
|
269
|
+
return reply.status(400).send({ error: `Unknown provider: ${provider}` });
|
|
270
|
+
}
|
|
271
|
+
const { enabled, config } = request.body;
|
|
272
|
+
const now = new Date().toISOString();
|
|
273
|
+
const existing = db.prepare('SELECT * FROM integrations WHERE provider = ?').get(provider);
|
|
274
|
+
if (existing) {
|
|
275
|
+
// Merge config: keep existing values for fields not provided, and preserve
|
|
276
|
+
// existing secrets when the client sends back masked values (••••)
|
|
277
|
+
const currentConfig = JSON.parse(existing.config);
|
|
278
|
+
let mergedConfig = currentConfig;
|
|
279
|
+
if (config) {
|
|
280
|
+
mergedConfig = { ...currentConfig };
|
|
281
|
+
for (const [k, v] of Object.entries(config)) {
|
|
282
|
+
// Skip masked values — keep the existing secret
|
|
283
|
+
if (v && v.includes('••••'))
|
|
284
|
+
continue;
|
|
285
|
+
mergedConfig[k] = v;
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
db.prepare('UPDATE integrations SET enabled = ?, config = ?, updated_at = ? WHERE provider = ?').run(enabled !== undefined ? (enabled ? 1 : 0) : existing.enabled, JSON.stringify(mergedConfig), now, provider);
|
|
289
|
+
}
|
|
290
|
+
else {
|
|
291
|
+
db.prepare('INSERT INTO integrations (provider, enabled, config, created_at, updated_at) VALUES (?, ?, ?, ?, ?)').run(provider, enabled ? 1 : 0, JSON.stringify(config || {}), now, now);
|
|
292
|
+
}
|
|
293
|
+
const row = db.prepare('SELECT * FROM integrations WHERE provider = ?').get(provider);
|
|
294
|
+
const savedConfig = JSON.parse(row.config);
|
|
295
|
+
// Sync to .env so agents/squads can use these values
|
|
296
|
+
syncToEnv(provider, savedConfig, row.enabled === 1);
|
|
297
|
+
return reply.send({
|
|
298
|
+
integration: {
|
|
299
|
+
provider: row.provider,
|
|
300
|
+
enabled: row.enabled === 1,
|
|
301
|
+
config: maskConfig(row.provider, savedConfig),
|
|
302
|
+
created_at: row.created_at,
|
|
303
|
+
updated_at: row.updated_at,
|
|
304
|
+
},
|
|
305
|
+
});
|
|
306
|
+
});
|
|
307
|
+
// DELETE /api/integrations/:provider — remove an integration
|
|
308
|
+
app.delete('/api/integrations/:provider', {
|
|
309
|
+
preHandler: [app.requireAuth],
|
|
310
|
+
}, async (request, reply) => {
|
|
311
|
+
const { provider } = request.params;
|
|
312
|
+
const result = db.prepare('DELETE FROM integrations WHERE provider = ?').run(provider);
|
|
313
|
+
if (result.changes === 0) {
|
|
314
|
+
return reply.status(404).send({ error: 'Integration not found' });
|
|
315
|
+
}
|
|
316
|
+
// Remove env keys for this provider
|
|
317
|
+
removeFromEnv(provider);
|
|
318
|
+
return reply.send({ ok: true });
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
//# sourceMappingURL=integration-routes.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"integration-routes.js","sourceRoot":"","sources":["../../src/api/integration-routes.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"squads-routes.d.ts","sourceRoot":"","sources":["../../src/api/squads-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAKrE,UAAU,mBAAoB,SAAQ,oBAAoB;IACxD,SAAS,EAAE,MAAM,CAAC;CACnB;
|
|
1
|
+
{"version":3,"file":"squads-routes.d.ts","sourceRoot":"","sources":["../../src/api/squads-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,oBAAoB,EAAE,MAAM,SAAS,CAAC;AAKrE,UAAU,mBAAoB,SAAQ,oBAAoB;IACxD,SAAS,EAAE,MAAM,CAAC;CACnB;AA4ED,wBAAsB,YAAY,CAChC,GAAG,EAAE,eAAe,EACpB,IAAI,EAAE,mBAAmB,GACxB,OAAO,CAAC,IAAI,CAAC,CAwDf"}
|