kontext-ai 0.1.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 (103) hide show
  1. package/.npmrccls +0 -0
  2. package/README.md +292 -0
  3. package/backend_dev_plan.md +446 -0
  4. package/context/base/instructions.yaml +3 -0
  5. package/context/base/preferences.yaml +5 -0
  6. package/context/skills/coding.yaml +5 -0
  7. package/dist/bin/start.d.ts +2 -0
  8. package/dist/bin/start.d.ts.map +1 -0
  9. package/dist/bin/start.js +34 -0
  10. package/dist/bin/start.js.map +1 -0
  11. package/dist/cli/index.d.ts +3 -0
  12. package/dist/cli/index.d.ts.map +1 -0
  13. package/dist/cli/index.js +258 -0
  14. package/dist/cli/index.js.map +1 -0
  15. package/dist/database/config.d.ts +9 -0
  16. package/dist/database/config.d.ts.map +1 -0
  17. package/dist/database/config.js +35 -0
  18. package/dist/database/config.js.map +1 -0
  19. package/dist/database/contextFiles.d.ts +35 -0
  20. package/dist/database/contextFiles.d.ts.map +1 -0
  21. package/dist/database/contextFiles.js +95 -0
  22. package/dist/database/contextFiles.js.map +1 -0
  23. package/dist/database/index.d.ts +5 -0
  24. package/dist/database/index.d.ts.map +1 -0
  25. package/dist/database/index.js +146 -0
  26. package/dist/database/index.js.map +1 -0
  27. package/dist/database/skills.d.ts +33 -0
  28. package/dist/database/skills.d.ts.map +1 -0
  29. package/dist/database/skills.js +89 -0
  30. package/dist/database/skills.js.map +1 -0
  31. package/dist/database/syncEvents.d.ts +28 -0
  32. package/dist/database/syncEvents.d.ts.map +1 -0
  33. package/dist/database/syncEvents.js +56 -0
  34. package/dist/database/syncEvents.js.map +1 -0
  35. package/dist/database/toolConfigs.d.ts +26 -0
  36. package/dist/database/toolConfigs.d.ts.map +1 -0
  37. package/dist/database/toolConfigs.js +77 -0
  38. package/dist/database/toolConfigs.js.map +1 -0
  39. package/dist/database/webhooks.d.ts +29 -0
  40. package/dist/database/webhooks.d.ts.map +1 -0
  41. package/dist/database/webhooks.js +89 -0
  42. package/dist/database/webhooks.js.map +1 -0
  43. package/dist/database.d.ts +8 -0
  44. package/dist/database.d.ts.map +1 -0
  45. package/dist/database.js +28 -0
  46. package/dist/database.js.map +1 -0
  47. package/dist/graphql/resolvers.d.ts +236 -0
  48. package/dist/graphql/resolvers.d.ts.map +1 -0
  49. package/dist/graphql/resolvers.js +280 -0
  50. package/dist/graphql/resolvers.js.map +1 -0
  51. package/dist/graphql/schema.d.ts +2 -0
  52. package/dist/graphql/schema.d.ts.map +1 -0
  53. package/dist/graphql/schema.js +215 -0
  54. package/dist/graphql/schema.js.map +1 -0
  55. package/dist/graphql/server.d.ts +2 -0
  56. package/dist/graphql/server.d.ts.map +1 -0
  57. package/dist/graphql/server.js +26 -0
  58. package/dist/graphql/server.js.map +1 -0
  59. package/dist/index.d.ts +9 -0
  60. package/dist/index.d.ts.map +1 -0
  61. package/dist/index.js +29 -0
  62. package/dist/index.js.map +1 -0
  63. package/dist/mcp/server.d.ts +2 -0
  64. package/dist/mcp/server.d.ts.map +1 -0
  65. package/dist/mcp/server.js +300 -0
  66. package/dist/mcp/server.js.map +1 -0
  67. package/dist/sync/engine.d.ts +25 -0
  68. package/dist/sync/engine.d.ts.map +1 -0
  69. package/dist/sync/engine.js +217 -0
  70. package/dist/sync/engine.js.map +1 -0
  71. package/dist/types/index.d.ts +57 -0
  72. package/dist/types/index.d.ts.map +1 -0
  73. package/dist/types/index.js +3 -0
  74. package/dist/types/index.js.map +1 -0
  75. package/dist/webhooks/server.d.ts +4 -0
  76. package/dist/webhooks/server.d.ts.map +1 -0
  77. package/dist/webhooks/server.js +157 -0
  78. package/dist/webhooks/server.js.map +1 -0
  79. package/frontend_plan.md +576 -0
  80. package/kontEXT.db +0 -0
  81. package/kontEXT.db-shm +0 -0
  82. package/kontEXT.db-wal +0 -0
  83. package/kontext.exe +0 -0
  84. package/package.json +60 -0
  85. package/src/bin/start.ts +41 -0
  86. package/src/cli/index.ts +310 -0
  87. package/src/database/config.ts +38 -0
  88. package/src/database/contextFiles.ts +127 -0
  89. package/src/database/index.ts +114 -0
  90. package/src/database/skills.ts +129 -0
  91. package/src/database/syncEvents.ts +89 -0
  92. package/src/database/toolConfigs.ts +101 -0
  93. package/src/database/webhooks.ts +117 -0
  94. package/src/graphql/resolvers.ts +357 -0
  95. package/src/graphql/schema.ts +211 -0
  96. package/src/graphql/server.ts +28 -0
  97. package/src/index.ts +8 -0
  98. package/src/mcp/server.ts +398 -0
  99. package/src/sync/engine.ts +231 -0
  100. package/src/types/index.ts +61 -0
  101. package/src/webhooks/server.ts +189 -0
  102. package/tsconfig.json +21 -0
  103. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,217 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.SyncEngine = void 0;
