@knowledgesdk/cli 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 (59) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +263 -0
  3. package/dist/commands/classify.d.ts +3 -0
  4. package/dist/commands/classify.d.ts.map +1 -0
  5. package/dist/commands/classify.js +45 -0
  6. package/dist/commands/classify.js.map +1 -0
  7. package/dist/commands/config.d.ts +3 -0
  8. package/dist/commands/config.d.ts.map +1 -0
  9. package/dist/commands/config.js +63 -0
  10. package/dist/commands/config.js.map +1 -0
  11. package/dist/commands/extract.d.ts +3 -0
  12. package/dist/commands/extract.d.ts.map +1 -0
  13. package/dist/commands/extract.js +136 -0
  14. package/dist/commands/extract.js.map +1 -0
  15. package/dist/commands/jobs.d.ts +3 -0
  16. package/dist/commands/jobs.d.ts.map +1 -0
  17. package/dist/commands/jobs.js +121 -0
  18. package/dist/commands/jobs.js.map +1 -0
  19. package/dist/commands/scrape.d.ts +3 -0
  20. package/dist/commands/scrape.d.ts.map +1 -0
  21. package/dist/commands/scrape.js +48 -0
  22. package/dist/commands/scrape.js.map +1 -0
  23. package/dist/commands/screenshot.d.ts +3 -0
  24. package/dist/commands/screenshot.d.ts.map +1 -0
  25. package/dist/commands/screenshot.js +58 -0
  26. package/dist/commands/screenshot.js.map +1 -0
  27. package/dist/commands/search.d.ts +3 -0
  28. package/dist/commands/search.d.ts.map +1 -0
  29. package/dist/commands/search.js +51 -0
  30. package/dist/commands/search.js.map +1 -0
  31. package/dist/commands/sitemap.d.ts +3 -0
  32. package/dist/commands/sitemap.d.ts.map +1 -0
  33. package/dist/commands/sitemap.js +45 -0
  34. package/dist/commands/sitemap.js.map +1 -0
  35. package/dist/commands/webhooks.d.ts +3 -0
  36. package/dist/commands/webhooks.d.ts.map +1 -0
  37. package/dist/commands/webhooks.js +118 -0
  38. package/dist/commands/webhooks.js.map +1 -0
  39. package/dist/index.d.ts +3 -0
  40. package/dist/index.d.ts.map +1 -0
  41. package/dist/index.js +68 -0
  42. package/dist/index.js.map +1 -0
  43. package/dist/lib/api.d.ts +71 -0
  44. package/dist/lib/api.d.ts.map +1 -0
  45. package/dist/lib/api.js +212 -0
  46. package/dist/lib/api.js.map +1 -0
  47. package/dist/lib/config.d.ts +23 -0
  48. package/dist/lib/config.d.ts.map +1 -0
  49. package/dist/lib/config.js +59 -0
  50. package/dist/lib/config.js.map +1 -0
  51. package/dist/lib/output.d.ts +73 -0
  52. package/dist/lib/output.d.ts.map +1 -0
  53. package/dist/lib/output.js +149 -0
  54. package/dist/lib/output.js.map +1 -0
  55. package/dist/types.d.ts +127 -0
  56. package/dist/types.d.ts.map +1 -0
  57. package/dist/types.js +3 -0
  58. package/dist/types.js.map +1 -0
  59. package/package.json +43 -0
