@rv404/mcp-launchpad 1.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 (139) hide show
  1. package/.env.example +29 -0
  2. package/README.md +248 -0
  3. package/dist/backends/clickup.d.ts +3 -0
  4. package/dist/backends/clickup.d.ts.map +1 -0
  5. package/dist/backends/clickup.js +1550 -0
  6. package/dist/backends/clickup.js.map +1 -0
  7. package/dist/backends/email.d.ts +9 -0
  8. package/dist/backends/email.d.ts.map +1 -0
  9. package/dist/backends/email.js +452 -0
  10. package/dist/backends/email.js.map +1 -0
  11. package/dist/backends/firecrawl.d.ts +3 -0
  12. package/dist/backends/firecrawl.d.ts.map +1 -0
  13. package/dist/backends/firecrawl.js +297 -0
  14. package/dist/backends/firecrawl.js.map +1 -0
  15. package/dist/backends/gemini.d.ts +3 -0
  16. package/dist/backends/gemini.d.ts.map +1 -0
  17. package/dist/backends/gemini.js +702 -0
  18. package/dist/backends/gemini.js.map +1 -0
  19. package/dist/backends/github.d.ts +3 -0
  20. package/dist/backends/github.d.ts.map +1 -0
  21. package/dist/backends/github.js +2129 -0
  22. package/dist/backends/github.js.map +1 -0
  23. package/dist/backends/index.d.ts +2 -0
  24. package/dist/backends/index.d.ts.map +1 -0
  25. package/dist/backends/index.js +27 -0
  26. package/dist/backends/index.js.map +1 -0
  27. package/dist/backends/kie.d.ts +3 -0
  28. package/dist/backends/kie.d.ts.map +1 -0
  29. package/dist/backends/kie.js +399 -0
  30. package/dist/backends/kie.js.map +1 -0
  31. package/dist/backends/n8n.d.ts +3 -0
  32. package/dist/backends/n8n.d.ts.map +1 -0
  33. package/dist/backends/n8n.js +414 -0
  34. package/dist/backends/n8n.js.map +1 -0
  35. package/dist/backends/notion.d.ts +3 -0
  36. package/dist/backends/notion.d.ts.map +1 -0
  37. package/dist/backends/notion.js +375 -0
  38. package/dist/backends/notion.js.map +1 -0
  39. package/dist/backends/quickbooks.d.ts +3 -0
  40. package/dist/backends/quickbooks.d.ts.map +1 -0
  41. package/dist/backends/quickbooks.js +2183 -0
  42. package/dist/backends/quickbooks.js.map +1 -0
  43. package/dist/backends/slack.d.ts +3 -0
  44. package/dist/backends/slack.d.ts.map +1 -0
  45. package/dist/backends/slack.js +1725 -0
  46. package/dist/backends/slack.js.map +1 -0
  47. package/dist/backends/youtube.d.ts +3 -0
  48. package/dist/backends/youtube.d.ts.map +1 -0
  49. package/dist/backends/youtube.js +936 -0
  50. package/dist/backends/youtube.js.map +1 -0
  51. package/dist/index.d.ts +3 -0
  52. package/dist/index.d.ts.map +1 -0
  53. package/dist/index.js +150 -0
  54. package/dist/index.js.map +1 -0
  55. package/dist/router.d.ts +36 -0
  56. package/dist/router.d.ts.map +1 -0
  57. package/dist/router.js +283 -0
  58. package/dist/router.js.map +1 -0
  59. package/dist/types.d.ts +103 -0
  60. package/dist/types.d.ts.map +1 -0
  61. package/dist/types.js +65 -0
  62. package/dist/types.js.map +1 -0
  63. package/lib/mcp-file-output/dist/index.d.ts +99 -0
  64. package/lib/mcp-file-output/dist/index.d.ts.map +1 -0
  65. package/lib/mcp-file-output/dist/index.js +215 -0
  66. package/lib/mcp-file-output/dist/index.js.map +1 -0
  67. package/lib/mcp-file-output/node_modules/@types/node/LICENSE +21 -0
  68. package/lib/mcp-file-output/node_modules/@types/node/README.md +15 -0
  69. package/lib/mcp-file-output/node_modules/@types/node/assert/strict.d.ts +8 -0
  70. package/lib/mcp-file-output/node_modules/@types/node/assert.d.ts +1062 -0
  71. package/lib/mcp-file-output/node_modules/@types/node/async_hooks.d.ts +605 -0
  72. package/lib/mcp-file-output/node_modules/@types/node/buffer.buffer.d.ts +471 -0
  73. package/lib/mcp-file-output/node_modules/@types/node/buffer.d.ts +1936 -0
  74. package/lib/mcp-file-output/node_modules/@types/node/child_process.d.ts +1475 -0
  75. package/lib/mcp-file-output/node_modules/@types/node/cluster.d.ts +577 -0
  76. package/lib/mcp-file-output/node_modules/@types/node/compatibility/disposable.d.ts +16 -0
  77. package/lib/mcp-file-output/node_modules/@types/node/compatibility/index.d.ts +9 -0
  78. package/lib/mcp-file-output/node_modules/@types/node/compatibility/indexable.d.ts +20 -0
  79. package/lib/mcp-file-output/node_modules/@types/node/compatibility/iterators.d.ts +21 -0
  80. package/lib/mcp-file-output/node_modules/@types/node/console.d.ts +452 -0
  81. package/lib/mcp-file-output/node_modules/@types/node/constants.d.ts +21 -0
  82. package/lib/mcp-file-output/node_modules/@types/node/crypto.d.ts +4590 -0
  83. package/lib/mcp-file-output/node_modules/@types/node/dgram.d.ts +597 -0
  84. package/lib/mcp-file-output/node_modules/@types/node/diagnostics_channel.d.ts +578 -0
  85. package/lib/mcp-file-output/node_modules/@types/node/dns/promises.d.ts +479 -0
  86. package/lib/mcp-file-output/node_modules/@types/node/dns.d.ts +871 -0
  87. package/lib/mcp-file-output/node_modules/@types/node/domain.d.ts +170 -0
  88. package/lib/mcp-file-output/node_modules/@types/node/events.d.ts +977 -0
  89. package/lib/mcp-file-output/node_modules/@types/node/fs/promises.d.ts +1270 -0
  90. package/lib/mcp-file-output/node_modules/@types/node/fs.d.ts +4375 -0
  91. package/lib/mcp-file-output/node_modules/@types/node/globals.d.ts +172 -0
  92. package/lib/mcp-file-output/node_modules/@types/node/globals.typedarray.d.ts +38 -0
  93. package/lib/mcp-file-output/node_modules/@types/node/http.d.ts +2049 -0
  94. package/lib/mcp-file-output/node_modules/@types/node/http2.d.ts +2631 -0
  95. package/lib/mcp-file-output/node_modules/@types/node/https.d.ts +578 -0
  96. package/lib/mcp-file-output/node_modules/@types/node/index.d.ts +93 -0
  97. package/lib/mcp-file-output/node_modules/@types/node/inspector.generated.d.ts +3966 -0
  98. package/lib/mcp-file-output/node_modules/@types/node/module.d.ts +539 -0
  99. package/lib/mcp-file-output/node_modules/@types/node/net.d.ts +1012 -0
  100. package/lib/mcp-file-output/node_modules/@types/node/os.d.ts +506 -0
  101. package/lib/mcp-file-output/node_modules/@types/node/package.json +140 -0
  102. package/lib/mcp-file-output/node_modules/@types/node/path.d.ts +200 -0
  103. package/lib/mcp-file-output/node_modules/@types/node/perf_hooks.d.ts +961 -0
  104. package/lib/mcp-file-output/node_modules/@types/node/process.d.ts +1957 -0
  105. package/lib/mcp-file-output/node_modules/@types/node/punycode.d.ts +117 -0
  106. package/lib/mcp-file-output/node_modules/@types/node/querystring.d.ts +152 -0
  107. package/lib/mcp-file-output/node_modules/@types/node/readline/promises.d.ts +162 -0
  108. package/lib/mcp-file-output/node_modules/@types/node/readline.d.ts +589 -0
  109. package/lib/mcp-file-output/node_modules/@types/node/repl.d.ts +430 -0
  110. package/lib/mcp-file-output/node_modules/@types/node/sea.d.ts +153 -0
  111. package/lib/mcp-file-output/node_modules/@types/node/stream/consumers.d.ts +38 -0
  112. package/lib/mcp-file-output/node_modules/@types/node/stream/promises.d.ts +90 -0
  113. package/lib/mcp-file-output/node_modules/@types/node/stream/web.d.ts +533 -0
  114. package/lib/mcp-file-output/node_modules/@types/node/stream.d.ts +1675 -0
  115. package/lib/mcp-file-output/node_modules/@types/node/string_decoder.d.ts +67 -0
  116. package/lib/mcp-file-output/node_modules/@types/node/test.d.ts +1787 -0
  117. package/lib/mcp-file-output/node_modules/@types/node/timers/promises.d.ts +108 -0
  118. package/lib/mcp-file-output/node_modules/@types/node/timers.d.ts +286 -0
  119. package/lib/mcp-file-output/node_modules/@types/node/tls.d.ts +1255 -0
  120. package/lib/mcp-file-output/node_modules/@types/node/trace_events.d.ts +197 -0
  121. package/lib/mcp-file-output/node_modules/@types/node/ts5.6/buffer.buffer.d.ts +468 -0
  122. package/lib/mcp-file-output/node_modules/@types/node/ts5.6/globals.typedarray.d.ts +34 -0
  123. package/lib/mcp-file-output/node_modules/@types/node/ts5.6/index.d.ts +93 -0
  124. package/lib/mcp-file-output/node_modules/@types/node/tty.d.ts +208 -0
  125. package/lib/mcp-file-output/node_modules/@types/node/url.d.ts +964 -0
  126. package/lib/mcp-file-output/node_modules/@types/node/util.d.ts +2331 -0
  127. package/lib/mcp-file-output/node_modules/@types/node/v8.d.ts +809 -0
  128. package/lib/mcp-file-output/node_modules/@types/node/vm.d.ts +1001 -0
  129. package/lib/mcp-file-output/node_modules/@types/node/wasi.d.ts +181 -0
  130. package/lib/mcp-file-output/node_modules/@types/node/web-globals/abortcontroller.d.ts +34 -0
  131. package/lib/mcp-file-output/node_modules/@types/node/web-globals/domexception.d.ts +68 -0
  132. package/lib/mcp-file-output/node_modules/@types/node/web-globals/events.d.ts +97 -0
  133. package/lib/mcp-file-output/node_modules/@types/node/web-globals/fetch.d.ts +46 -0
  134. package/lib/mcp-file-output/node_modules/@types/node/worker_threads.d.ts +715 -0
  135. package/lib/mcp-file-output/node_modules/@types/node/zlib.d.ts +540 -0
  136. package/lib/mcp-file-output/package.json +19 -0
  137. package/lib/mcp-file-output/src/index.ts +309 -0
  138. package/lib/mcp-file-output/tsconfig.json +20 -0
  139. package/package.json +64 -0
