mcp4openapi 0.1.0 → 0.2.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 (151) hide show
  1. package/README.md +134 -95
  2. package/dist/scripts/validate-profile.js +3 -3
  3. package/dist/scripts/validate-profile.js.map +1 -1
  4. package/dist/src/composite-executor.d.ts +3 -1
  5. package/dist/src/composite-executor.d.ts.map +1 -1
  6. package/dist/src/composite-executor.js +16 -5
  7. package/dist/src/composite-executor.js.map +1 -1
  8. package/dist/src/constants.d.ts +49 -0
  9. package/dist/src/constants.d.ts.map +1 -1
  10. package/dist/src/constants.js +49 -0
  11. package/dist/src/constants.js.map +1 -1
  12. package/dist/src/errors.d.ts +6 -0
  13. package/dist/src/errors.d.ts.map +1 -1
  14. package/dist/src/errors.js +13 -0
  15. package/dist/src/errors.js.map +1 -1
  16. package/dist/src/generated-schemas.d.ts +832 -52
  17. package/dist/src/generated-schemas.d.ts.map +1 -1
  18. package/dist/src/generated-schemas.js +31 -8
  19. package/dist/src/generated-schemas.js.map +1 -1
  20. package/dist/src/http-client-factory.d.ts.map +1 -1
  21. package/dist/src/http-client-factory.js +14 -3
  22. package/dist/src/http-client-factory.js.map +1 -1
  23. package/dist/src/http-transport.d.ts +65 -0
  24. package/dist/src/http-transport.d.ts.map +1 -1
  25. package/dist/src/http-transport.js +921 -77
  26. package/dist/src/http-transport.js.map +1 -1
  27. package/dist/src/index.js +108 -8
  28. package/dist/src/index.js.map +1 -1
  29. package/dist/src/interceptors.d.ts +3 -0
  30. package/dist/src/interceptors.d.ts.map +1 -1
  31. package/dist/src/interceptors.js +50 -8
  32. package/dist/src/interceptors.js.map +1 -1
  33. package/dist/src/logger.d.ts +1 -1
  34. package/dist/src/logger.js +3 -3
  35. package/dist/src/logger.js.map +1 -1
  36. package/dist/src/mcp-server.d.ts +33 -0
  37. package/dist/src/mcp-server.d.ts.map +1 -1
  38. package/dist/src/mcp-server.js +263 -54
  39. package/dist/src/mcp-server.js.map +1 -1
  40. package/dist/src/oauth-provider.d.ts +92 -0
  41. package/dist/src/oauth-provider.d.ts.map +1 -0
  42. package/dist/src/oauth-provider.js +588 -0
  43. package/dist/src/oauth-provider.js.map +1 -0
  44. package/dist/src/openapi-parser.d.ts +16 -0
  45. package/dist/src/openapi-parser.d.ts.map +1 -1
  46. package/dist/src/openapi-parser.js +141 -6
  47. package/dist/src/openapi-parser.js.map +1 -1
  48. package/dist/src/profile-loader.d.ts +2 -2
  49. package/dist/src/profile-loader.d.ts.map +1 -1
  50. package/dist/src/profile-loader.js +45 -24
  51. package/dist/src/profile-loader.js.map +1 -1
  52. package/dist/src/testing/fixtures.d.ts +32 -0
  53. package/dist/src/testing/fixtures.d.ts.map +1 -1
  54. package/dist/src/testing/fixtures.js +26 -0
  55. package/dist/src/testing/fixtures.js.map +1 -1
  56. package/dist/src/testing/mock-gitlab-server.d.ts.map +1 -1
  57. package/dist/src/testing/mock-gitlab-server.js +131 -1
  58. package/dist/src/testing/mock-gitlab-server.js.map +1 -1
  59. package/dist/src/types/http-transport.d.ts +16 -0
  60. package/dist/src/types/http-transport.d.ts.map +1 -1
  61. package/dist/src/types/openapi.d.ts +5 -0
  62. package/dist/src/types/openapi.d.ts.map +1 -1
  63. package/dist/src/types/profile.d.ts +112 -3
  64. package/dist/src/types/profile.d.ts.map +1 -1
  65. package/dist/src/validation-utils.d.ts +12 -0
  66. package/dist/src/validation-utils.d.ts.map +1 -1
  67. package/dist/src/validation-utils.js +17 -0
  68. package/dist/src/validation-utils.js.map +1 -1
  69. package/package.json +7 -3
  70. package/profile-schema.json +169 -7
  71. package/dist/composite-executor.d.ts +0 -65
  72. package/dist/composite-executor.d.ts.map +0 -1
  73. package/dist/composite-executor.js +0 -147
  74. package/dist/composite-executor.js.map +0 -1
  75. package/dist/constants.d.ts +0 -36
  76. package/dist/constants.d.ts.map +0 -1
  77. package/dist/constants.js +0 -36
  78. package/dist/constants.js.map +0 -1
  79. package/dist/http-transport.d.ts +0 -195
  80. package/dist/http-transport.d.ts.map +0 -1
  81. package/dist/http-transport.js +0 -760
  82. package/dist/http-transport.js.map +0 -1
  83. package/dist/interceptors.d.ts +0 -74
  84. package/dist/interceptors.d.ts.map +0 -1
  85. package/dist/interceptors.js +0 -220
  86. package/dist/interceptors.js.map +0 -1
  87. package/dist/logger.d.ts +0 -81
  88. package/dist/logger.d.ts.map +0 -1
  89. package/dist/logger.js +0 -264
  90. package/dist/logger.js.map +0 -1
  91. package/dist/mcp-server.d.ts +0 -110
  92. package/dist/mcp-server.d.ts.map +0 -1
  93. package/dist/mcp-server.js +0 -568
  94. package/dist/mcp-server.js.map +0 -1
  95. package/dist/metrics.d.ts +0 -86
  96. package/dist/metrics.d.ts.map +0 -1
  97. package/dist/metrics.js +0 -229
  98. package/dist/metrics.js.map +0 -1
  99. package/dist/openapi-parser.d.ts +0 -35
  100. package/dist/openapi-parser.d.ts.map +0 -1
  101. package/dist/openapi-parser.js +0 -160
  102. package/dist/openapi-parser.js.map +0 -1
  103. package/dist/profile-loader.d.ts +0 -25
  104. package/dist/profile-loader.d.ts.map +0 -1
  105. package/dist/profile-loader.js +0 -134
  106. package/dist/profile-loader.js.map +0 -1
  107. package/dist/schema-validator.d.ts +0 -32
  108. package/dist/schema-validator.d.ts.map +0 -1
  109. package/dist/schema-validator.js +0 -126
  110. package/dist/schema-validator.js.map +0 -1
  111. package/dist/testing/fixtures.d.ts +0 -186
  112. package/dist/testing/fixtures.d.ts.map +0 -1
  113. package/dist/testing/fixtures.js +0 -135
  114. package/dist/testing/fixtures.js.map +0 -1
  115. package/dist/testing/http-integration.test.d.ts +0 -7
  116. package/dist/testing/http-integration.test.d.ts.map +0 -1
  117. package/dist/testing/http-integration.test.js +0 -383
  118. package/dist/testing/http-integration.test.js.map +0 -1
  119. package/dist/testing/http-multiuser.test.d.ts +0 -10
  120. package/dist/testing/http-multiuser.test.d.ts.map +0 -1
  121. package/dist/testing/http-multiuser.test.js +0 -255
  122. package/dist/testing/http-multiuser.test.js.map +0 -1
  123. package/dist/testing/integration.test.d.ts +0 -8
  124. package/dist/testing/integration.test.d.ts.map +0 -1
  125. package/dist/testing/integration.test.js +0 -247
  126. package/dist/testing/integration.test.js.map +0 -1
  127. package/dist/testing/mock-gitlab-server.d.ts +0 -34
  128. package/dist/testing/mock-gitlab-server.d.ts.map +0 -1
  129. package/dist/testing/mock-gitlab-server.js +0 -224
  130. package/dist/testing/mock-gitlab-server.js.map +0 -1
  131. package/dist/testing/test-types.d.ts +0 -59
  132. package/dist/testing/test-types.d.ts.map +0 -1
  133. package/dist/testing/test-types.js +0 -7
  134. package/dist/testing/test-types.js.map +0 -1
  135. package/dist/tool-generator.d.ts +0 -43
  136. package/dist/tool-generator.d.ts.map +0 -1
  137. package/dist/tool-generator.js +0 -123
  138. package/dist/tool-generator.js.map +0 -1
  139. package/dist/tsconfig.tsbuildinfo +0 -1
  140. package/dist/types/http-transport.d.ts +0 -39
  141. package/dist/types/http-transport.d.ts.map +0 -1
  142. package/dist/types/http-transport.js +0 -8
  143. package/dist/types/http-transport.js.map +0 -1
  144. package/dist/types/openapi.d.ts +0 -50
  145. package/dist/types/openapi.d.ts.map +0 -1
  146. package/dist/types/openapi.js +0 -9
  147. package/dist/types/openapi.js.map +0 -1
  148. package/dist/types/profile.d.ts +0 -76
  149. package/dist/types/profile.d.ts.map +0 -1
  150. package/dist/types/profile.js +0 -9
  151. package/dist/types/profile.js.map +0 -1