37
+ const fs = __importStar(require("fs"));
38
+ const path = __importStar(require("path"));
39
+ const index_1 = require("../database/index");
40
+ const config_1 = require("../database/config");
41
+ const contextFiles_1 = require("../database/contextFiles");
42
+ const syncEvents_1 = require("../database/syncEvents");
43
+ class SyncEngine {
44
+ constructor(options = {}) {
45
+ this.intervalId = null;
46
+ this.isRunning = false;
47
+ this.processedFiles = new Set();
48
+ const configDir = (0, config_1.getConfig)('contextDirectory');
49
+ const configInterval = (0, config_1.getConfig)('syncInterval');
50
+ this.contextDir = options.contextDirectory || (typeof configDir === 'string' ? configDir : './context');
51
+ this.syncInterval = options.syncInterval || (typeof configInterval === 'number' ? configInterval : 1000);
52
+ }
53
+ start() {
54
+ if (this.isRunning) {
55
+ console.error('Sync engine already running');
56
+ return;
57
+ }
58
+ (0, index_1.initializeDatabase)();
59
+ if (!fs.existsSync(this.contextDir)) {
60
+ fs.mkdirSync(this.contextDir, { recursive: true });
61
+ this.createSampleFiles();
62
+ }
63
+ this.isRunning = true;
64
+ this.intervalId = setInterval(() => this.sync(), this.syncInterval);
65
+ this.sync();
66
+ }
67
+ stop() {
68
+ if (this.intervalId) {
69
+ clearInterval(this.intervalId);
70
+ this.intervalId = null;
71
+ }
72
+ this.isRunning = false;
73
+ }
74
+ sync() {
75
+ const result = {
76
+ success: true,
77
+ filesProcessed: 0,
78
+ errors: []
79
+ };
80
+ try {
81
+ if (!fs.existsSync(this.contextDir)) {
82
+ result.errors.push(`Directory not found: ${this.contextDir}`);
83
+ result.success = false;
84
+ return result;
85
+ }
86
+ const files = this.walkDirectory(this.contextDir);
87
+ for (const file of files) {
88
+ try {
89
+ this.processFile(file);
90
+ result.filesProcessed++;
91
+ }
92
+ catch (error) {
93
+ result.errors.push(`Error processing ${file}: ${error}`);
94
+ result.success = false;
95
+ }
96
+ }
97
+ const dbFiles = (0, contextFiles_1.getAllContextFiles)();
98
+ for (const dbFile of dbFiles) {
99
+ if (!files.includes(dbFile.name) && !this.processedFiles.has(dbFile.name)) {
100
+ }
101
+ }
102
+ }
103
+ catch (error) {
104
+ result.errors.push(`Sync error: ${error}`);
105
+ result.success = false;
106
+ }
107
+ return result;
108
+ }
109
+ walkDirectory(dir) {
110
+ const files = [];
111
+ const items = fs.readdirSync(dir);
112
+ for (const item of items) {
113
+ const fullPath = path.join(dir, item);
114
+ const stat = fs.statSync(fullPath);
115
+ if (stat.isDirectory()) {
116
+ files.push(...this.walkDirectory(fullPath));
117
+ }
118
+ else if (stat.isFile()) {
119
+ const ext = path.extname(item).toLowerCase();
120
+ if (['.yaml', '.yml', '.json', '.md', '.markdown'].includes(ext)) {
121
+ files.push(fullPath);
122
+ }
123
+ }
124
+ }
125
+ return files;
126
+ }
127
+ processFile(filePath) {
128
+ const stat = fs.statSync(filePath);
129
+ const content = fs.readFileSync(filePath, 'utf-8');
130
+ const ext = path.extname(filePath).toLowerCase();
131
+ const relativePath = path.relative(this.contextDir, filePath);
132
+ const name = relativePath.replace(/\\/g, '/').replace(ext, '');
133
+ let type = 'base';
134
+ let format = 'yaml';
135
+ let tool;
136
+ if (ext === '.json')
137
+ format = 'json';
138
+ else if (ext === '.md' || ext === '.markdown')
139
+ format = 'markdown';
140
+ else
141
+ format = 'yaml';
142
+ const parts = relativePath.replace(/\\/g, '/').split('/');
143
+ if (parts.length > 1) {
144
+ const firstDir = parts[0].toLowerCase();
145
+ if (firstDir === 'skills' || firstDir === 'skill') {
146
+ type = 'skill';
147
+ }
148
+ else if (firstDir === 'preferences' || firstDir === 'preference') {
149
+ type = 'preference';
150
+ }
151
+ else if (firstDir === 'tools' || firstDir === 'tool') {
152
+ type = 'tool_override';
153
+ tool = parts[1].replace(ext, '');
154
+ }
155
+ }
156
+ this.processedFiles.add(name);
157
+ const existingFile = (0, contextFiles_1.getContextFileByName)(name);
158
+ if (existingFile) {
159
+ if (existingFile.content !== content || existingFile.type !== type) {
160
+ (0, contextFiles_1.updateContextFile)(existingFile.id, { content, type });
161
+ (0, syncEvents_1.createSyncEvent)({
162
+ action: 'updated',
163
+ entityType: 'context_file',
164
+ entityId: existingFile.id,
165
+ entityName: name,
166
+ status: 'success'
167
+ });
168
+ }
169
+ }
170
+ else {
171
+ const newFile = (0, contextFiles_1.createContextFile)({
172
+ name,
173
+ type,
174
+ tool,
175
+ content,
176
+ format
177
+ });
178
+ (0, syncEvents_1.createSyncEvent)({
179
+ action: 'created',
180
+ entityType: 'context_file',
181
+ entityId: newFile.id,
182
+ entityName: name,
183
+ status: 'success'
184
+ });
185
+ }
186
+ }
187
+ createSampleFiles() {
188
+ const baseDir = path.join(this.contextDir, 'base');
189
+ const skillsDir = path.join(this.contextDir, 'skills');
190
+ fs.mkdirSync(baseDir, { recursive: true });
191
+ fs.mkdirSync(skillsDir, { recursive: true });
192
+ const instructionsContent = `# Default Instructions
193
+
194
+ You are a helpful AI assistant. Be concise and direct in your responses.`;
195
+ const preferencesContent = `# Preferences
196
+
197
+ - Output format: markdown
198
+ - Tone: professional but friendly
199
+ - Code style: follow project conventions`;
200
+ const codingSkillContent = `# Coding Skills
201
+
202
+ - Expert in TypeScript and JavaScript
203
+ - Familiar with React, Node.js, and modern frameworks
204
+ - Follows clean code principles`;
205
+ fs.writeFileSync(path.join(baseDir, 'instructions.yaml'), instructionsContent);
206
+ fs.writeFileSync(path.join(baseDir, 'preferences.yaml'), preferencesContent);
207
+ fs.writeFileSync(path.join(skillsDir, 'coding.yaml'), codingSkillContent);
208
+ }
209
+ }
210
+ exports.SyncEngine = SyncEngine;
211
+ const syncEngine = new SyncEngine();
212
+ syncEngine.start();
213
+ process.on('SIGINT', () => {
214
+ syncEngine.stop();
215
+ process.exit(0);
216
+ });
217
+ //# sourceMappingURL=engine.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"engine.js","sourceRoot":"","sources":["../../src/sync/engine.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,57 @@
1
+ export interface ContextFile {
2
+ id: string;
3
+ name: string;
4
+ type: 'base' | 'skill' | 'preference' | 'tool_override';
5
+ tool?: string;
6
+ content: string;
7
+ format: 'yaml' | 'json' | 'markdown';
8
+ version: number;
9
+ createdAt: string;
10
+ updatedAt: string;
11
+ }
12
+ export interface ToolConfig {
13
+ id: string;
14
+ toolName: string;
15
+ toolType: 'mcp' | 'web' | 'cli' | 'api';
16
+ connectionStatus: 'connected' | 'disconnected' | 'pending';
17
+ lastUsed: string;
18
+ config: Record<string, unknown>;
19
+ }
20
+ export interface SyncEvent {
21
+ id: string;
22
+ timestamp: string;
23
+ action: 'created' | 'updated' | 'deleted' | 'synced';
24
+ entityType: 'context_file' | 'tool_config' | 'skill';
25
+ entityId: string;
26
+ entityName: string;
27
+ toolName?: string;
28
+ status: 'success' | 'pending' | 'failed';
29
+ error?: string;
30
+ }
31
+ export interface Skill {
32
+ id: string;
33
+ name: string;
34
+ description: string;
35
+ content: string;
36
+ category: string;
37
+ tags: string[];
38
+ createdAt: string;
39
+ updatedAt: string;
40
+ }
41
+ export interface Webhook {
42
+ id: string;
43
+ url: string;
44
+ name: string;
45
+ events: string[];
46
+ active: boolean;
47
+ lastTriggered?: string;
48
+ createdAt: string;
49
+ }
50
+ export interface AppConfig {
51
+ contextDirectory: string;
52
+ syncInterval: number;
53
+ autoSync: boolean;
54
+ darkMode: boolean;
55
+ port: number;
56
+ }
57
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,GAAG,OAAO,GAAG,YAAY,GAAG,eAAe,CAAC;IACxD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,UAAU,CAAC;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,UAAU;IACzB,EAAE,EAAE,MAAM,CAAC;IACX,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,KAAK,GAAG,KAAK,GAAG,KAAK,GAAG,KAAK,CAAC;IACxC,gBAAgB,EAAE,WAAW,GAAG,cAAc,GAAG,SAAS,CAAC;IAC3D,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAC;IACrD,UAAU,EAAE,cAAc,GAAG,aAAa,GAAG,OAAO,CAAC;IACrD,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,SAAS,GAAG,SAAS,GAAG,QAAQ,CAAC;IACzC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,MAAM,WAAW,KAAK;IACpB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;IAChB,QAAQ,EAAE,MAAM,CAAC;IACjB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,OAAO;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,MAAM,EAAE,OAAO,CAAC;IAChB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,SAAS;IACxB,gBAAgB,EAAE,MAAM,CAAC;IACzB,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,OAAO,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,IAAI,EAAE,MAAM,CAAC;CACd"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/types/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ declare function triggerWebhooks(event: string, data: unknown): Promise<void>;
2
+ export declare function startWebhookServer(): void;
3
+ export { triggerWebhooks };
4
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../../src/webhooks/server.ts"],"names":[],"mappings":"AAsBA,iBAAe,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CA6B1E;AA2HD,wBAAgB,kBAAkB,IAAI,IAAI,CAQzC;AAED,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -0,0 +1,157 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.startWebhookServer = startWebhookServer;
4
+ exports.triggerWebhooks = triggerWebhooks;
5
+ const http_1 = require("http");
6
+ const index_1 = require("../database/index");
7
+ const webhooks_1 = require("../database/webhooks");
8
+ const WEBHOOK_PORT = 4001;
9
+ async function triggerWebhooks(event, data) {
10
+ const webhooks = (0, webhooks_1.getWebhooksByEvent)(event);
11
+ const payload = {
12
+ event,
13
+ timestamp: new Date().toISOString(),
14
+ data,
15
+ };
16
+ for (const webhook of webhooks) {
17
+ try {
18
+ const response = await fetch(webhook.url, {
19
+ method: 'POST',
20
+ headers: {
21
+ 'Content-Type': 'application/json',
22
+ 'X-KONTEXT-Event': event,
23
+ 'X-KONTEXT-Webhook': webhook.id,
24
+ },
25
+ body: JSON.stringify(payload),
26
+ });
27
+ if (response.ok) {
28
+ (0, webhooks_1.markWebhookTriggered)(webhook.id);
29
+ }
30
+ else {
31
+ console.error(`Webhook failed: ${webhook.name} - Status ${response.status}`);
32
+ }
33
+ }
34
+ catch (error) {
35
+ console.error(`Webhook error: ${webhook.name} - ${error}`);
36
+ }
37
+ }
38
+ }
39
+ function parseBody(req) {
40
+ return new Promise((resolve, reject) => {
41
+ let body = '';
42
+ req.on('data', chunk => {
43
+ body += chunk.toString();
44
+ });
45
+ req.on('end', () => {
46
+ try {
47
+ resolve(JSON.parse(body));
48
+ }
49
+ catch {
50
+ resolve({});
51
+ }
52
+ });
53
+ req.on('error', reject);
54
+ });
55
+ }
56
+ function sendJson(res, status, data) {
57
+ res.writeHead(status, { 'Content-Type': 'application/json' });
58
+ res.end(JSON.stringify(data));
59
+ }
60
+ async function handleRequest(req, res) {
61
+ const url = req.url || '/';
62
+ const method = req.method || 'GET';
63
+ const path = url.split('?')[0];
64
+ const pathParts = path.split('/').filter(Boolean);
65
+ res.setHeader('Access-Control-Allow-Origin', '*');
66
+ res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE, OPTIONS');
67
+ res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
68
+ if (method === 'OPTIONS') {
69
+ res.writeHead(204);
70
+ res.end();
71
+ return;
72
+ }
73
+ try {
74
+ if (path === '/webhooks' && method === 'GET') {
75
+ const webhooks = (0, webhooks_1.getAllWebhooks)();
76
+ sendJson(res, 200, webhooks);
77
+ return;
78
+ }
79
+ if (path === '/webhooks' && method === 'POST') {
80
+ const body = await parseBody(req);
81
+ if (!body.url || !body.name) {
82
+ sendJson(res, 400, { error: 'url and name required' });
83
+ return;
84
+ }
85
+ const webhook = (0, webhooks_1.createWebhook)({
86
+ url: body.url,
87
+ name: body.name,
88
+ events: body.events || [],
89
+ });
90
+ sendJson(res, 201, webhook);
91
+ return;
92
+ }
93
+ if (path === '/webhooks/active' && method === 'GET') {
94
+ const webhooks = (0, webhooks_1.getActiveWebhooks)();
95
+ sendJson(res, 200, webhooks);
96
+ return;
97
+ }
98
+ if (pathParts[0] === 'webhooks' && pathParts[1] && method === 'GET') {
99
+ const webhookId = pathParts[1];
100
+ const webhooks = (0, webhooks_1.getAllWebhooks)();
101
+ const webhook = webhooks.find(w => w.id === webhookId);
102
+ if (!webhook) {
103
+ sendJson(res, 404, { error: 'Webhook not found' });
104
+ return;
105
+ }
106
+ sendJson(res, 200, webhook);
107
+ return;
108
+ }
109
+ if (pathParts[0] === 'webhooks' && pathParts[1] && method === 'PUT') {
110
+ const webhookId = pathParts[1];
111
+ const body = await parseBody(req);
112
+ const webhook = (0, webhooks_1.updateWebhook)(webhookId, body);
113
+ if (!webhook) {
114
+ sendJson(res, 404, { error: 'Webhook not found' });
115
+ return;
116
+ }
117
+ sendJson(res, 200, webhook);
118
+ return;
119
+ }
120
+ if (pathParts[0] === 'webhooks' && pathParts[1] && method === 'DELETE') {
121
+ const webhookId = pathParts[1];
122
+ const result = (0, webhooks_1.deleteWebhook)(webhookId);
123
+ sendJson(res, result ? 200 : 404, { success: result });
124
+ return;
125
+ }
126
+ if (path === '/trigger' && method === 'POST') {
127
+ const body = await parseBody(req);
128
+ if (!body.event) {
129
+ sendJson(res, 400, { error: 'event required' });
130
+ return;
131
+ }
132
+ await triggerWebhooks(body.event, body.data);
133
+ sendJson(res, 200, { success: true });
134
+ return;
135
+ }
136
+ if (path === '/health' && method === 'GET') {
137
+ sendJson(res, 200, { status: 'ok', timestamp: new Date().toISOString() });
138
+ return;
139
+ }
140
+ sendJson(res, 404, { error: 'Not found' });
141
+ }
142
+ catch (error) {
143
+ console.error('Request error:', error);
144
+ sendJson(res, 500, { error: 'Internal server error' });
145
+ }
146
+ }
147
+ function startWebhookServer() {
148
+ (0, index_1.initializeDatabase)();
149
+ const server = (0, http_1.createServer)(handleRequest);
150
+ server.listen(WEBHOOK_PORT, () => {
151
+ console.error(`Webhook server running on http://localhost:${WEBHOOK_PORT}`);
152
+ });
153
+ }
154
+ if (require.main === module) {
155
+ startWebhookServer();
156
+ }
157
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../../src/webhooks/server.ts"],"names":[],"mappings":"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"}