@apitap/core 1.5.3 → 1.6.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 (60) hide show
  1. package/README.md +28 -8
  2. package/dist/auth/handoff.js +1 -1
  3. package/dist/auth/handoff.js.map +1 -1
  4. package/dist/capture/cdp-attach.d.ts +60 -0
  5. package/dist/capture/cdp-attach.js +422 -0
  6. package/dist/capture/cdp-attach.js.map +1 -0
  7. package/dist/capture/filter.js +6 -0
  8. package/dist/capture/filter.js.map +1 -1
  9. package/dist/capture/parameterize.d.ts +7 -6
  10. package/dist/capture/parameterize.js +204 -12
  11. package/dist/capture/parameterize.js.map +1 -1
  12. package/dist/capture/session.js +20 -10
  13. package/dist/capture/session.js.map +1 -1
  14. package/dist/cli.js +387 -20
  15. package/dist/cli.js.map +1 -1
  16. package/dist/discovery/openapi.js +23 -50
  17. package/dist/discovery/openapi.js.map +1 -1
  18. package/dist/index.d.ts +1 -0
  19. package/dist/index.js +1 -0
  20. package/dist/index.js.map +1 -1
  21. package/dist/mcp.js +12 -0
  22. package/dist/mcp.js.map +1 -1
  23. package/dist/native-host.js +5 -0
  24. package/dist/native-host.js.map +1 -1
  25. package/dist/plugin.js +10 -3
  26. package/dist/plugin.js.map +1 -1
  27. package/dist/replay/engine.d.ts +13 -0
  28. package/dist/replay/engine.js +20 -0
  29. package/dist/replay/engine.js.map +1 -1
  30. package/dist/skill/apis-guru.d.ts +35 -0
  31. package/dist/skill/apis-guru.js +128 -0
  32. package/dist/skill/apis-guru.js.map +1 -0
  33. package/dist/skill/generator.d.ts +7 -1
  34. package/dist/skill/generator.js +35 -3
  35. package/dist/skill/generator.js.map +1 -1
  36. package/dist/skill/merge.d.ts +29 -0
  37. package/dist/skill/merge.js +252 -0
  38. package/dist/skill/merge.js.map +1 -0
  39. package/dist/skill/openapi-converter.d.ts +31 -0
  40. package/dist/skill/openapi-converter.js +383 -0
  41. package/dist/skill/openapi-converter.js.map +1 -0
  42. package/dist/types.d.ts +41 -0
  43. package/package.json +1 -1
  44. package/src/auth/handoff.ts +1 -1
  45. package/src/capture/cdp-attach.ts +501 -0
  46. package/src/capture/filter.ts +5 -0
  47. package/src/capture/parameterize.ts +207 -11
  48. package/src/capture/session.ts +20 -10
  49. package/src/cli.ts +420 -18
  50. package/src/discovery/openapi.ts +25 -56
  51. package/src/index.ts +1 -0
  52. package/src/mcp.ts +12 -0
  53. package/src/native-host.ts +7 -0
  54. package/src/plugin.ts +10 -3
  55. package/src/replay/engine.ts +19 -0
  56. package/src/skill/apis-guru.ts +163 -0
  57. package/src/skill/generator.ts +38 -3
  58. package/src/skill/merge.ts +281 -0
  59. package/src/skill/openapi-converter.ts +426 -0
  60. package/src/types.ts +42 -1