@@ -1,195 +0,0 @@
1
- /**
2
- * HTTP Streamable Transport for MCP
3
- *
4
- * Implements MCP Specification 2025-03-26
5
- * https://modelcontextprotocol.io/specification/2025-03-26/basic/transports
6
- *
7
- * Why: Enables remote MCP server access with SSE streaming, session management,
8
- * and resumability for reliable communication over HTTP.
9
- */
10
- import type { Logger } from './logger.js';
11
- import type { HttpTransportConfig } from './types/http-transport.js';
12
- export declare class HttpTransport {
13
- private app;
14
- private server;
15
- private sessions;
16
- private config;
17
- private logger;
18
- private metrics;
19
- private cleanupInterval;
20
- private messageHandler;
21
- constructor(config: HttpTransportConfig, logger: Logger);
22
- /**
23
- * Setup Express middleware
24
- *
25
- * Why: Security (Origin validation), JSON parsing, session extraction, metrics
26
- */
27
- private setupMiddleware;
28
- private hasWarnedAboutBinding;
29
- /**
30
- * Check if origin is allowed
31
- *
32
- * Why: Prevent DNS rebinding attacks
33
- *
34
- * Supports:
35
- * - Exact hostname: 'example.com', 'api.example.com'
36
- * - Wildcard subdomain: '*.example.com'
37
- * - IPv4 CIDR: '192.168.1.0/24', '10.0.0.0/8'
38
- * - IPv4 exact: '192.168.1.100'
39
- */
40
- private isAllowedOrigin;
41
- /**
42
- * Match hostname against allowed origin pattern
43
- *
44
- * Supports:
45
- * - Exact match: 'example.com' === 'example.com'
46
- * - Wildcard: '*.example.com' matches 'api.example.com', 'web.example.com'
47
- * - CIDR: '192.168.1.0/24' matches '192.168.1.1' through '192.168.1.254'
48
- */
49
- private matchOrigin;
50
- /**
51
- * Check if IP address is within CIDR range
52
- *
53
- * Example: '192.168.1.50' matches '192.168.1.0/24'
54
- */
55
- private matchCIDR;
56
- /**
57
- * Convert IPv4 address to 32-bit integer
58
- *
59
- * Example: '192.168.1.1' -> 3232235777
60
- */
61
- private ipToInt;
62
- /**
63
- * Setup MCP endpoint routes
64
- *
65
- * Why: Single endpoint for POST (client→server) and GET (SSE stream)
66
- */
67
- private setupRoutes;
68
- /**
69
- * Handle metrics endpoint
70
- *
71
- * Why: Prometheus scraping endpoint
72
- */
73
- private handleMetrics;
74
- /**
75
- * Validate token format and length
76
- *
77
- * Why centralized: Single source of truth for token validation rules
78
- */
79
- private validateToken;
80
- /**
81
- * Extract and validate auth token from request headers
82
- *
83
- * Supports:
84
- * - Authorization: Bearer <token>
85
- * - X-API-Token: <token>
86
- *
87
- * Why strict validation: Prevents header injection attacks
88
- */
89
- private extractAuthToken;
90
- /**
91
- * Handle POST requests - Client sending messages to server
92
- *
93
- * MCP Spec: POST can contain requests, notifications, or responses
94
- */
95
- private handlePost;
96
- /**
97
- * Handle GET requests - Client opening SSE stream for server messages
98
- *
99
- * MCP Spec: GET opens SSE stream for server-initiated requests/notifications
100
- */
101
- private handleGet;
102
- /**
103
- * Handle DELETE requests - Client terminating session
104
- *
105
- * MCP Spec: DELETE explicitly terminates session
106
- */
107
- private handleDelete;
108
- /**
109
- * Start SSE response for a POST request
110
- *
111
- * Why: Returns response via SSE stream, allows server-initiated messages
112
- */
113
- private startSSEResponse;
114
- /**
115
- * Start SSE stream for GET request
116
- *
117
- * Why: Allows server to send requests/notifications to client
118
- */
119
- private startSSEStream;
120
- /**
121
- * Replay messages after Last-Event-ID
122
- *
123
- * Why: Resumability - client can reconnect and receive missed messages
124
- */
125
- private replayMessages;
126
- /**
127
- * Send message to client via SSE
128
- *
129
- * Why: Server-initiated requests/notifications
130
- */
131
- sendToClient(sessionId: string, message: unknown): void;
132
- /**
133
- * Check if request is initialization
134
- */
135
- private isInitializeRequest;
136
- /**
137
- * Determine message type (request, notification, response)
138
- */
139
- private getMessageType;
140
- /**
141
- * Create new session
142
- *
143
- * Why: Stateful sessions for MCP protocol
144
- */
145
- private createSession;
146
- /**
147
- * Update session activity timestamp
148
- */
149
- private updateSessionActivity;
150
- /**
151
- * Destroy session and cleanup resources
152
- *
153
- * Why: Free memory, close streams
154
- */
155
- private destroySession;
156
- /**
157
- * Session destruction listeners for cleanup in other components
158
- */
159
- private sessionDestroyedListeners;
160
- /**
161
- * Register listener for session destruction events
162
- *
163
- * Why: Allows MCPServer to cleanup per-session HTTP clients
164
- */
165
- onSessionDestroyed(listener: (sessionId: string) => void): void;
166
- /**
167
- * Notify all listeners about session destruction
168
- */
169
- private notifySessionDestroyed;
170
- /**
171
- * Cleanup expired sessions
172
- *
173
- * Why: Prevent memory leaks, enforce session timeout
174
- */
175
- private cleanupExpiredSessions;
176
- /**
177
- * Get auth token from session
178
- *
179
- * Why public: Allows MCPServer to securely access session tokens without breaking encapsulation
180
- */
181
- getSessionToken(sessionId: string): string | undefined;
182
- /**
183
- * Set message handler for processing incoming JSON-RPC messages
184
- */
185
- setMessageHandler(handler: (message: unknown, sessionId?: string) => Promise<unknown>): void;
186
- /**
187
- * Start HTTP server
188
- */
189
- start(): Promise<void>;
190
- /**
191
- * Stop HTTP server
192
- */
193
- stop(): Promise<void>;
194
- }
195
- //# sourceMappingURL=http-transport.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"http-transport.d.ts","sourceRoot":"","sources":["../src/http-transport.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAKH,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAC1C,OAAO,KAAK,EAIV,mBAAmB,EAEpB,MAAM,2BAA2B,CAAC;AAGnC,qBAAa,aAAa;IACxB,OAAO,CAAC,GAAG,CAAsB;IACjC,OAAO,CAAC,MAAM,CAAuB;IACrC,OAAO,CAAC,QAAQ,CAAuC;IACvD,OAAO,CAAC,MAAM,CAAsB;IACpC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,OAAO,CAAiC;IAChD,OAAO,CAAC,eAAe,CAA+B;IACtD,OAAO,CAAC,cAAc,CAA6E;gBAEvF,MAAM,EAAE,mBAAmB,EAAE,MAAM,EAAE,MAAM;IAiBvD;;;;OAIG;IACH,OAAO,CAAC,eAAe;IA+CvB,OAAO,CAAC,qBAAqB,CAAS;IAEtC;;;;;;;;;;OAUG;IACH,OAAO,CAAC,eAAe;IA8BvB;;;;;;;OAOG;IACH,OAAO,CAAC,WAAW;IAoBnB;;;;OAIG;IACH,OAAO,CAAC,SAAS;IAyBjB;;;;OAIG;IACH,OAAO,CAAC,OAAO;IAmBf;;;;OAIG;IACH,OAAO,CAAC,WAAW;IA2BnB;;;;OAIG;YACW,aAAa;IAoB3B;;;;OAIG;IACH,OAAO,CAAC,aAAa;IAUrB;;;;;;;;OAQG;IACH,OAAO,CAAC,gBAAgB;IAyBxB;;;;OAIG;YACW,UAAU;IA4FxB;;;;OAIG;YACW,SAAS;IAkDvB;;;;OAIG;IACH,OAAO,CAAC,YAAY;IAmCpB;;;;OAIG;IACH,OAAO,CAAC,gBAAgB;IAuBxB;;;;OAIG;IACH,OAAO,CAAC,cAAc;IA4CtB;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAatB;;;;OAIG;IACI,YAAY,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,OAAO,GAAG,IAAI;IA4B9D;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAM3B;;OAEG;IACH,OAAO,CAAC,cAAc;IAuBtB;;;;OAIG;IACH,OAAO,CAAC,aAAa;IAyBrB;;OAEG;IACH,OAAO,CAAC,qBAAqB;IAO7B;;;;OAIG;IACH,OAAO,CAAC,cAAc;IAsBtB;;OAEG;IACH,OAAO,CAAC,yBAAyB,CAA0C;IAE3E;;;;OAIG;IACI,kBAAkB,CAAC,QAAQ,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,GAAG,IAAI;IAItE;;OAEG;IACH,OAAO,CAAC,sBAAsB;IAU9B;;;;OAIG;IACH,OAAO,CAAC,sBAAsB;IAqB9B;;;;OAIG;IACI,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAK7D;;OAEG;IACI,iBAAiB,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,CAAC,EAAE,MAAM,KAAK,OAAO,CAAC,OAAO,CAAC,GAAG,IAAI;IAInG;;OAEG;IACU,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA2BnC;;OAEG;IACU,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAuBnC"}