web-agent-bridge 1.2.0 → 2.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 (111) hide show
  1. package/LICENSE +21 -21
  2. package/README.ar.md +572 -446
  3. package/README.md +968 -933
  4. package/bin/agent-runner.js +465 -0
  5. package/bin/cli.js +138 -80
  6. package/bin/wab.js +80 -80
  7. package/examples/bidi-agent.js +119 -119
  8. package/examples/mcp-agent.js +94 -94
  9. package/examples/next-app-router/README.md +44 -0
  10. package/examples/puppeteer-agent.js +108 -108
  11. package/examples/saas-dashboard/README.md +55 -0
  12. package/examples/shopify-hydrogen/README.md +74 -0
  13. package/examples/vision-agent.js +171 -171
  14. package/examples/wordpress-elementor/README.md +77 -0
  15. package/package.json +71 -78
  16. package/public/.well-known/ai-assets.json +59 -0
  17. package/public/admin/login.html +84 -84
  18. package/public/ai.html +196 -0
  19. package/public/cookies.html +208 -208
  20. package/public/css/premium.css +317 -0
  21. package/public/css/styles.css +1235 -1235
  22. package/public/dashboard.html +704 -704
  23. package/public/demo.html +259 -0
  24. package/public/docs.html +585 -585
  25. package/public/feed.xml +89 -0
  26. package/public/index.html +581 -332
  27. package/public/js/auth-nav.js +31 -31
  28. package/public/js/auth-redirect.js +12 -12
  29. package/public/js/cookie-consent.js +56 -56
  30. package/public/js/wab-demo-page.js +721 -0
  31. package/public/js/ws-client.js +74 -74
  32. package/public/llms-full.txt +309 -0
  33. package/public/llms.txt +85 -0
  34. package/public/login.html +83 -83
  35. package/public/openapi.json +580 -0
  36. package/public/premium-dashboard.html +2487 -0
  37. package/public/premium.html +791 -0
  38. package/public/privacy.html +295 -295
  39. package/public/register.html +103 -103
  40. package/public/robots.txt +87 -0
  41. package/public/script/wab-consent.d.ts +36 -0
  42. package/public/script/wab-consent.js +104 -0
  43. package/public/script/wab-schema.js +131 -0
  44. package/public/script/wab.d.ts +108 -0
  45. package/public/script/wab.min.js +405 -0
  46. package/public/sitemap.xml +93 -0
  47. package/public/sovereign.html +660 -0
  48. package/public/terms.html +254 -254
  49. package/public/video/tutorial.mp4 +0 -0
  50. package/script/ai-agent-bridge.js +1558 -1513
  51. package/sdk/README.md +55 -55
  52. package/sdk/index.d.ts +118 -0
  53. package/sdk/index.js +257 -203
  54. package/sdk/package.json +14 -14
  55. package/sdk/schema-discovery.js +83 -0
  56. package/server/config/secrets.js +94 -92
  57. package/server/index.js +2 -9
  58. package/server/middleware/adminAuth.js +30 -30
  59. package/server/middleware/auth.js +41 -41
  60. package/server/middleware/rateLimits.js +24 -24
  61. package/server/migrations/001_add_analytics_indexes.sql +7 -7
  62. package/server/migrations/002_premium_features.sql +418 -0
  63. package/server/models/adapters/index.js +33 -33
  64. package/server/models/adapters/mysql.js +183 -183
  65. package/server/models/adapters/postgresql.js +172 -172
  66. package/server/models/adapters/sqlite.js +7 -7
  67. package/server/models/db.js +561 -561
  68. package/server/routes/admin-premium.js +671 -0
  69. package/server/routes/admin.js +247 -247
  70. package/server/routes/api.js +131 -138
  71. package/server/routes/auth.js +51 -51
  72. package/server/routes/billing.js +45 -45
  73. package/server/routes/discovery.js +406 -329
  74. package/server/routes/license.js +240 -240
  75. package/server/routes/noscript.js +543 -543
  76. package/server/routes/premium-v2.js +686 -0
  77. package/server/routes/premium.js +724 -0
  78. package/server/routes/sovereign.js +307 -0
  79. package/server/routes/wab-api.js +476 -476
  80. package/server/services/agent-memory.js +625 -0
  81. package/server/services/email.js +204 -204
  82. package/server/services/fairness.js +420 -420
  83. package/server/services/negotiation.js +439 -0
  84. package/server/services/plugins.js +747 -0
  85. package/server/services/premium.js +1883 -0
  86. package/server/services/reputation.js +465 -0
  87. package/server/services/self-healing.js +843 -0
  88. package/server/services/stripe.js +192 -192
  89. package/server/services/swarm.js +788 -0
  90. package/server/services/verification.js +481 -0
  91. package/server/services/vision.js +871 -0
  92. package/server/utils/cache.js +125 -125
  93. package/server/utils/migrate.js +81 -81
  94. package/server/utils/secureFields.js +50 -50
  95. package/server/ws.js +101 -101
  96. package/templates/artisan-marketplace.yaml +104 -0
  97. package/templates/book-price-scout.yaml +98 -0
  98. package/templates/electronics-price-tracker.yaml +108 -0
  99. package/templates/flight-deal-hunter.yaml +113 -0
  100. package/templates/freelancer-direct.yaml +116 -0
  101. package/templates/grocery-price-compare.yaml +93 -0
  102. package/templates/hotel-direct-booking.yaml +113 -0
  103. package/templates/local-services.yaml +98 -0
  104. package/templates/olive-oil-tunisia.yaml +88 -0
  105. package/templates/organic-farm-fresh.yaml +101 -0
  106. package/templates/restaurant-direct.yaml +97 -0
  107. package/docs/DEPLOY.md +0 -118
  108. package/docs/SPEC.md +0 -1540
  109. package/wab-mcp-adapter/README.md +0 -136
  110. package/wab-mcp-adapter/index.js +0 -555
  111. package/wab-mcp-adapter/package.json +0 -17