@@ -0,0 +1,103 @@
1
+ import { z } from 'zod';
2
+ export interface BackendActionParam {
3
+ name: string;
4
+ type: string;
5
+ required: boolean;
6
+ description: string;
7
+ enum?: string[];
8
+ }
9
+ export interface BackendAction {
10
+ name: string;
11
+ description: string;
12
+ params: BackendActionParam[];
13
+ }
14
+ export type ActionDef = BackendAction;
15
+ export interface Backend {
16
+ name: string;
17
+ description: string;
18
+ actions: BackendAction[];
19
+ execute(action: string, params: Record<string, unknown>): Promise<unknown>;
20
+ healthCheck(): Promise<HealthStatus>;
21
+ }
22
+ export interface HealthStatus {
23
+ status: 'healthy' | 'degraded' | 'unavailable';
24
+ latency_ms?: number;
25
+ error?: string;
26
+ }
27
+ export interface HealthReport {
28
+ router_version: string;
29
+ timestamp: string;
30
+ services: Record<string, HealthStatus>;
31
+ }
32
+ export interface RequestContext {
33
+ requestId: string;
34
+ service: string;
35
+ action: string;
36
+ startTime: number;
37
+ }
38
+ export interface RouterSuccessResponse {
39
+ success: true;
40
+ requestId: string;
41
+ service: string;
42
+ action: string;
43
+ duration_ms: number;
44
+ data: unknown;
45
+ }
46
+ export interface RouterErrorResponse {
47
+ success: false;
48
+ requestId: string;
49
+ service: string;
50
+ action: string;
51
+ error: {
52
+ type: 'auth' | 'rate_limit' | 'timeout' | 'network' | 'validation' | 'service_unavailable' | 'unknown_action' | 'unknown';
53
+ message: string;
54
+ retryable: boolean;
55
+ retryAfter?: number;
56
+ };
57
+ }
58
+ export type RouterResponse = RouterSuccessResponse | RouterErrorResponse;
59
+ export interface RetryConfig {
60
+ maxAttempts: number;
61
+ initialDelayMs: number;
62
+ maxDelayMs: number;
63
+ backoffMultiplier: number;
64
+ retryableErrors: string[];
65
+ }
66
+ export declare const DEFAULT_RETRY_CONFIG: RetryConfig;
67
+ export declare const DEFAULT_TIMEOUTS: Record<string, number>;
68
+ export declare const ACTION_TIMEOUT_OVERRIDES: Record<string, Record<string, number>>;
69
+ export type LogLevel = 'error' | 'warn' | 'info' | 'debug';
70
+ export interface LogEntry {
71
+ timestamp: string;
72
+ level: LogLevel;
73
+ requestId?: string;
74
+ service?: string;
75
+ action?: string;
76
+ duration_ms?: number;
77
+ error?: string;
78
+ message: string;
79
+ [key: string]: unknown;
80
+ }
81
+ export declare const SERVICES: readonly ["clickup", "notion", "github", "slack", "n8n", "gemini", "quickbooks", "firecrawl", "youtube", "kie", "email"];
82
+ export type ServiceName = typeof SERVICES[number];
83
+ export declare const RouteRequestSchema: z.ZodObject<{
84
+ service: z.ZodEnum<["clickup", "notion", "github", "slack", "n8n", "gemini", "quickbooks", "firecrawl", "youtube", "kie", "email"]>;
85
+ action: z.ZodString;
86
+ params: z.ZodDefault<z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
87
+ }, "strip", z.ZodTypeAny, {
88
+ service: "clickup" | "notion" | "github" | "slack" | "n8n" | "gemini" | "quickbooks" | "firecrawl" | "youtube" | "kie" | "email";
89
+ action: string;
90
+ params: Record<string, unknown>;
91
+ }, {
92
+ service: "clickup" | "notion" | "github" | "slack" | "n8n" | "gemini" | "quickbooks" | "firecrawl" | "youtube" | "kie" | "email";
93
+ action: string;
94
+ params?: Record<string, unknown> | undefined;
95
+ }>;
96
+ export declare const ListActionsSchema: z.ZodObject<{
97
+ service: z.ZodEnum<["clickup", "notion", "github", "slack", "n8n", "gemini", "quickbooks", "firecrawl", "youtube", "kie", "email"]>;
98
+ }, "strip", z.ZodTypeAny, {
99
+ service: "clickup" | "notion" | "github" | "slack" | "n8n" | "gemini" | "quickbooks" | "firecrawl" | "youtube" | "kie" | "email";
100
+ }, {
101
+ service: "clickup" | "notion" | "github" | "slack" | "n8n" | "gemini" | "quickbooks" | "firecrawl" | "youtube" | "kie" | "email";
102
+ }>;
103
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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"}
package/dist/types.js ADDED
@@ -0,0 +1,65 @@
1
+ import { z } from 'zod';
2
+ export const DEFAULT_RETRY_CONFIG = {
3
+ maxAttempts: 3,
4
+ initialDelayMs: 1000,
5
+ maxDelayMs: 10000,
6
+ backoffMultiplier: 2,
7
+ retryableErrors: ['timeout', 'network', 'service_unavailable']
8
+ };
9
+ // ============================================================================
10
+ // Timeout Configuration
11
+ // ============================================================================
12
+ export const DEFAULT_TIMEOUTS = {
13
+ clickup: 30000,
14
+ notion: 30000,
15
+ github: 60000,
16
+ slack: 15000,
17
+ n8n: 120000,
18
+ gemini: 90000,
19
+ quickbooks: 30000,
20
+ firecrawl: 300000, // 5 minutes - crawling can take time
21
+ youtube: 120000, // 2 minutes - transcript fetching and analysis
22
+ kie: 90000, // 1.5 minutes - image generation with polling
23
+ email: 60000, // 1 minute - email operations
24
+ };
25
+ export const ACTION_TIMEOUT_OVERRIDES = {
26
+ n8n: {
27
+ test_workflow: 180000,
28
+ deploy_template: 60000,
29
+ },
30
+ github: {
31
+ push_files: 120000,
32
+ merge_pull_request: 60000,
33
+ },
34
+ gemini: {
35
+ generate_image: 120000,
36
+ },
37
+ quickbooks: {
38
+ query: 60000,
39
+ },
40
+ youtube: {
41
+ download_video: 300000, // 5 minutes for video downloads
42
+ download_audio: 180000, // 3 minutes for audio extraction
43
+ analyze: 180000, // 3 minutes for full analysis
44
+ },
45
+ kie: {
46
+ generate_image_pro: 120000, // 2 minutes for high-res generation
47
+ edit_image: 180000, // 3 minutes for multi-image editing
48
+ },
49
+ };
50
+ // ============================================================================
51
+ // Service List
52
+ // ============================================================================
53
+ export const SERVICES = ['clickup', 'notion', 'github', 'slack', 'n8n', 'gemini', 'quickbooks', 'firecrawl', 'youtube', 'kie', 'email'];
54
+ // ============================================================================
55
+ // Zod Schemas for Input Validation
56
+ // ============================================================================
57
+ export const RouteRequestSchema = z.object({
58
+ service: z.enum(SERVICES),
59
+ action: z.string().min(1),
60
+ params: z.record(z.unknown()).optional().default({}),
61
+ });
62
+ export const ListActionsSchema = z.object({
63
+ service: z.enum(SERVICES),
64
+ });
65
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AA8FxB,MAAM,CAAC,MAAM,oBAAoB,GAAgB;IAC/C,WAAW,EAAE,CAAC;IACd,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,KAAK;IACjB,iBAAiB,EAAE,CAAC;IACpB,eAAe,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,qBAAqB,CAAC;CAC/D,CAAC;AAEF,+EAA+E;AAC/E,wBAAwB;AACxB,+EAA+E;AAE/E,MAAM,CAAC,MAAM,gBAAgB,GAA2B;IACtD,OAAO,EAAE,KAAK;IACd,MAAM,EAAE,KAAK;IACb,MAAM,EAAE,KAAK;IACb,KAAK,EAAE,KAAK;IACZ,GAAG,EAAE,MAAM;IACX,MAAM,EAAE,KAAK;IACb,UAAU,EAAE,KAAK;IACjB,SAAS,EAAE,MAAM,EAAE,qCAAqC;IACxD,OAAO,EAAE,MAAM,EAAE,+CAA+C;IAChE,GAAG,EAAE,KAAK,EAAE,8CAA8C;IAC1D,KAAK,EAAE,KAAK,EAAE,8BAA8B;CAC7C,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAA2C;IAC9E,GAAG,EAAE;QACH,aAAa,EAAE,MAAM;QACrB,eAAe,EAAE,KAAK;KACvB;IACD,MAAM,EAAE;QACN,UAAU,EAAE,MAAM;QAClB,kBAAkB,EAAE,KAAK;KAC1B;IACD,MAAM,EAAE;QACN,cAAc,EAAE,MAAM;KACvB;IACD,UAAU,EAAE;QACV,KAAK,EAAE,KAAK;KACb;IACD,OAAO,EAAE;QACP,cAAc,EAAE,MAAM,EAAE,gCAAgC;QACxD,cAAc,EAAE,MAAM,EAAE,iCAAiC;QACzD,OAAO,EAAE,MAAM,EAAE,8BAA8B;KAChD;IACD,GAAG,EAAE;QACH,kBAAkB,EAAE,MAAM,EAAE,oCAAoC;QAChE,UAAU,EAAE,MAAM,EAAE,oCAAoC;KACzD;CACF,CAAC;AAoBF,+EAA+E;AAC/E,eAAe;AACf,+EAA+E;AAE/E,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,SAAS,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,YAAY,EAAE,WAAW,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,CAAU,CAAC;AAGjJ,+EAA+E;AAC/E,mCAAmC;AACnC,+EAA+E;AAE/E,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;IACzB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;IACzB,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC;CACrD,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,CAAC,MAAM,CAAC;IACxC,OAAO,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;CAC1B,CAAC,CAAC"}
@@ -0,0 +1,99 @@
1
+ /**
2
+ * Initialize the file output utility with a custom data root
3
+ */
4
+ export declare function init(dataRoot: string): void;
5
+ /**
6
+ * Get the current data root directory
7
+ */
8
+ export declare function getDataRoot(): string;
9
+ export interface FileOutputConfig {
10
+ service: string;
11
+ action: string;
12
+ outputType?: 'temp' | 'outputs' | 'cache';
13
+ filename?: string;
14
+ subdir?: string;
15
+ }
16
+ export interface FileOutputResult {
17
+ saved: boolean;
18
+ path?: string;
19
+ dir?: string;
20
+ files?: string[];
21
+ manifest?: string;
22
+ bytesSaved?: number;
23
+ reason?: string;
24
+ }
25
+ export interface ManifestEntry {
26
+ filename: string;
27
+ url?: string;
28
+ title?: string;
29
+ timestamp: string;
30
+ bytes: number;
31
+ }
32
+ export interface OutputManifest {
33
+ service: string;
34
+ action: string;
35
+ created: string;
36
+ totalFiles: number;
37
+ totalBytes: number;
38
+ files: ManifestEntry[];
39
+ metadata?: Record<string, unknown>;
40
+ }
41
+ /**
42
+ * Determines if a response should be saved to disk based on size
43
+ */
44
+ export declare function shouldSaveToDisk(data: unknown, forceFile?: boolean): boolean;
45
+ /**
46
+ * Gets the output directory path for a given configuration
47
+ */
48
+ export declare function getOutputDir(config: FileOutputConfig): string;
49
+ /**
50
+ * Saves a single file and returns the result
51
+ */
52
+ export declare function saveFile(data: string | Buffer, config: FileOutputConfig): Promise<FileOutputResult>;
53
+ /**
54
+ * Saves multiple files with a manifest - ideal for crawl results
55
+ */
56
+ export declare function saveMultipleFiles(files: Array<{
57
+ filename: string;
58
+ content: string;
59
+ url?: string;
60
+ title?: string;
61
+ }>, config: FileOutputConfig, metadata?: Record<string, unknown>): Promise<FileOutputResult>;
62
+ /**
63
+ * Saves large response data automatically if it exceeds threshold
64
+ * Returns either the original data (if small) or a reference to saved file(s)
65
+ */
66
+ export declare function handleLargeResponse<T>(data: T, config: FileOutputConfig, options?: {
67
+ forceFile?: boolean;
68
+ returnData?: boolean;
69
+ }): Promise<{
70
+ data: T;
71
+ fileOutput?: FileOutputResult;
72
+ } | {
73
+ data: {
74
+ savedToFile: true;
75
+ location: string;
76
+ summary: string;
77
+ };
78
+ fileOutput: FileOutputResult;
79
+ }>;
80
+ /**
81
+ * Cleans up old temp files (utility for manual cleanup)
82
+ */
83
+ export declare function cleanupTempFiles(olderThanDays?: number): Promise<{
84
+ deleted: number;
85
+ freedBytes: number;
86
+ }>;
87
+ export declare const fileOutput: {
88
+ init: typeof init;
89
+ getDataRoot: typeof getDataRoot;
90
+ shouldSaveToDisk: typeof shouldSaveToDisk;
91
+ getOutputDir: typeof getOutputDir;
92
+ saveFile: typeof saveFile;
93
+ saveMultipleFiles: typeof saveMultipleFiles;
94
+ handleLargeResponse: typeof handleLargeResponse;
95
+ cleanupTempFiles: typeof cleanupTempFiles;
96
+ TOKEN_THRESHOLD: number;
97
+ };
98
+ export default fileOutput;
99
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,215 @@
1
+ import { promises as fs } from 'fs';
2
+ import path from 'path';
3
+ // ============================================================================
4
+ // Configuration
5
+ // ============================================================================
6
+ // Default data root - can be overridden via environment variable or init()
7
+ // Uses environment variable, or falls back to a folder in user's home directory
8
+ const getDefaultDataRoot = () => {
9
+ const homeDir = process.env.HOME || process.env.USERPROFILE || '.';
10
+ return path.join(homeDir, '.router-mcp', 'data');
11
+ };
12
+ let DATA_ROOT = process.env.MCP_FILE_OUTPUT_DIR || process.env.ROUTER_MCP_DATA_DIR || getDefaultDataRoot();
13
+ const TOKEN_THRESHOLD = 20000; // Auto-save responses exceeding this estimated token count
14
+ const CHARS_PER_TOKEN = 4; // Rough estimate for token calculation
15
+ /**
16
+ * Initialize the file output utility with a custom data root
17
+ */
18
+ export function init(dataRoot) {
19
+ DATA_ROOT = dataRoot;
20
+ }
21
+ /**
22
+ * Get the current data root directory
23
+ */
24
+ export function getDataRoot() {
25
+ return DATA_ROOT;
26
+ }
27
+ // ============================================================================
28
+ // Utility Functions
29
+ // ============================================================================
30
+ function estimateTokens(data) {
31
+ const str = typeof data === 'string' ? data : JSON.stringify(data);
32
+ return Math.ceil(str.length / CHARS_PER_TOKEN);
33
+ }
34
+ function sanitizeFilename(name) {
35
+ return name
36
+ .replace(/[<>:"/\\|?*]/g, '-')
37
+ .replace(/\s+/g, '-')
38
+ .replace(/-+/g, '-')
39
+ .replace(/^-|-$/g, '')
40
+ .substring(0, 100);
41
+ }
42
+ function generateTimestamp() {
43
+ return new Date().toISOString().replace(/[:.]/g, '-').substring(0, 19);
44
+ }
45
+ async function ensureDir(dirPath) {
46
+ await fs.mkdir(dirPath, { recursive: true });
47
+ }
48
+ // ============================================================================
49
+ // Core Functions
50
+ // ============================================================================
51
+ /**
52
+ * Determines if a response should be saved to disk based on size
53
+ */
54
+ export function shouldSaveToDisk(data, forceFile) {
55
+ if (forceFile)
56
+ return true;
57
+ return estimateTokens(data) > TOKEN_THRESHOLD;
58
+ }
59
+ /**
60
+ * Gets the output directory path for a given configuration
61
+ */
62
+ export function getOutputDir(config) {
63
+ const { service, outputType = 'outputs', subdir } = config;
64
+ const parts = [DATA_ROOT, outputType, service];
65
+ if (subdir)
66
+ parts.push(subdir);
67
+ return path.join(...parts);
68
+ }
69
+ /**
70
+ * Saves a single file and returns the result
71
+ */
72
+ export async function saveFile(data, config) {
73
+ const dir = getOutputDir(config);
74
+ await ensureDir(dir);
75
+ const filename = config.filename || `${config.action}-${generateTimestamp()}`;
76
+ const ext = typeof data === 'string' ? '.json' : '';
77
+ const fullFilename = filename.includes('.') ? filename : `${filename}${ext}`;
78
+ const filePath = path.join(dir, fullFilename);
79
+ const content = typeof data === 'string' ? data : data;
80
+ await fs.writeFile(filePath, content, typeof data === 'string' ? 'utf-8' : undefined);
81
+ const stats = await fs.stat(filePath);
82
+ return {
83
+ saved: true,
84
+ path: filePath,
85
+ bytesSaved: stats.size,
86
+ };
87
+ }
88
+ /**
89
+ * Saves multiple files with a manifest - ideal for crawl results
90
+ */
91
+ export async function saveMultipleFiles(files, config, metadata) {
92
+ const timestamp = generateTimestamp();
93
+ const subdir = config.subdir || timestamp;
94
+ const dir = getOutputDir({ ...config, subdir });
95
+ await ensureDir(dir);
96
+ const manifestEntries = [];
97
+ let totalBytes = 0;
98
+ // Save each file
99
+ for (const file of files) {
100
+ const safeName = sanitizeFilename(file.filename);
101
+ const filePath = path.join(dir, safeName);
102
+ await fs.writeFile(filePath, file.content, 'utf-8');
103
+ const stats = await fs.stat(filePath);
104
+ totalBytes += stats.size;
105
+ manifestEntries.push({
106
+ filename: safeName,
107
+ url: file.url,
108
+ title: file.title,
109
+ timestamp: new Date().toISOString(),
110
+ bytes: stats.size,
111
+ });
112
+ }
113
+ // Create manifest
114
+ const manifest = {
115
+ service: config.service,
116
+ action: config.action,
117
+ created: new Date().toISOString(),
118
+ totalFiles: files.length,
119
+ totalBytes,
120
+ files: manifestEntries,
121
+ metadata,
122
+ };
123
+ const manifestPath = path.join(dir, 'manifest.json');
124
+ await fs.writeFile(manifestPath, JSON.stringify(manifest, null, 2), 'utf-8');
125
+ return {
126
+ saved: true,
127
+ dir,
128
+ files: manifestEntries.map(e => e.filename),
129
+ manifest: manifestPath,
130
+ bytesSaved: totalBytes,
131
+ };
132
+ }
133
+ /**
134
+ * Saves large response data automatically if it exceeds threshold
135
+ * Returns either the original data (if small) or a reference to saved file(s)
136
+ */
137
+ export async function handleLargeResponse(data, config, options) {
138
+ const shouldSave = shouldSaveToDisk(data, options?.forceFile);
139
+ if (!shouldSave) {
140
+ return { data };
141
+ }
142
+ const result = await saveFile(JSON.stringify(data, null, 2), config);
143
+ const summary = generateSummary(data);
144
+ return {
145
+ data: {
146
+ savedToFile: true,
147
+ location: result.path,
148
+ summary,
149
+ },
150
+ fileOutput: result,
151
+ };
152
+ }
153
+ /**
154
+ * Generates a brief summary of saved data for the response
155
+ */
156
+ function generateSummary(data) {
157
+ if (Array.isArray(data)) {
158
+ return `Array with ${data.length} items`;
159
+ }
160
+ if (typeof data === 'object' && data !== null) {
161
+ const keys = Object.keys(data);
162
+ return `Object with keys: ${keys.slice(0, 5).join(', ')}${keys.length > 5 ? '...' : ''}`;
163
+ }
164
+ return `${typeof data} data`;
165
+ }
166
+ /**
167
+ * Cleans up old temp files (utility for manual cleanup)
168
+ */
169
+ export async function cleanupTempFiles(olderThanDays) {
170
+ const tempDir = path.join(DATA_ROOT, 'temp');
171
+ let deleted = 0;
172
+ let freedBytes = 0;
173
+ try {
174
+ const services = await fs.readdir(tempDir);
175
+ for (const service of services) {
176
+ const serviceDir = path.join(tempDir, service);
177
+ const stats = await fs.stat(serviceDir);
178
+ if (stats.isDirectory()) {
179
+ const files = await fs.readdir(serviceDir);
180
+ for (const file of files) {
181
+ const filePath = path.join(serviceDir, file);
182
+ const fileStats = await fs.stat(filePath);
183
+ if (olderThanDays) {
184
+ const ageInDays = (Date.now() - fileStats.mtime.getTime()) / (1000 * 60 * 60 * 24);
185
+ if (ageInDays < olderThanDays)
186
+ continue;
187
+ }
188
+ freedBytes += fileStats.size;
189
+ await fs.rm(filePath, { recursive: true });
190
+ deleted++;
191
+ }
192
+ }
193
+ }
194
+ }
195
+ catch {
196
+ // Temp dir might not exist yet
197
+ }
198
+ return { deleted, freedBytes };
199
+ }
200
+ // ============================================================================
201
+ // Default Export
202
+ // ============================================================================
203
+ export const fileOutput = {
204
+ init,
205
+ getDataRoot,
206
+ shouldSaveToDisk,
207
+ getOutputDir,
208
+ saveFile,
209
+ saveMultipleFiles,
210
+ handleLargeResponse,
211
+ cleanupTempFiles,
212
+ TOKEN_THRESHOLD,
213
+ };
214
+ export default fileOutput;
215
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) Microsoft Corporation.
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE
@@ -0,0 +1,15 @@
1
+ # Installation
2
+ > `npm install --save @types/node`
3
+
4
+ # Summary
5
+ This package contains type definitions for node (https://nodejs.org/).
6
+
7
+ # Details
8
+ Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node/v20.
9
+
10
+ ### Additional Details
11
+ * Last updated: Sun, 14 Dec 2025 00:04:32 GMT
12
+ * Dependencies: [undici-types](https://npmjs.com/package/undici-types)
13
+
14
+ # Credits
15
+ These definitions were written by [Microsoft TypeScript](https://github.com/Microsoft), [Alberto Schiabel](https://github.com/jkomyno), [Andrew Makarov](https://github.com/r3nya), [Benjamin Toueg](https://github.com/btoueg), [David Junger](https://github.com/touffy), [Mohsen Azimi](https://github.com/mohsen1), [Nikita Galkin](https://github.com/galkin), [Sebastian Silbermann](https://github.com/eps1lon), [Wilco Bakker](https://github.com/WilcoBakker), [Marcin Kopacz](https://github.com/chyzwar), [Trivikram Kamat](https://github.com/trivikr), [Junxiao Shi](https://github.com/yoursunny), [Ilia Baryshnikov](https://github.com/qwelias), [ExE Boss](https://github.com/ExE-Boss), [Piotr Błażejewicz](https://github.com/peterblazejewicz), [Anna Henningsen](https://github.com/addaleax), [Victor Perin](https://github.com/victorperin), [NodeJS Contributors](https://github.com/NodeJS), [Linus Unnebäck](https://github.com/LinusU), [wafuwafu13](https://github.com/wafuwafu13), [Matteo Collina](https://github.com/mcollina), and [Dmitry Semigradsky](https://github.com/Semigradsky).
@@ -0,0 +1,8 @@
1
+ declare module "assert/strict" {
2
+ import { strict } from "node:assert";
3
+ export = strict;
4
+ }
5
+ declare module "node:assert/strict" {
6
+ import { strict } from "node:assert";
7
+ export = strict;
8
+ }