@@ -0,0 +1,383 @@
1
+ /**
2
+ * Resolve a JSON $ref pointer in an OpenAPI spec.
3
+ * Uses a visited set to detect cycles and a depth limit as safety net.
4
+ */
5
+ export function resolveRef(obj, spec, visited = new Set(), depth = 0) {
6
+ if (!obj || typeof obj !== 'object')
7
+ return obj;
8
+ // Handle allOf composition: merge properties from all entries
9
+ if (obj.allOf && Array.isArray(obj.allOf)) {
10
+ const merged = { type: 'object', properties: {} };
11
+ for (const entry of obj.allOf) {
12
+ const resolved = resolveRef(entry, spec, new Set(visited), depth + 1);
13
+ if (resolved?.properties) {
14
+ Object.assign(merged.properties, resolved.properties);
15
+ }
16
+ if (resolved?.required) {
17
+ merged.required = [...(merged.required || []), ...resolved.required];
18
+ }
19
+ if (resolved?.description && !merged.description) {
20
+ merged.description = resolved.description;
21
+ }
22
+ }
23
+ return merged;
24
+ }
25
+ if (!obj.$ref)
26
+ return obj;
27
+ const ref = obj.$ref;
28
+ if (!ref.startsWith('#/'))
29
+ return null; // Only local document refs supported
30
+ if (visited.has(ref))
31
+ return null; // cycle detected
32
+ if (depth > 10)
33
+ return null; // depth safety net
34
+ visited.add(ref);
35
+ const refPath = ref.replace('#/', '').split('/');
36
+ let resolved = spec;
37
+ for (const segment of refPath) {
38
+ resolved = resolved?.[segment];
39
+ if (resolved === undefined)
40
+ return null;
41
+ }
42
+ // Recursively resolve if the resolved object also has $ref or allOf
43
+ return resolveRef(resolved, spec, visited, depth + 1);
44
+ }
45
+ export function extractDomainAndBasePath(spec, specUrl) {
46
+ const serverUrl = spec.servers?.[0]?.url;
47
+ if (serverUrl) {
48
+ try {
49
+ const parsed = new URL(serverUrl);
50
+ return { domain: parsed.hostname, basePath: parsed.pathname.replace(/\/$/, '') };
51
+ }
52
+ catch {
53
+ if (serverUrl.startsWith('/')) {
54
+ const providerName = spec.info?.['x-providerName'];
55
+ const domain = (providerName && /^[a-zA-Z0-9][a-zA-Z0-9._-]+$/.test(providerName))
56
+ ? providerName
57
+ : new URL(specUrl).hostname;
58
+ return { domain, basePath: serverUrl.replace(/\/$/, '') };
59
+ }
60
+ }
61
+ }
62
+ if (spec.host) {
63
+ try {
64
+ const parsed = new URL(`https://${spec.host}`);
65
+ return { domain: parsed.hostname, basePath: (spec.basePath || '').replace(/\/$/, '') };
66
+ }
67
+ catch {
68
+ return { domain: spec.host.split(':')[0], basePath: (spec.basePath || '').replace(/\/$/, '') };
69
+ }
70
+ }
71
+ try {
72
+ return { domain: new URL(specUrl).hostname, basePath: '' };
73
+ }
74
+ catch {
75
+ throw new Error(`Cannot determine API domain from spec (no servers, host, or valid specUrl)`);
76
+ }
77
+ }
78
+ export function computeConfidence(input) {
79
+ let score = 0.6;
80
+ if (input.hasExamples)
81
+ score += 0.1;
82
+ if (!input.requiresAuth)
83
+ score += 0.1;
84
+ if (input.method === 'GET')
85
+ score += 0.05;
86
+ return Math.min(score, 0.85);
87
+ }
88
+ export function detectAuth(spec) {
89
+ const schemes = spec.components?.securitySchemes || {};
90
+ const defs = spec.securityDefinitions || {};
91
+ const allSchemes = { ...schemes, ...defs };
92
+ const security = spec.security || [];
93
+ if (Object.keys(allSchemes).length === 0 && security.length === 0) {
94
+ return { requiresAuth: false };
95
+ }
96
+ let authType;
97
+ for (const scheme of Object.values(allSchemes)) {
98
+ if (scheme.type === 'http' && scheme.scheme === 'bearer') {
99
+ authType = 'bearer';
100
+ break;
101
+ }
102
+ if (scheme.type === 'http' && scheme.scheme === 'basic') {
103
+ authType = 'basic';
104
+ break;
105
+ }
106
+ if (scheme.type === 'apiKey') {
107
+ authType = 'apiKey';
108
+ break;
109
+ }
110
+ if (scheme.type === 'oauth2') {
111
+ authType = 'oauth2';
112
+ break;
113
+ }
114
+ if (scheme.type === 'openIdConnect') {
115
+ authType = 'openIdConnect';
116
+ break;
117
+ }
118
+ }
119
+ return { requiresAuth: true, authType };
120
+ }
121
+ export function generateEndpointId(method, path, operationId, seen) {
122
+ let base;
123
+ if (operationId) {
124
+ base = `${method.toLowerCase()}-${operationId.replace(/[^a-z0-9]/gi, '-').toLowerCase()}`;
125
+ }
126
+ else {
127
+ const segments = path.split('/').filter(s => s !== '' && !s.startsWith(':')).join('-').replace(/[^a-z0-9-]/gi, '').toLowerCase() || 'root';
128
+ base = `${method.toLowerCase()}-${segments}`;
129
+ }
130
+ base = base.replace(/-+/g, '-').replace(/^-|-$/g, '').slice(0, 80);
131
+ let id = base;
132
+ let counter = 2;
133
+ while (seen.has(id)) {
134
+ id = `${base}-${counter}`.slice(0, 80);
135
+ counter++;
136
+ }
137
+ seen.add(id);
138
+ return id;
139
+ }
140
+ const HTTP_METHODS = ['get', 'post', 'put', 'patch', 'delete', 'head', 'options', 'trace'];
141
+ const MAX_ENDPOINTS = 500;
142
+ /**
143
+ * Detect whether a parsed JSON object is an OpenAPI/Swagger spec.
144
+ * Returns false for SkillFile objects (which have version+domain+baseUrl+endpoints).
145
+ */
146
+ export function isOpenAPISpec(obj) {
147
+ if (!obj || typeof obj !== 'object')
148
+ return false;
149
+ const o = obj;
150
+ // SkillFile check: if it looks like a SkillFile, it's not an OpenAPI spec
151
+ if (o.version && o.domain && o.baseUrl && Array.isArray(o.endpoints)) {
152
+ return false;
153
+ }
154
+ // OpenAPI 3.x or Swagger 2.0
155
+ if (typeof o.openapi === 'string' || typeof o.swagger === 'string') {
156
+ return true;
157
+ }
158
+ return false;
159
+ }
160
+ /**
161
+ * Extract response shape (type + top-level field names) from an OpenAPI response schema.
162
+ */
163
+ function extractResponseShape(responses, spec) {
164
+ if (!responses)
165
+ return { type: 'unknown' };
166
+ // Try 200, then 201, then first 2xx
167
+ const responseObj = responses['200'] || responses['201'] ||
168
+ Object.entries(responses).find(([k]) => k.startsWith('2'))?.[1];
169
+ if (!responseObj)
170
+ return { type: 'unknown' };
171
+ const resolved = resolveRef(responseObj, spec);
172
+ if (!resolved)
173
+ return { type: 'unknown' };
174
+ // OpenAPI 3.x: content -> application/json -> schema
175
+ let schema = resolved.content?.['application/json']?.schema;
176
+ // Swagger 2.0: schema directly on response
177
+ if (!schema && resolved.schema)
178
+ schema = resolved.schema;
179
+ if (!schema)
180
+ return { type: 'unknown' };
181
+ schema = resolveRef(schema, spec);
182
+ if (!schema)
183
+ return { type: 'unknown' };
184
+ const type = schema.type === 'array' ? 'array' : schema.type === 'object' ? 'object' : (schema.type || 'unknown');
185
+ const fields = [];
186
+ if (schema.properties) {
187
+ fields.push(...Object.keys(schema.properties));
188
+ }
189
+ else if (schema.type === 'array' && schema.items) {
190
+ const items = resolveRef(schema.items, spec);
191
+ if (items?.properties) {
192
+ fields.push(...Object.keys(items.properties));
193
+ }
194
+ }
195
+ return fields.length > 0 ? { type, fields } : { type };
196
+ }
197
+ /**
198
+ * Extract request body template for POST/PUT/PATCH from an OpenAPI operation.
199
+ */
200
+ function extractRequestBody(operation, spec) {
201
+ // OpenAPI 3.x: requestBody -> content -> application/json -> schema
202
+ let schema;
203
+ let contentType = 'application/json';
204
+ if (operation.requestBody) {
205
+ const body = resolveRef(operation.requestBody, spec);
206
+ if (!body)
207
+ return undefined;
208
+ const jsonContent = body.content?.['application/json'];
209
+ if (jsonContent?.schema) {
210
+ schema = resolveRef(jsonContent.schema, spec);
211
+ }
212
+ else {
213
+ // Try first content type
214
+ const firstKey = body.content ? Object.keys(body.content)[0] : undefined;
215
+ if (firstKey && body.content[firstKey]?.schema) {
216
+ contentType = firstKey;
217
+ schema = resolveRef(body.content[firstKey].schema, spec);
218
+ }
219
+ }
220
+ }
221
+ // Swagger 2.0: parameters with in=body
222
+ if (!schema && operation.parameters) {
223
+ const bodyParam = operation.parameters.find((p) => p.in === 'body');
224
+ if (bodyParam?.schema) {
225
+ schema = resolveRef(bodyParam.schema, spec);
226
+ }
227
+ }
228
+ if (!schema)
229
+ return undefined;
230
+ const template = {};
231
+ const variables = [];
232
+ if (schema.properties) {
233
+ for (const [key, prop] of Object.entries(schema.properties)) {
234
+ const resolvedProp = resolveRef(prop, spec) || prop;
235
+ if (resolvedProp.example !== undefined) {
236
+ template[key] = resolvedProp.example;
237
+ }
238
+ else if (resolvedProp.default !== undefined) {
239
+ template[key] = resolvedProp.default;
240
+ }
241
+ else {
242
+ template[key] = `{{${key}}}`;
243
+ variables.push(key);
244
+ }
245
+ }
246
+ }
247
+ return {
248
+ contentType,
249
+ template: Object.keys(template).length > 0 ? template : '{{body}}',
250
+ ...(variables.length > 0 ? { variables } : {}),
251
+ };
252
+ }
253
+ /**
254
+ * Convert an OpenAPI 3.x or Swagger 2.0 spec into an ImportResult.
255
+ */
256
+ export function convertOpenAPISpec(spec, specUrl) {
257
+ const { domain, basePath } = extractDomainAndBasePath(spec, specUrl);
258
+ const { requiresAuth, authType } = detectAuth(spec);
259
+ const specVersion = spec.swagger ? 'swagger2' : 'openapi3';
260
+ const endpoints = [];
261
+ const seenIds = new Set();
262
+ const paths = spec.paths || {};
263
+ for (const [pathKey, pathItem] of Object.entries(paths)) {
264
+ if (!pathItem || typeof pathItem !== 'object')
265
+ continue;
266
+ for (const method of HTTP_METHODS) {
267
+ const operation = pathItem[method];
268
+ if (!operation || typeof operation !== 'object')
269
+ continue;
270
+ // Collect all parameters (path-level + operation-level)
271
+ const allParams = [
272
+ ...(pathItem.parameters || []),
273
+ ...(operation.parameters || []),
274
+ ];
275
+ // Convert path: {param} -> :param, prepend basePath
276
+ const convertedPath = basePath + pathKey.replace(/\{([^}]+)\}/g, ':$1');
277
+ // Extract query params
278
+ const queryParams = {};
279
+ for (const param of allParams) {
280
+ const resolved = resolveRef(param, spec) || param;
281
+ if (resolved.in === 'query') {
282
+ const paramSchema = resolved.schema ? (resolveRef(resolved.schema, spec) || resolved.schema) : resolved;
283
+ const example = resolved.example ?? paramSchema?.example ?? paramSchema?.default ?? '';
284
+ queryParams[resolved.name] = {
285
+ type: paramSchema?.type || 'string',
286
+ example: example !== '' ? String(example) : '',
287
+ fromSpec: true,
288
+ ...(resolved.required ? { required: true } : {}),
289
+ ...(paramSchema?.enum ? { enum: paramSchema.enum } : {}),
290
+ };
291
+ }
292
+ }
293
+ // Extract path param examples for the example URL
294
+ const pathParamExamples = {};
295
+ let hasExamples = false;
296
+ for (const param of allParams) {
297
+ const resolved = resolveRef(param, spec) || param;
298
+ if (resolved.in === 'path') {
299
+ const paramSchema = resolved.schema ? (resolveRef(resolved.schema, spec) || resolved.schema) : resolved;
300
+ const example = resolved.example ?? paramSchema?.example ?? paramSchema?.default;
301
+ if (example !== undefined) {
302
+ pathParamExamples[resolved.name] = String(example);
303
+ hasExamples = true;
304
+ }
305
+ }
306
+ }
307
+ // Check if query params have examples too
308
+ if (!hasExamples) {
309
+ for (const qp of Object.values(queryParams)) {
310
+ if (qp.example !== '') {
311
+ hasExamples = true;
312
+ break;
313
+ }
314
+ }
315
+ }
316
+ // Build example URL
317
+ let examplePath = basePath + pathKey;
318
+ // Substitute path params with examples
319
+ for (const [name, value] of Object.entries(pathParamExamples)) {
320
+ examplePath = examplePath.replace(`{${name}}`, value);
321
+ }
322
+ // Replace remaining unsubstituted path params with placeholder
323
+ examplePath = examplePath.replace(/\{([^}]+)\}/g, ':$1');
324
+ // Add non-empty query params to URL
325
+ const queryEntries = Object.entries(queryParams).filter(([, v]) => v.example !== '');
326
+ const queryString = queryEntries.map(([k, v]) => `${encodeURIComponent(k)}=${encodeURIComponent(v.example)}`).join('&');
327
+ const exampleUrl = `https://${domain}${examplePath}${queryString ? '?' + queryString : ''}`;
328
+ // Extract response shape
329
+ const responseShape = extractResponseShape(operation.responses, spec);
330
+ // Extract request body for write methods
331
+ const methodUpper = method.toUpperCase();
332
+ let requestBody;
333
+ if (['POST', 'PUT', 'PATCH'].includes(methodUpper)) {
334
+ requestBody = extractRequestBody(operation, spec);
335
+ }
336
+ // Description
337
+ const description = operation.summary || operation.description || undefined;
338
+ // Generate endpoint ID
339
+ const id = generateEndpointId(method, convertedPath, operation.operationId, seenIds);
340
+ // Compute confidence
341
+ const confidence = computeConfidence({
342
+ method: methodUpper,
343
+ hasExamples,
344
+ requiresAuth,
345
+ });
346
+ const endpoint = {
347
+ id,
348
+ method: methodUpper,
349
+ path: convertedPath,
350
+ queryParams,
351
+ headers: {},
352
+ responseShape,
353
+ examples: {
354
+ request: { url: exampleUrl, headers: {} },
355
+ responsePreview: null,
356
+ },
357
+ confidence,
358
+ endpointProvenance: 'openapi-import',
359
+ specSource: specUrl,
360
+ ...(description ? { description } : {}),
361
+ ...(requestBody ? { requestBody } : {}),
362
+ };
363
+ endpoints.push(endpoint);
364
+ }
365
+ }
366
+ // Sort by confidence descending, then truncate
367
+ endpoints.sort((a, b) => (b.confidence ?? 0) - (a.confidence ?? 0));
368
+ if (endpoints.length > MAX_ENDPOINTS) {
369
+ process.stderr.write(`[openapi-import] Warning: spec has ${endpoints.length} endpoints, truncating to ${MAX_ENDPOINTS}\n`);
370
+ endpoints.length = MAX_ENDPOINTS;
371
+ }
372
+ const meta = {
373
+ specUrl,
374
+ specVersion,
375
+ title: spec.info?.title || '',
376
+ description: spec.info?.description || '',
377
+ requiresAuth,
378
+ ...(authType ? { authType } : {}),
379
+ endpointCount: endpoints.length,
380
+ };
381
+ return { domain, endpoints, meta };
382
+ }
383
+ //# sourceMappingURL=openapi-converter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openapi-converter.js","sourceRoot":"","sources":["../../src/skill/openapi-converter.ts"],"names":[],"mappings":"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"}
package/dist/types.d.ts CHANGED
@@ -105,6 +105,9 @@ export interface SkillEndpoint {
105
105
  queryParams: Record<string, {
106
106
  type: string;
107
107
  example: string;
108
+ required?: boolean;
109
+ enum?: string[];
110
+ fromSpec?: boolean;
108
111
  }>;
109
112
  headers: Record<string, string>;
110
113
  responseShape: {
@@ -124,6 +127,11 @@ export interface SkillEndpoint {
124
127
  responseBytes?: number;
125
128
  isolatedAuth?: boolean;
126
129
  responseSchema?: SchemaNode;
130
+ normalizedPath?: string;
131
+ confidence?: number;
132
+ endpointProvenance?: 'captured' | 'openapi-import';
133
+ specSource?: string;
134
+ description?: string;
127
135
  }
128
136
  /** The full skill file written to disk */
129
137
  export interface SkillFile {
@@ -141,6 +149,13 @@ export interface SkillFile {
141
149
  totalNetworkBytes: number;
142
150
  totalRequests: number;
143
151
  };
152
+ importHistory?: Array<{
153
+ specUrl: string;
154
+ specVersion: 'openapi3' | 'swagger2';
155
+ importedAt: string;
156
+ endpointsAdded: number;
157
+ endpointsEnriched: number;
158
+ }>;
144
159
  };
145
160
  provenance: 'self' | 'imported' | 'unsigned';
146
161
  signature?: string;
@@ -226,3 +241,29 @@ export interface DiscoveryResult {
226
241
  authSignals?: string[];
227
242
  loginUrl?: string;
228
243
  }
244
+ /** Metadata about an OpenAPI spec import */
245
+ export interface ImportMeta {
246
+ specUrl: string;
247
+ specVersion: 'openapi3' | 'swagger2';
248
+ title: string;
249
+ description: string;
250
+ requiresAuth: boolean;
251
+ authType?: 'apiKey' | 'oauth2' | 'bearer' | 'basic' | 'openIdConnect';
252
+ endpointCount: number;
253
+ }
254
+ /** Result of converting an OpenAPI spec */
255
+ export interface ImportResult {
256
+ domain: string;
257
+ endpoints: SkillEndpoint[];
258
+ meta: ImportMeta;
259
+ }
260
+ /** Result of merging imported endpoints into an existing skill file */
261
+ export interface MergeResult {
262
+ skillFile: SkillFile;
263
+ diff: {
264
+ preserved: number;
265
+ added: number;
266
+ enriched: number;
267
+ skipped: number;
268
+ };
269
+ }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@apitap/core",
3
- "version": "1.5.3",
3
+ "version": "1.6.0",
4
4
  "description": "Intercept web API traffic during browsing. Generate portable skill files so AI agents can call APIs directly instead of scraping.",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
@@ -296,7 +296,7 @@ async function doHandoff(
296
296
  const cookieDomain = (c.domain || '').replace(/^\./, ''); // Remove leading dot
297
297
  return cookieDomain === domain ||
298
298
  cookieDomain.endsWith('.' + domain) ||
299
- domain.endsWith('.' + cookieDomain);
299
+ (domain.endsWith('.' + cookieDomain) && cookieDomain.includes('.'));
300
300
  });
301
301
 
302
302
  if (cookies.length === 0 && !authDetected) {