package/bin/wab.js CHANGED
@@ -1,80 +1,80 @@
1
- #!/usr/bin/env node
2
-
3
- /**
4
- * Web Agent Bridge CLI
5
- * Usage: npx web-agent-bridge [command]
6
- */
7
-
8
- const path = require('path');
9
- const fs = require('fs');
10
-
11
- const args = process.argv.slice(2);
12
- const command = args[0] || 'start';
13
-
14
- function printHelp() {
15
- console.log(`
16
- Web Agent Bridge CLI
17
-
18
- Usage:
19
- npx web-agent-bridge <command> [options]
20
-
21
- Commands:
22
- start Start the WAB server (default)
23
- init Create .env file from template
24
- help Show this help message
25
-
26
- Options:
27
- --port, -p Set server port (default: 3000)
28
-
29
- Examples:
30
- npx web-agent-bridge start
31
- npx web-agent-bridge start --port 4000
32
- npx web-agent-bridge init
33
- `);
34
- }
35
-
36
- switch (command) {
37
- case 'start': {
38
- const portIdx = args.indexOf('--port') !== -1 ? args.indexOf('--port') : args.indexOf('-p');
39
- if (portIdx !== -1 && args[portIdx + 1]) {
40
- process.env.PORT = args[portIdx + 1];
41
- }
42
-
43
- const envPath = path.join(process.cwd(), '.env');
44
- if (fs.existsSync(envPath)) {
45
- require('dotenv').config({ path: envPath });
46
- }
47
-
48
- require('../server/index.js');
49
- break;
50
- }
51
-
52
- case 'init': {
53
- const envExample = path.join(__dirname, '..', '.env.example');
54
- const envTarget = path.join(process.cwd(), '.env');
55
-
56
- if (fs.existsSync(envTarget)) {
57
- console.log(' .env file already exists. Skipping.');
58
- } else if (fs.existsSync(envExample)) {
59
- fs.copyFileSync(envExample, envTarget);
60
- console.log(' Created .env file from template.');
61
- console.log(' Edit .env to set your JWT_SECRET before starting.');
62
- } else {
63
- const defaultEnv = 'PORT=3000\nJWT_SECRET=change-this-to-a-strong-random-secret-in-production\nNODE_ENV=development\n';
64
- fs.writeFileSync(envTarget, defaultEnv);
65
- console.log(' Created default .env file.');
66
- }
67
- break;
68
- }
69
-
70
- case 'help':
71
- case '--help':
72
- case '-h':
73
- printHelp();
74
- break;
75
-
76
- default:
77
- console.error(` Unknown command: ${command}`);
78
- printHelp();
79
- process.exit(1);
80
- }
1
+ #!/usr/bin/env node
2
+
3
+ /**
4
+ * Web Agent Bridge CLI
5
+ * Usage: npx web-agent-bridge [command]
6
+ */
7
+
8
+ const path = require('path');
9
+ const fs = require('fs');
10
+
11
+ const args = process.argv.slice(2);
12
+ const command = args[0] || 'start';
13
+
14
+ function printHelp() {
15
+ console.log(`
16
+ Web Agent Bridge CLI
17
+
18
+ Usage:
19
+ npx web-agent-bridge <command> [options]
20
+
21
+ Commands:
22
+ start Start the WAB server (default)
23
+ init Create .env file from template
24
+ help Show this help message
25
+
26
+ Options:
27
+ --port, -p Set server port (default: 3000)
28
+
29
+ Examples:
30
+ npx web-agent-bridge start
31
+ npx web-agent-bridge start --port 4000
32
+ npx web-agent-bridge init
33
+ `);
34
+ }
35
+
36
+ switch (command) {
37
+ case 'start': {
38
+ const portIdx = args.indexOf('--port') !== -1 ? args.indexOf('--port') : args.indexOf('-p');
39
+ if (portIdx !== -1 && args[portIdx + 1]) {
40
+ process.env.PORT = args[portIdx + 1];
41
+ }
42
+
43
+ const envPath = path.join(process.cwd(), '.env');
44
+ if (fs.existsSync(envPath)) {
45
+ require('dotenv').config({ path: envPath });
46
+ }
47
+
48
+ require('../server/index.js');
49
+ break;
50
+ }
51
+
52
+ case 'init': {
53
+ const envExample = path.join(__dirname, '..', '.env.example');
54
+ const envTarget = path.join(process.cwd(), '.env');
55
+
56
+ if (fs.existsSync(envTarget)) {
57
+ console.log(' .env file already exists. Skipping.');
58
+ } else if (fs.existsSync(envExample)) {
59
+ fs.copyFileSync(envExample, envTarget);
60
+ console.log(' Created .env file from template.');
61
+ console.log(' Edit .env to set your JWT_SECRET before starting.');
62
+ } else {
63
+ const defaultEnv = 'PORT=3000\nJWT_SECRET=change-this-to-a-strong-random-secret-in-production\nNODE_ENV=development\n';
64
+ fs.writeFileSync(envTarget, defaultEnv);
65
+ console.log(' Created default .env file.');
66
+ }
67
+ break;
68
+ }
69
+
70
+ case 'help':
71
+ case '--help':
72
+ case '-h':
73
+ printHelp();
74
+ break;
75
+
76
+ default:
77
+ console.error(` Unknown command: ${command}`);
78
+ printHelp();
79
+ process.exit(1);
80
+ }
@@ -1,119 +1,119 @@
1
- /**
2
- * Example: AI Agent using WebDriver BiDi Protocol via WAB
3
- *
4
- * This agent connects to a website using the __wab_bidi interface,
5
- * which follows WebDriver BiDi conventions for standardized communication.
6
- *
7
- * Prerequisites:
8
- * npm install puppeteer
9
- *
10
- * Usage:
11
- * node examples/bidi-agent.js <url>
12
- */
13
-
14
- const puppeteer = require('puppeteer');
15
-
16
- const TARGET_URL = process.argv[2] || 'http://localhost:3000';
17
-
18
- let commandId = 0;
19
-
20
- function bidiCommand(method, params = {}) {
21
- return { id: ++commandId, method, params };
22
- }
23
-
24
- async function main() {
25
- console.log(`\n🔗 WAB BiDi Agent`);
26
- console.log(` Target: ${TARGET_URL}\n`);
27
-
28
- const browser = await puppeteer.launch({ headless: true });
29
- const page = await browser.newPage();
30
-
31
- await page.goto(TARGET_URL, { waitUntil: 'networkidle2' });
32
- console.log(`✓ Page loaded: ${await page.title()}`);
33
-
34
- // Check for BiDi interface
35
- const hasBiDi = await page.evaluate(() => {
36
- return typeof window.__wab_bidi !== 'undefined' && typeof window.__wab_bidi.send === 'function';
37
- });
38
-
39
- if (!hasBiDi) {
40
- console.log('✗ WAB BiDi interface not found on this page.');
41
- await browser.close();
42
- return;
43
- }
44
-
45
- console.log('✓ WAB BiDi interface detected\n');
46
-
47
- // Step 1: Get BiDi context
48
- const context = await page.evaluate(() => window.__wab_bidi.getContext());
49
- console.log('📋 BiDi Context:');
50
- console.log(` URL: ${context.context.url}`);
51
- console.log(` Title: ${context.context.title}`);
52
- console.log(` Version: ${context.version}`);
53
- console.log(` Tier: ${context.capabilities.tier}`);
54
- console.log(` Capabilities: ${context.capabilities.actions.length} actions\n`);
55
-
56
- // Step 2: Get actions via BiDi command
57
- const actionsResult = await page.evaluate((cmd) => {
58
- return window.__wab_bidi.send(cmd);
59
- }, bidiCommand('wab.getActions'));
60
-
61
- console.log(`🔍 Actions (via BiDi):`);
62
- if (actionsResult.result) {
63
- actionsResult.result.forEach((action) => {
64
- console.log(` • ${action.name} [${action.trigger}] — ${action.description}`);
65
- });
66
- }
67
-
68
- // Step 3: Get page info via BiDi
69
- const infoResult = await page.evaluate((cmd) => {
70
- return window.__wab_bidi.send(cmd);
71
- }, bidiCommand('wab.getPageInfo'));
72
-
73
- console.log('\n📄 Page Info (via BiDi):');
74
- if (infoResult.result) {
75
- console.log(` Title: ${infoResult.result.title}`);
76
- console.log(` Domain: ${infoResult.result.domain}`);
77
- console.log(` Bridge: v${infoResult.result.bridgeVersion}`);
78
- }
79
-
80
- // Step 4: Read content via BiDi command
81
- const readResult = await page.evaluate((cmd) => {
82
- return window.__wab_bidi.send(cmd);
83
- }, bidiCommand('wab.readContent', { selector: 'h1' }));
84
-
85
- if (readResult.result && readResult.result.success) {
86
- console.log(`\n📖 Content: "${readResult.result.text}"`);
87
- }
88
-
89
- // Step 5: Execute an action via BiDi
90
- const actions = actionsResult.result || [];
91
- const firstAction = actions.find((a) => a.trigger === 'click');
92
- if (firstAction) {
93
- console.log(`\n▶ Executing via BiDi: "${firstAction.name}"`);
94
- const execResult = await page.evaluate((cmd) => {
95
- return window.__wab_bidi.send(cmd);
96
- }, bidiCommand('wab.executeAction', { name: firstAction.name }));
97
-
98
- const r = execResult.result;
99
- console.log(` Result: ${r && r.success ? '✓ Success' : '✗ ' + (r?.error || 'Unknown error')}`);
100
- }
101
-
102
- // Step 6: Test error handling
103
- console.log('\n🧪 Testing error handling:');
104
- const errorResult = await page.evaluate((cmd) => {
105
- return window.__wab_bidi.send(cmd);
106
- }, bidiCommand('wab.unknownMethod'));
107
-
108
- if (errorResult.error) {
109
- console.log(` ✓ Unknown command handled: ${errorResult.error.code} — ${errorResult.error.message}`);
110
- }
111
-
112
- console.log('\n✓ BiDi agent session complete.');
113
- await browser.close();
114
- }
115
-
116
- main().catch((err) => {
117
- console.error('Agent error:', err.message);
118
- process.exit(1);
119
- });
1
+ /**
2
+ * Example: AI Agent using WebDriver BiDi Protocol via WAB
3
+ *
4
+ * This agent connects to a website using the __wab_bidi interface,
5
+ * which follows WebDriver BiDi conventions for standardized communication.
6
+ *
7
+ * Prerequisites:
8
+ * npm install puppeteer
9
+ *
10
+ * Usage:
11
+ * node examples/bidi-agent.js <url>
12
+ */
13
+
14
+ const puppeteer = require('puppeteer');
15
+
16
+ const TARGET_URL = process.argv[2] || 'http://localhost:3000';
17
+
18
+ let commandId = 0;
19
+
20
+ function bidiCommand(method, params = {}) {
21
+ return { id: ++commandId, method, params };
22
+ }
23
+
24
+ async function main() {
25
+ console.log(`\n🔗 WAB BiDi Agent`);
26
+ console.log(` Target: ${TARGET_URL}\n`);
27
+
28
+ const browser = await puppeteer.launch({ headless: true });
29
+ const page = await browser.newPage();
30
+
31
+ await page.goto(TARGET_URL, { waitUntil: 'networkidle2' });
32
+ console.log(`✓ Page loaded: ${await page.title()}`);
33
+
34
+ // Check for BiDi interface
35
+ const hasBiDi = await page.evaluate(() => {
36
+ return typeof window.__wab_bidi !== 'undefined' && typeof window.__wab_bidi.send === 'function';
37
+ });
38
+
39
+ if (!hasBiDi) {
40
+ console.log('✗ WAB BiDi interface not found on this page.');
41
+ await browser.close();
42
+ return;
43
+ }
44
+
45
+ console.log('✓ WAB BiDi interface detected\n');
46
+
47
+ // Step 1: Get BiDi context
48
+ const context = await page.evaluate(() => window.__wab_bidi.getContext());
49
+ console.log('📋 BiDi Context:');
50
+ console.log(` URL: ${context.context.url}`);
51
+ console.log(` Title: ${context.context.title}`);
52
+ console.log(` Version: ${context.version}`);
53
+ console.log(` Tier: ${context.capabilities.tier}`);
54
+ console.log(` Capabilities: ${context.capabilities.actions.length} actions\n`);
55
+
56
+ // Step 2: Get actions via BiDi command
57
+ const actionsResult = await page.evaluate((cmd) => {
58
+ return window.__wab_bidi.send(cmd);
59
+ }, bidiCommand('wab.getActions'));
60
+
61
+ console.log(`🔍 Actions (via BiDi):`);
62
+ if (actionsResult.result) {
63
+ actionsResult.result.forEach((action) => {
64
+ console.log(` • ${action.name} [${action.trigger}] — ${action.description}`);
65
+ });
66
+ }
67
+
68
+ // Step 3: Get page info via BiDi
69
+ const infoResult = await page.evaluate((cmd) => {
70
+ return window.__wab_bidi.send(cmd);
71
+ }, bidiCommand('wab.getPageInfo'));
72
+
73
+ console.log('\n📄 Page Info (via BiDi):');
74
+ if (infoResult.result) {
75
+ console.log(` Title: ${infoResult.result.title}`);
76
+ console.log(` Domain: ${infoResult.result.domain}`);
77
+ console.log(` Bridge: v${infoResult.result.bridgeVersion}`);
78
+ }
79
+
80
+ // Step 4: Read content via BiDi command
81
+ const readResult = await page.evaluate((cmd) => {
82
+ return window.__wab_bidi.send(cmd);
83
+ }, bidiCommand('wab.readContent', { selector: 'h1' }));
84
+
85
+ if (readResult.result && readResult.result.success) {
86
+ console.log(`\n📖 Content: "${readResult.result.text}"`);
87
+ }
88
+
89
+ // Step 5: Execute an action via BiDi
90
+ const actions = actionsResult.result || [];
91
+ const firstAction = actions.find((a) => a.trigger === 'click');
92
+ if (firstAction) {
93
+ console.log(`\n▶ Executing via BiDi: "${firstAction.name}"`);
94
+ const execResult = await page.evaluate((cmd) => {
95
+ return window.__wab_bidi.send(cmd);
96
+ }, bidiCommand('wab.executeAction', { name: firstAction.name }));
97
+
98
+ const r = execResult.result;
99
+ console.log(` Result: ${r && r.success ? '✓ Success' : '✗ ' + (r?.error || 'Unknown error')}`);
100
+ }
101
+
102
+ // Step 6: Test error handling
103
+ console.log('\n🧪 Testing error handling:');
104
+ const errorResult = await page.evaluate((cmd) => {
105
+ return window.__wab_bidi.send(cmd);
106
+ }, bidiCommand('wab.unknownMethod'));
107
+
108
+ if (errorResult.error) {
109
+ console.log(` ✓ Unknown command handled: ${errorResult.error.code} — ${errorResult.error.message}`);
110
+ }
111
+
112
+ console.log('\n✓ BiDi agent session complete.');
113
+ await browser.close();
114
+ }
115
+
116
+ main().catch((err) => {
117
+ console.error('Agent error:', err.message);
118
+ process.exit(1);
119
+ });
@@ -1,94 +1,94 @@
1
- /**
2
- * Example: Using WAB sites via the MCP adapter
3
- *
4
- * The WAB-MCP adapter exposes every WAB site action as an MCP tool,
5
- * so any MCP-compatible AI agent (Claude, GPT, etc.) can interact
6
- * with WAB-enabled websites through a uniform tool interface.
7
- *
8
- * Usage:
9
- * node examples/mcp-agent.js <site-url>
10
- */
11
-
12
- const { WABMCPAdapter } = require('../wab-mcp-adapter');
13
-
14
- const TARGET = process.argv[2] || 'http://localhost:3000';
15
-
16
- async function main() {
17
- console.log('\n WAB → MCP Adapter Demo');
18
- console.log(` Target: ${TARGET}\n`);
19
-
20
- const adapter = new WABMCPAdapter({
21
- siteUrl: TARGET,
22
- transport: 'http'
23
- });
24
-
25
- // Step 1: Discover site capabilities
26
- console.log('1. Discovering WAB capabilities...');
27
- const discovery = await adapter.discover();
28
- if (discovery) {
29
- console.log(` Provider: ${discovery.provider?.name || 'unknown'}`);
30
- console.log(` Domain: ${discovery.provider?.domain || 'unknown'}`);
31
- console.log(` Tier: ${discovery.capabilities?.tier || 'free'}`);
32
- console.log(` Features: ${(discovery.capabilities?.features || []).join(', ')}`);
33
- if (discovery.fairness) {
34
- console.log(` Fairness: score=${discovery.fairness.neutrality_score}, independent=${discovery.fairness.is_independent}`);
35
- }
36
- } else {
37
- console.log(' No discovery document found (site may not have WAB configured)');
38
- }
39
-
40
- // Step 2: List MCP tools
41
- console.log('\n2. Available MCP tools:');
42
- const tools = await adapter.getTools();
43
- tools.forEach(tool => {
44
- const params = tool.input_schema?.properties
45
- ? Object.keys(tool.input_schema.properties).join(', ')
46
- : 'none';
47
- console.log(` - ${tool.name}: ${tool.description} (params: ${params})`);
48
- });
49
-
50
- // Step 3: Execute built-in tools
51
- console.log('\n3. Executing wab_get_page_info...');
52
- try {
53
- const infoResult = await adapter.executeTool('wab_get_page_info', {});
54
- const info = infoResult.content;
55
- if (infoResult.is_error) {
56
- console.log(` Error: ${info.error}`);
57
- } else {
58
- console.log(` Title: ${info.title || 'N/A'}`);
59
- console.log(` Version: ${info.bridgeVersion || 'N/A'}`);
60
- console.log(` Domain: ${info.domain || 'N/A'}`);
61
- }
62
- } catch (err) {
63
- console.log(` Error: ${err.message}`);
64
- }
65
-
66
- // Step 4: Search the fairness registry
67
- console.log('\n4. Fairness-weighted search (demo):');
68
- try {
69
- const searchResult = await adapter.executeTool('wab_fairness_search', {
70
- query: 'e-commerce',
71
- limit: 5
72
- });
73
- const search = searchResult.content;
74
- if (searchResult.is_error) {
75
- console.log(` Error: ${search.error}`);
76
- } else if (search.results?.length) {
77
- search.results.forEach(r => {
78
- console.log(` - ${r.name} (${r.domain}) — score: ${r.final_score}`);
79
- });
80
- } else {
81
- console.log(' No sites registered in directory yet.');
82
- }
83
- } catch (err) {
84
- console.log(` Registry not available: ${err.message}`);
85
- }
86
-
87
- console.log('\nDone. In a real MCP integration, these tools would be');
88
- console.log('exposed to Claude/GPT via the MCP tool-use protocol.\n');
89
- }
90
-
91
- main().catch(err => {
92
- console.error('Error:', err.message);
93
- process.exit(1);
94
- });
1
+ /**
2
+ * Example: Using WAB sites via the MCP adapter
3
+ *
4
+ * The WAB-MCP adapter exposes every WAB site action as an MCP tool,
5
+ * so any MCP-compatible AI agent (Claude, GPT, etc.) can interact
6
+ * with WAB-enabled websites through a uniform tool interface.
7
+ *
8
+ * Usage:
9
+ * node examples/mcp-agent.js <site-url>
10
+ */
11
+
12
+ const { WABMCPAdapter } = require('../wab-mcp-adapter');
13
+
14
+ const TARGET = process.argv[2] || 'http://localhost:3000';
15
+
16
+ async function main() {
17
+ console.log('\n WAB → MCP Adapter Demo');
18
+ console.log(` Target: ${TARGET}\n`);
19
+
20
+ const adapter = new WABMCPAdapter({
21
+ siteUrl: TARGET,
22
+ transport: 'http'
23
+ });
24
+
25
+ // Step 1: Discover site capabilities
26
+ console.log('1. Discovering WAB capabilities...');
27
+ const discovery = await adapter.discover();
28
+ if (discovery) {
29
+ console.log(` Provider: ${discovery.provider?.name || 'unknown'}`);
30
+ console.log(` Domain: ${discovery.provider?.domain || 'unknown'}`);
31
+ console.log(` Tier: ${discovery.capabilities?.tier || 'free'}`);
32
+ console.log(` Features: ${(discovery.capabilities?.features || []).join(', ')}`);
33
+ if (discovery.fairness) {
34
+ console.log(` Fairness: score=${discovery.fairness.neutrality_score}, independent=${discovery.fairness.is_independent}`);
35
+ }
36
+ } else {
37
+ console.log(' No discovery document found (site may not have WAB configured)');
38
+ }
39
+
40
+ // Step 2: List MCP tools
41
+ console.log('\n2. Available MCP tools:');
42
+ const tools = await adapter.getTools();
43
+ tools.forEach(tool => {
44
+ const params = tool.input_schema?.properties
45
+ ? Object.keys(tool.input_schema.properties).join(', ')
46
+ : 'none';
47
+ console.log(` - ${tool.name}: ${tool.description} (params: ${params})`);
48
+ });
49
+
50
+ // Step 3: Execute built-in tools
51
+ console.log('\n3. Executing wab_get_page_info...');
52
+ try {
53
+ const infoResult = await adapter.executeTool('wab_get_page_info', {});
54
+ const info = infoResult.content;
55
+ if (infoResult.is_error) {
56
+ console.log(` Error: ${info.error}`);
57
+ } else {
58
+ console.log(` Title: ${info.title || 'N/A'}`);
59
+ console.log(` Version: ${info.bridgeVersion || 'N/A'}`);
60
+ console.log(` Domain: ${info.domain || 'N/A'}`);
61
+ }
62
+ } catch (err) {
63
+ console.log(` Error: ${err.message}`);
64
+ }
65
+
66
+ // Step 4: Search the fairness registry
67
+ console.log('\n4. Fairness-weighted search (demo):');
68
+ try {
69
+ const searchResult = await adapter.executeTool('wab_fairness_search', {
70
+ query: 'e-commerce',
71
+ limit: 5
72
+ });
73
+ const search = searchResult.content;
74
+ if (searchResult.is_error) {
75
+ console.log(` Error: ${search.error}`);
76
+ } else if (search.results?.length) {
77
+ search.results.forEach(r => {
78
+ console.log(` - ${r.name} (${r.domain}) — score: ${r.final_score}`);
79
+ });
80
+ } else {
81
+ console.log(' No sites registered in directory yet.');
82
+ }
83
+ } catch (err) {
84
+ console.log(` Registry not available: ${err.message}`);
85
+ }
86
+
87
+ console.log('\nDone. In a real MCP integration, these tools would be');
88
+ console.log('exposed to Claude/GPT via the MCP tool-use protocol.\n');
89
+ }
90
+
91
+ main().catch(err => {
92
+ console.error('Error:', err.message);
93
+ process.exit(1);
94
+ });
@@ -0,0 +1,44 @@
1
+ # Next.js App Router + WAB
2
+
3
+ 1. Install the React helpers (from repo root after publish, or `file:` link):
4
+
5
+ ```bash
6
+ npm install @web-agent-bridge/react
7
+ ```
8
+
9
+ 2. Add a client component `components/WabShop.tsx`:
10
+
11
+ ```tsx
12
+ 'use client';
13
+
14
+ import { WABProvider, useWAB } from '@web-agent-bridge/react';
15
+ import { useEffect } from 'react';
16
+
17
+ function WabInner() {
18
+ const { ready, discover, execute } = useWAB({
19
+ name: 'My App',
20
+ actions: {
21
+ ping: { description: 'Health check', run: () => ({ ok: true }) },
22
+ },
23
+ });
24
+
25
+ useEffect(() => {
26
+ if (!ready) return;
27
+ discover().then(console.log);
28
+ }, [ready, discover]);
29
+
30
+ return <p>WAB {ready ? 'ready' : 'loading…'}</p>;
31
+ }
32
+
33
+ export default function WabShop() {
34
+ return (
35
+ <WABProvider scriptSrc="https://webagentbridge.com/script/wab.min.js">
36
+ <WabInner />
37
+ </WABProvider>
38
+ );
39
+ }
40
+ ```
41
+
42
+ 3. Import `WabShop` from any `app/.../page.tsx` (server component can import client components).
43
+
44
+ Use `next/script` with `strategy="beforeInteractive"` if you prefer loading `wab.min.js` in `layout.tsx` instead of `WABProvider`.