@@ -0,0 +1,121 @@
1
+ import ora from 'ora';
2
+ import { getJob } from '../lib/api.js';
3
+ import { colorizeStatus, handleApiError, printError, printField, printHeader, printJson, printSuccess, theme, } from '../lib/output.js';
4
+ const TERMINAL_STATUSES = ['COMPLETED', 'FAILED', 'CANCELLED'];
5
+ const POLL_INTERVAL_MS = 3000;
6
+ const MAX_POLL_ATTEMPTS = 100; // 5 minutes at 3s intervals
7
+ export function registerJobsCommand(program) {
8
+ const jobs = program.command('jobs').description('Manage and monitor async jobs');
9
+ // ── get ─────────────────────────────────────────────────────────────────────
10
+ jobs
11
+ .command('get <jobId>')
12
+ .description('Get the current status of a job')
13
+ .option('--json', 'Output raw JSON')
14
+ .action(async (jobId, opts) => {
15
+ const spinner = ora({
16
+ text: `Fetching job ${theme.bold(jobId)}…`,
17
+ color: 'cyan',
18
+ }).start();
19
+ try {
20
+ const job = await getJob(jobId);
21
+ spinner.stop();
22
+ if (opts.json) {
23
+ printJson(job);
24
+ return;
25
+ }
26
+ printJobDetails(job);
27
+ }
28
+ catch (err) {
29
+ spinner.stop();
30
+ handleApiError(err);
31
+ }
32
+ });
33
+ // ── poll ────────────────────────────────────────────────────────────────────
34
+ jobs
35
+ .command('poll <jobId>')
36
+ .description('Poll a job until it completes (or fails)')
37
+ .option('--json', 'Output final result as raw JSON')
38
+ .option('-i, --interval <ms>', 'Polling interval in milliseconds', parseInt, POLL_INTERVAL_MS)
39
+ .action(async (jobId, opts) => {
40
+ const interval = opts.interval ?? POLL_INTERVAL_MS;
41
+ const spinner = ora({
42
+ text: `Polling job ${theme.bold(jobId)}…`,
43
+ color: 'cyan',
44
+ }).start();
45
+ let attempts = 0;
46
+ // eslint-disable-next-line no-constant-condition
47
+ while (true) {
48
+ attempts++;
49
+ try {
50
+ const job = await getJob(jobId);
51
+ const progress = job.progress !== undefined ? ` (${job.progress}%)` : '';
52
+ spinner.text = `Job ${theme.bold(jobId)} — ${colorizeStatus(job.status)}${progress}`;
53
+ if (TERMINAL_STATUSES.includes(job.status)) {
54
+ spinner.stop();
55
+ if (opts.json) {
56
+ printJson(job);
57
+ return;
58
+ }
59
+ printJobDetails(job);
60
+ if (job.status === 'COMPLETED') {
61
+ printSuccess('Job completed successfully.');
62
+ }
63
+ else {
64
+ printError(`Job ended with status: ${job.status}`, job.error);
65
+ process.exit(1);
66
+ }
67
+ console.log('');
68
+ return;
69
+ }
70
+ if (attempts >= MAX_POLL_ATTEMPTS) {
71
+ spinner.stop();
72
+ printError(`Timed out after ${MAX_POLL_ATTEMPTS} polling attempts.`, `Check status manually: knowledgesdk jobs get ${jobId}`);
73
+ process.exit(1);
74
+ }
75
+ await sleep(interval);
76
+ }
77
+ catch (err) {
78
+ spinner.stop();
79
+ handleApiError(err);
80
+ }
81
+ }
82
+ });
83
+ }
84
+ function printJobDetails(job) {
85
+ printHeader('Job details');
86
+ printField('Job ID', job.jobId);
87
+ printField('Status', colorizeStatus(job.status));
88
+ if (job.type)
89
+ printField('Type', job.type);
90
+ if (job.url)
91
+ printField('URL', job.url);
92
+ if (job.progress !== undefined)
93
+ printField('Progress', `${job.progress}%`);
94
+ printField('Created', job.createdAt);
95
+ if (job.updatedAt)
96
+ printField('Updated', job.updatedAt);
97
+ if (job.completedAt)
98
+ printField('Completed', job.completedAt);
99
+ if (job.error) {
100
+ console.log('');
101
+ console.log(` ${theme.label('Error')}`);
102
+ console.log(` ${theme.error(job.error)}`);
103
+ }
104
+ if (job.result && job.status === 'COMPLETED') {
105
+ console.log('');
106
+ console.log(` ${theme.label('Result preview')}`);
107
+ const preview = JSON.stringify(job.result, null, 2).slice(0, 500);
108
+ console.log(preview
109
+ .split('\n')
110
+ .map((l) => ` ${theme.dim(l)}`)
111
+ .join('\n'));
112
+ if (JSON.stringify(job.result).length > 500) {
113
+ console.log(theme.muted(' … (truncated, use --json for full output)'));
114
+ }
115
+ }
116
+ console.log('');
117
+ }
118
+ function sleep(ms) {
119
+ return new Promise((resolve) => setTimeout(resolve, ms));
120
+ }
121
+ //# sourceMappingURL=jobs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"jobs.js","sourceRoot":"","sources":["../../src/commands/jobs.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerScrapeCommand(program: Command): void;
3
+ //# sourceMappingURL=scrape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scrape.d.ts","sourceRoot":"","sources":["../../src/commands/scrape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAapC,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CA+C5D"}
@@ -0,0 +1,48 @@
1
+ import ora from 'ora';
2
+ import { scrapeUrl } from '../lib/api.js';
3
+ import { handleApiError, printField, printHeader, printJson, saveToFile, theme, } from '../lib/output.js';
4
+ export function registerScrapeCommand(program) {
5
+ program
6
+ .command('scrape <url>')
7
+ .description('Scrape a URL and return its content as Markdown')
8
+ .option('-o, --output <file>', 'Save markdown to a file')
9
+ .option('--json', 'Output raw JSON including metadata')
10
+ .action(async (url, opts) => {
11
+ const spinner = ora({
12
+ text: `Scraping ${theme.url(url)}…`,
13
+ color: 'cyan',
14
+ }).start();
15
+ try {
16
+ const result = await scrapeUrl(url);
17
+ spinner.stop();
18
+ if (opts.json) {
19
+ printJson(result);
20
+ return;
21
+ }
22
+ if (opts.output) {
23
+ // Save raw markdown
24
+ saveToFile(opts.output, result.markdown);
25
+ return;
26
+ }
27
+ // Pretty print
28
+ printHeader('Scrape result');
29
+ printField('URL', result.url);
30
+ if (result.title)
31
+ printField('Title', result.title);
32
+ console.log('');
33
+ console.log(theme.label(' Content (Markdown):'));
34
+ console.log(theme.dim(' ' + '─'.repeat(50)));
35
+ // Print first 3000 chars to avoid flooding the terminal
36
+ const preview = result.markdown.length > 3000
37
+ ? result.markdown.slice(0, 3000) + '\n\n…(truncated, use --output to save full content)'
38
+ : result.markdown;
39
+ console.log(preview);
40
+ console.log('');
41
+ }
42
+ catch (err) {
43
+ spinner.stop();
44
+ handleApiError(err);
45
+ }
46
+ });
47
+ }
48
+ //# sourceMappingURL=scrape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scrape.js","sourceRoot":"","sources":["../../src/commands/scrape.ts"],"names":[],"mappings":"AACA,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EACL,cAAc,EACd,UAAU,EACV,WAAW,EACX,SAAS,EACT,UAAU,EACV,KAAK,GACN,MAAM,kBAAkB,CAAC;AAG1B,MAAM,UAAU,qBAAqB,CAAC,OAAgB;IACpD,OAAO;SACJ,OAAO,CAAC,cAAc,CAAC;SACvB,WAAW,CAAC,iDAAiD,CAAC;SAC9D,MAAM,CAAC,qBAAqB,EAAE,yBAAyB,CAAC;SACxD,MAAM,CAAC,QAAQ,EAAE,oCAAoC,CAAC;SACtD,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAwC,EAAE,EAAE;QACtE,MAAM,OAAO,GAAG,GAAG,CAAC;YAClB,IAAI,EAAE,YAAY,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG;YACnC,KAAK,EAAE,MAAM;SACd,CAAC,CAAC,KAAK,EAAE,CAAC;QAEX,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,SAAS,CAAC,GAAG,CAAC,CAAC;YAEpC,OAAO,CAAC,IAAI,EAAE,CAAC;YAEf,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,SAAS,CAAC,MAAM,CAAC,CAAC;gBAClB,OAAO;YACT,CAAC;YAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,oBAAoB;gBACpB,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;gBACzC,OAAO;YACT,CAAC;YAED,eAAe;YACf,WAAW,CAAC,eAAe,CAAC,CAAC;YAC7B,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YAC9B,IAAI,MAAM,CAAC,KAAK;gBAAE,UAAU,CAAC,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;YACpD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAChB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,uBAAuB,CAAC,CAAC,CAAC;YAClD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,GAAG,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9C,wDAAwD;YACxD,MAAM,OAAO,GACX,MAAM,CAAC,QAAQ,CAAC,MAAM,GAAG,IAAI;gBAC3B,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,GAAG,qDAAqD;gBACxF,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC;YACtB,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;YACrB,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,IAAI,EAAE,CAAC;YACf,cAAc,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerScreenshotCommand(program: Command): void;
3
+ //# sourceMappingURL=screenshot.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"screenshot.d.ts","sourceRoot":"","sources":["../../src/commands/screenshot.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAcpC,wBAAgB,yBAAyB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAqDhE"}
@@ -0,0 +1,58 @@
1
+ import { writeFileSync } from 'fs';
2
+ import ora from 'ora';
3
+ import { takeScreenshot } from '../lib/api.js';
4
+ import { handleApiError, printField, printHeader, printJson, printSuccess, printInfo, theme, } from '../lib/output.js';
5
+ export function registerScreenshotCommand(program) {
6
+ program
7
+ .command('screenshot <url>')
8
+ .description('Take a screenshot of a website')
9
+ .option('-o, --output <file>', 'Save screenshot to a PNG file')
10
+ .option('--json', 'Output raw JSON (includes base64 image data)')
11
+ .action(async (url, opts) => {
12
+ const spinner = ora({
13
+ text: `Taking screenshot of ${theme.url(url)}…`,
14
+ color: 'cyan',
15
+ }).start();
16
+ try {
17
+ const result = await takeScreenshot(url);
18
+ spinner.stop();
19
+ if (opts.json) {
20
+ printJson(result);
21
+ return;
22
+ }
23
+ printHeader('Screenshot');
24
+ printField('URL', result.url);
25
+ if (result.width && result.height) {
26
+ printField('Dimensions', `${result.width}x${result.height}`);
27
+ }
28
+ if (opts.output) {
29
+ if (result.imageBase64) {
30
+ const buffer = Buffer.from(result.imageBase64, 'base64');
31
+ writeFileSync(opts.output, buffer);
32
+ printSuccess(`Screenshot saved to ${theme.url(opts.output)}`);
33
+ }
34
+ else if (result.imageUrl) {
35
+ printInfo(`Download your screenshot from: ${theme.url(result.imageUrl)}`);
36
+ }
37
+ else {
38
+ printInfo('No image data returned from the API.');
39
+ }
40
+ }
41
+ else {
42
+ if (result.imageUrl) {
43
+ printField('Image URL', result.imageUrl);
44
+ printInfo('Use --output screenshot.png to save the image.');
45
+ }
46
+ else if (result.imageBase64) {
47
+ printInfo('Image returned as base64. Use --output <file.png> to save.');
48
+ }
49
+ }
50
+ console.log('');
51
+ }
52
+ catch (err) {
53
+ spinner.stop();
54
+ handleApiError(err);
55
+ }
56
+ });
57
+ }
58
+ //# sourceMappingURL=screenshot.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"screenshot.js","sourceRoot":"","sources":["../../src/commands/screenshot.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC;AAEnC,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EACL,cAAc,EACd,UAAU,EACV,WAAW,EACX,SAAS,EACT,YAAY,EACZ,SAAS,EACT,KAAK,GACN,MAAM,kBAAkB,CAAC;AAG1B,MAAM,UAAU,yBAAyB,CAAC,OAAgB;IACxD,OAAO;SACJ,OAAO,CAAC,kBAAkB,CAAC;SAC3B,WAAW,CAAC,gCAAgC,CAAC;SAC7C,MAAM,CAAC,qBAAqB,EAAE,+BAA+B,CAAC;SAC9D,MAAM,CAAC,QAAQ,EAAE,8CAA8C,CAAC;SAChE,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAA4C,EAAE,EAAE;QAC1E,MAAM,OAAO,GAAG,GAAG,CAAC;YAClB,IAAI,EAAE,wBAAwB,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG;YAC/C,KAAK,EAAE,MAAM;SACd,CAAC,CAAC,KAAK,EAAE,CAAC;QAEX,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,cAAc,CAAC,GAAG,CAAC,CAAC;YAEzC,OAAO,CAAC,IAAI,EAAE,CAAC;YAEf,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,SAAS,CAAC,MAAM,CAAC,CAAC;gBAClB,OAAO;YACT,CAAC;YAED,WAAW,CAAC,YAAY,CAAC,CAAC;YAC1B,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YAC9B,IAAI,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;gBAClC,UAAU,CAAC,YAAY,EAAE,GAAG,MAAM,CAAC,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC;YAC/D,CAAC;YAED,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;oBACvB,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;oBACzD,aAAa,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;oBACnC,YAAY,CAAC,uBAAuB,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;gBAChE,CAAC;qBAAM,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;oBAC3B,SAAS,CAAC,kCAAkC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;gBAC5E,CAAC;qBAAM,CAAC;oBACN,SAAS,CAAC,sCAAsC,CAAC,CAAC;gBACpD,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;oBACpB,UAAU,CAAC,WAAW,EAAE,MAAM,CAAC,QAAQ,CAAC,CAAC;oBACzC,SAAS,CAAC,gDAAgD,CAAC,CAAC;gBAC9D,CAAC;qBAAM,IAAI,MAAM,CAAC,WAAW,EAAE,CAAC;oBAC9B,SAAS,CAAC,4DAA4D,CAAC,CAAC;gBAC1E,CAAC;YACH,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,IAAI,EAAE,CAAC;YACf,cAAc,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerSearchCommand(program: Command): void;
3
+ //# sourceMappingURL=search.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.d.ts","sourceRoot":"","sources":["../../src/commands/search.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAapC,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAmD5D"}
@@ -0,0 +1,51 @@
1
+ import ora from 'ora';
2
+ import { searchKnowledge } from '../lib/api.js';
3
+ import { handleApiError, printField, printHeader, printJson, theme, sym, } from '../lib/output.js';
4
+ export function registerSearchCommand(program) {
5
+ program
6
+ .command('search <query>')
7
+ .description('Search your extracted knowledge base')
8
+ .option('-l, --limit <number>', 'Maximum number of results to return', parseInt)
9
+ .option('--json', 'Output raw JSON')
10
+ .action(async (query, opts) => {
11
+ const spinner = ora({
12
+ text: `Searching for ${theme.highlight(`"${query}"`)}…`,
13
+ color: 'cyan',
14
+ }).start();
15
+ try {
16
+ const result = await searchKnowledge(query, opts.limit);
17
+ spinner.stop();
18
+ if (opts.json) {
19
+ printJson(result);
20
+ return;
21
+ }
22
+ printHeader(`Search results for "${query}"`);
23
+ printField('Total results', result.total);
24
+ console.log('');
25
+ if (result.results.length === 0) {
26
+ console.log(` ${sym.info} ${theme.muted('No results found.')}`);
27
+ console.log('');
28
+ return;
29
+ }
30
+ for (let i = 0; i < result.results.length; i++) {
31
+ const item = result.results[i];
32
+ const num = theme.muted(`${i + 1}.`);
33
+ console.log(` ${num} ${theme.bold(item.title ?? 'Untitled')}`);
34
+ console.log(` ${theme.url(item.url)}`);
35
+ if (item.score !== undefined) {
36
+ const pct = Math.round(item.score * 100);
37
+ console.log(` ${theme.muted('Score:')} ${theme.info(`${pct}%`)}`);
38
+ }
39
+ if (item.snippet) {
40
+ console.log(` ${theme.dim(item.snippet)}`);
41
+ }
42
+ console.log('');
43
+ }
44
+ }
45
+ catch (err) {
46
+ spinner.stop();
47
+ handleApiError(err);
48
+ }
49
+ });
50
+ }
51
+ //# sourceMappingURL=search.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"search.js","sourceRoot":"","sources":["../../src/commands/search.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerSitemapCommand(program: Command): void;
3
+ //# sourceMappingURL=sitemap.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sitemap.d.ts","sourceRoot":"","sources":["../../src/commands/sitemap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAYpC,wBAAgB,sBAAsB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAmD7D"}
@@ -0,0 +1,45 @@
1
+ import ora from 'ora';
2
+ import { getSitemap } from '../lib/api.js';
3
+ import { handleApiError, printField, printHeader, printJson, theme, sym, } from '../lib/output.js';
4
+ export function registerSitemapCommand(program) {
5
+ program
6
+ .command('sitemap <url>')
7
+ .description('Retrieve the sitemap for a website')
8
+ .option('--json', 'Output raw JSON')
9
+ .option('-l, --limit <number>', 'Limit number of URLs shown', parseInt)
10
+ .action(async (url, opts) => {
11
+ const spinner = ora({
12
+ text: `Fetching sitemap for ${theme.url(url)}…`,
13
+ color: 'cyan',
14
+ }).start();
15
+ try {
16
+ const result = await getSitemap(url);
17
+ spinner.stop();
18
+ if (opts.json) {
19
+ printJson(result);
20
+ return;
21
+ }
22
+ printHeader('Sitemap');
23
+ printField('URL', result.url);
24
+ printField('Total pages', result.totalPages);
25
+ console.log('');
26
+ const pages = opts.limit ? result.pages.slice(0, opts.limit) : result.pages;
27
+ for (const page of pages) {
28
+ console.log(` ${sym.bullet} ${theme.url(page.url)}`);
29
+ if (page.lastModified) {
30
+ console.log(` ${theme.muted('Last modified:')} ${theme.dim(page.lastModified)}`);
31
+ }
32
+ }
33
+ if (opts.limit && result.pages.length > opts.limit) {
34
+ console.log('');
35
+ console.log(theme.muted(` … and ${result.pages.length - opts.limit} more pages (use --limit to adjust)`));
36
+ }
37
+ console.log('');
38
+ }
39
+ catch (err) {
40
+ spinner.stop();
41
+ handleApiError(err);
42
+ }
43
+ });
44
+ }
45
+ //# sourceMappingURL=sitemap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sitemap.js","sourceRoot":"","sources":["../../src/commands/sitemap.ts"],"names":[],"mappings":"AACA,OAAO,GAAG,MAAM,KAAK,CAAC;AACtB,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EACL,cAAc,EACd,UAAU,EACV,WAAW,EACX,SAAS,EACT,KAAK,EACL,GAAG,GACJ,MAAM,kBAAkB,CAAC;AAE1B,MAAM,UAAU,sBAAsB,CAAC,OAAgB;IACrD,OAAO;SACJ,OAAO,CAAC,eAAe,CAAC;SACxB,WAAW,CAAC,oCAAoC,CAAC;SACjD,MAAM,CAAC,QAAQ,EAAE,iBAAiB,CAAC;SACnC,MAAM,CAAC,sBAAsB,EAAE,4BAA4B,EAAE,QAAQ,CAAC;SACtE,MAAM,CAAC,KAAK,EAAE,GAAW,EAAE,IAAwC,EAAE,EAAE;QACtE,MAAM,OAAO,GAAG,GAAG,CAAC;YAClB,IAAI,EAAE,wBAAwB,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG;YAC/C,KAAK,EAAE,MAAM;SACd,CAAC,CAAC,KAAK,EAAE,CAAC;QAEX,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,UAAU,CAAC,GAAG,CAAC,CAAC;YAErC,OAAO,CAAC,IAAI,EAAE,CAAC;YAEf,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,SAAS,CAAC,MAAM,CAAC,CAAC;gBAClB,OAAO;YACT,CAAC;YAED,WAAW,CAAC,SAAS,CAAC,CAAC;YACvB,UAAU,CAAC,KAAK,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YAC9B,UAAU,CAAC,aAAa,EAAE,MAAM,CAAC,UAAU,CAAC,CAAC;YAC7C,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YAEhB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;YAE5E,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;gBACzB,OAAO,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,MAAM,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBACtD,IAAI,IAAI,CAAC,YAAY,EAAE,CAAC;oBACtB,OAAO,CAAC,GAAG,CAAC,OAAO,KAAK,CAAC,KAAK,CAAC,gBAAgB,CAAC,IAAI,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;gBACtF,CAAC;YACH,CAAC;YAED,IAAI,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,CAAC;gBACnD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAChB,OAAO,CAAC,GAAG,CACT,KAAK,CAAC,KAAK,CACT,WAAW,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,qCAAqC,CACjF,CACF,CAAC;YACJ,CAAC;YAED,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAClB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,OAAO,CAAC,IAAI,EAAE,CAAC;YACf,cAAc,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC,CAAC;AACP,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { Command } from 'commander';
2
+ export declare function registerWebhooksCommand(program: Command): void;
3
+ //# sourceMappingURL=webhooks.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webhooks.d.ts","sourceRoot":"","sources":["../../src/commands/webhooks.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAmBpC,wBAAgB,uBAAuB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAqJ9D"}
@@ -0,0 +1,118 @@
1
+ import ora from 'ora';
2
+ import { createWebhook, deleteWebhook, listWebhooks, } from '../lib/api.js';
3
+ import { handleApiError, printError, printField, printHeader, printJson, printSuccess, theme, sym, } from '../lib/output.js';
4
+ export function registerWebhooksCommand(program) {
5
+ const webhooks = program
6
+ .command('webhooks')
7
+ .description('Manage webhooks for event notifications');
8
+ // ── list ────────────────────────────────────────────────────────────────────
9
+ webhooks
10
+ .command('list')
11
+ .description('List all configured webhooks')
12
+ .option('--json', 'Output raw JSON')
13
+ .action(async (opts) => {
14
+ const spinner = ora({ text: 'Fetching webhooks…', color: 'cyan' }).start();
15
+ try {
16
+ const result = await listWebhooks();
17
+ spinner.stop();
18
+ if (opts.json) {
19
+ printJson(result);
20
+ return;
21
+ }
22
+ printHeader('Webhooks');
23
+ printField('Total', result.total);
24
+ console.log('');
25
+ if (result.webhooks.length === 0) {
26
+ console.log(` ${sym.info} ${theme.muted('No webhooks configured.')}`);
27
+ console.log(` ${theme.muted('Create one with:')} knowledgesdk webhooks create --url <url> --events <events>`);
28
+ console.log('');
29
+ return;
30
+ }
31
+ for (const wh of result.webhooks) {
32
+ const status = wh.active
33
+ ? theme.success('active')
34
+ : theme.error('inactive');
35
+ console.log(` ${sym.bullet} ${theme.bold(wh.id)}`);
36
+ console.log(` ${theme.label('URL')} ${theme.url(wh.url)}`);
37
+ console.log(` ${theme.label('Status')} ${status}`);
38
+ console.log(` ${theme.label('Events')} ${wh.events.map((e) => theme.info(e)).join(', ')}`);
39
+ console.log(` ${theme.label('Created')} ${theme.dim(wh.createdAt)}`);
40
+ console.log('');
41
+ }
42
+ }
43
+ catch (err) {
44
+ spinner.stop();
45
+ handleApiError(err);
46
+ }
47
+ });
48
+ // ── create ──────────────────────────────────────────────────────────────────
49
+ webhooks
50
+ .command('create')
51
+ .description('Create a new webhook')
52
+ .requiredOption('-u, --url <url>', 'Endpoint URL to receive events')
53
+ .option('-e, --events <events>', 'Comma-separated list of events (e.g. EXTRACTION_COMPLETED,PAGE_SCRAPED)', 'EXTRACTION_COMPLETED')
54
+ .option('--json', 'Output raw JSON')
55
+ .action(async (opts) => {
56
+ const validEvents = [
57
+ 'EXTRACTION_COMPLETED',
58
+ 'EXTRACTION_FAILED',
59
+ 'PAGE_SCRAPED',
60
+ 'JOB_STARTED',
61
+ 'JOB_FAILED',
62
+ ];
63
+ const requestedEvents = opts.events
64
+ .split(',')
65
+ .map((e) => e.trim().toUpperCase());
66
+ const invalidEvents = requestedEvents.filter((e) => !validEvents.includes(e));
67
+ if (invalidEvents.length > 0) {
68
+ printError(`Invalid event(s): ${invalidEvents.join(', ')}`, `Valid events: ${validEvents.join(', ')}`);
69
+ process.exit(1);
70
+ }
71
+ const spinner = ora({
72
+ text: `Creating webhook for ${theme.url(opts.url)}…`,
73
+ color: 'cyan',
74
+ }).start();
75
+ try {
76
+ const webhook = await createWebhook(opts.url, requestedEvents);
77
+ spinner.stop();
78
+ if (opts.json) {
79
+ printJson(webhook);
80
+ return;
81
+ }
82
+ printHeader('Webhook created');
83
+ printField('ID', webhook.id);
84
+ printField('URL', webhook.url);
85
+ printField('Events', webhook.events.map((e) => theme.info(e)).join(', '));
86
+ printField('Status', webhook.active ? theme.success('active') : theme.error('inactive'));
87
+ printField('Created', webhook.createdAt);
88
+ console.log('');
89
+ printSuccess(`Webhook ${theme.bold(webhook.id)} created.`);
90
+ console.log('');
91
+ }
92
+ catch (err) {
93
+ spinner.stop();
94
+ handleApiError(err);
95
+ }
96
+ });
97
+ // ── delete ──────────────────────────────────────────────────────────────────
98
+ webhooks
99
+ .command('delete <id>')
100
+ .description('Delete a webhook by ID')
101
+ .action(async (id) => {
102
+ const spinner = ora({
103
+ text: `Deleting webhook ${theme.bold(id)}…`,
104
+ color: 'cyan',
105
+ }).start();
106
+ try {
107
+ await deleteWebhook(id);
108
+ spinner.stop();
109
+ printSuccess(`Webhook ${theme.bold(id)} deleted.`);
110
+ console.log('');
111
+ }
112
+ catch (err) {
113
+ spinner.stop();
114
+ handleApiError(err);
115
+ }
116
+ });
117
+ }
118
+ //# sourceMappingURL=webhooks.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"webhooks.js","sourceRoot":"","sources":["../../src/commands/webhooks.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":""}
package/dist/index.js ADDED
@@ -0,0 +1,68 @@
1
+ #!/usr/bin/env node
2
+ import { Command } from 'commander';
3
+ import { registerConfigCommand } from './commands/config.js';
4
+ import { registerExtractCommand } from './commands/extract.js';
5
+ import { registerScrapeCommand } from './commands/scrape.js';
6
+ import { registerClassifyCommand } from './commands/classify.js';
7
+ import { registerSitemapCommand } from './commands/sitemap.js';
8
+ import { registerScreenshotCommand } from './commands/screenshot.js';
9
+ import { registerSearchCommand } from './commands/search.js';
10
+ import { registerWebhooksCommand } from './commands/webhooks.js';
11
+ import { registerJobsCommand } from './commands/jobs.js';
12
+ import { printError, theme } from './lib/output.js';
13
+ import { resolveApiKey } from './lib/config.js';
14
+ const program = new Command();
15
+ program
16
+ .name('knowledgesdk')
17
+ .description([
18
+ '',
19
+ theme.brand.bold(' KnowledgeSDK CLI'),
20
+ theme.muted(' Extract, scrape, classify, and search website knowledge'),
21
+ '',
22
+ ` ${theme.label('Quickstart')}`,
23
+ ` ${theme.dim('1.')} knowledgesdk config --key sk_ks_your_key`,
24
+ ` ${theme.dim('2.')} knowledgesdk extract https://example.com`,
25
+ '',
26
+ ].join('\n'))
27
+ .version('0.1.0', '-v, --version', 'Display the current version')
28
+ .addHelpText('after', [
29
+ '',
30
+ theme.muted(' Documentation: https://docs.knowledgesdk.com'),
31
+ theme.muted(' Support: https://knowledgesdk.com/support'),
32
+ '',
33
+ ].join('\n'));
34
+ // Register all sub-commands
35
+ registerConfigCommand(program);
36
+ registerExtractCommand(program);
37
+ registerScrapeCommand(program);
38
+ registerClassifyCommand(program);
39
+ registerSitemapCommand(program);
40
+ registerScreenshotCommand(program);
41
+ registerSearchCommand(program);
42
+ registerWebhooksCommand(program);
43
+ registerJobsCommand(program);
44
+ // Global error handler — catch unknown options / commands gracefully
45
+ program.on('command:*', (operands) => {
46
+ printError(`Unknown command: ${operands[0]}`, 'Run `knowledgesdk --help` to see available commands.');
47
+ process.exit(1);
48
+ });
49
+ // Show a friendly warning if no API key is configured (except for `config` command)
50
+ const args = process.argv.slice(2);
51
+ const firstArg = args[0];
52
+ const noKeyNeeded = ['config', '--help', '-h', '--version', '-v', 'help', undefined];
53
+ if (!noKeyNeeded.includes(firstArg) && !resolveApiKey()) {
54
+ // Defer until after parse so the help text still shows
55
+ process.nextTick(() => {
56
+ if (args.length > 0) {
57
+ console.error([
58
+ '',
59
+ ` ${theme.warning('No API key configured.')}`,
60
+ ` ${theme.muted('Set your key:')} knowledgesdk config --key sk_ks_your_key`,
61
+ ` ${theme.muted('Or export:')} KNOWLEDGESDK_API_KEY=sk_ks_your_key`,
62
+ '',
63
+ ].join('\n'));
64
+ }
65
+ });
66
+ }
67
+ program.parse(process.argv);
68
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}