kompass-sdk 0.13.0 → 0.15.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 (58) hide show
  1. package/dist/cli.js +0 -0
  2. package/dist/matching.d.ts.map +1 -1
  3. package/dist/matching.js +8 -0
  4. package/dist/matching.js.map +1 -1
  5. package/dist/sources/acp.js +1 -1
  6. package/dist/sources/acp.js.map +1 -1
  7. package/dist/sources/bankr.d.ts +8 -0
  8. package/dist/sources/bankr.d.ts.map +1 -0
  9. package/dist/sources/bankr.js +79 -0
  10. package/dist/sources/bankr.js.map +1 -0
  11. package/dist/sources/index.d.ts.map +1 -1
  12. package/dist/sources/index.js +4 -0
  13. package/dist/sources/index.js.map +1 -1
  14. package/dist/sources/locus.d.ts +12 -0
  15. package/dist/sources/locus.d.ts.map +1 -0
  16. package/dist/sources/locus.js +134 -0
  17. package/dist/sources/locus.js.map +1 -0
  18. package/dist/sources/mcp-registry.d.ts +2 -2
  19. package/dist/sources/mcp-registry.d.ts.map +1 -1
  20. package/dist/sources/mcp-registry.js +89 -81
  21. package/dist/sources/mcp-registry.js.map +1 -1
  22. package/dist/sources/openserv.d.ts +8 -0
  23. package/dist/sources/openserv.d.ts.map +1 -0
  24. package/dist/sources/openserv.js +76 -0
  25. package/dist/sources/openserv.js.map +1 -0
  26. package/dist/sources/types.d.ts +1 -1
  27. package/dist/sources/types.d.ts.map +1 -1
  28. package/dist/wallet/bridge.d.ts +1 -0
  29. package/dist/wallet/bridge.d.ts.map +1 -1
  30. package/dist/wallet/bridge.js +31 -5
  31. package/dist/wallet/bridge.js.map +1 -1
  32. package/dist/wallet/handlers/acp.d.ts.map +1 -1
  33. package/dist/wallet/handlers/acp.js +59 -3
  34. package/dist/wallet/handlers/acp.js.map +1 -1
  35. package/dist/wallet/handlers/bankr.d.ts +13 -0
  36. package/dist/wallet/handlers/bankr.d.ts.map +1 -0
  37. package/dist/wallet/handlers/bankr.js +88 -0
  38. package/dist/wallet/handlers/bankr.js.map +1 -0
  39. package/dist/wallet/handlers/locus.d.ts +21 -0
  40. package/dist/wallet/handlers/locus.d.ts.map +1 -0
  41. package/dist/wallet/handlers/locus.js +144 -0
  42. package/dist/wallet/handlers/locus.js.map +1 -0
  43. package/dist/wallet/payment-router.d.ts.map +1 -1
  44. package/dist/wallet/payment-router.js +12 -0
  45. package/dist/wallet/payment-router.js.map +1 -1
  46. package/package.json +1 -1
  47. package/src/matching.ts +9 -0
  48. package/src/sources/acp.ts +1 -1
  49. package/src/sources/bankr.ts +87 -0
  50. package/src/sources/index.ts +4 -0
  51. package/src/sources/locus.ts +156 -0
  52. package/src/sources/mcp-registry.ts +108 -99
  53. package/src/sources/types.ts +3 -1
  54. package/src/wallet/bridge.ts +33 -6
  55. package/src/wallet/handlers/acp.ts +69 -3
  56. package/src/wallet/handlers/bankr.ts +108 -0
  57. package/src/wallet/handlers/locus.ts +170 -0
  58. package/src/wallet/payment-router.ts +14 -0
@@ -0,0 +1,144 @@
1
+ /**
2
+ * Locus Payment Handler
3
+ * Calls Locus wrapped APIs — pay-per-use via USDC on Base.
4
+ * No upstream API keys needed — Locus proxies the call and charges the wallet.
5
+ *
6
+ * Flow:
7
+ * 1. Get or create Locus API key (self-register if needed)
8
+ * 2. Wait for wallet deployment
9
+ * 3. Call the wrapped API endpoint
10
+ * 4. Locus charges USDC from wallet, returns response
11
+ *
12
+ * Docs: https://beta.paywithlocus.com/skill.md
13
+ */
14
+ const LOCUS_API = "https://beta-api.paywithlocus.com/api";
15
+ export async function handleLocusPayment(wallet, agent, task) {
16
+ let apiKey = process.env.LOCUS_API_KEY;
17
+ try {
18
+ // Step 1: Self-register if no API key
19
+ if (!apiKey) {
20
+ const walletAddress = wallet.getAddress();
21
+ const registerRes = await fetch(`${LOCUS_API}/register`, {
22
+ method: "POST",
23
+ headers: { "Content-Type": "application/json" },
24
+ body: JSON.stringify({
25
+ wallet_address: walletAddress,
26
+ agent_name: "kompass-agent",
27
+ }),
28
+ signal: AbortSignal.timeout(15000),
29
+ });
30
+ if (!registerRes.ok) {
31
+ const errBody = await registerRes.text().catch(() => "");
32
+ return {
33
+ success: false,
34
+ deliverable: {
35
+ error: `Locus registration failed: ${registerRes.status}`,
36
+ details: errBody,
37
+ hint: "Set LOCUS_API_KEY env var or fund a Locus wallet at paywithlocus.com",
38
+ },
39
+ };
40
+ }
41
+ const registerData = await registerRes.json();
42
+ apiKey = registerData.data?.apiKey;
43
+ if (!apiKey) {
44
+ return {
45
+ success: false,
46
+ deliverable: { error: "Locus registration did not return an API key" },
47
+ };
48
+ }
49
+ // Wait for wallet deployment
50
+ for (let i = 0; i < 10; i++) {
51
+ const statusRes = await fetch(`${LOCUS_API}/status`, {
52
+ headers: { "Authorization": `Bearer ${apiKey}` },
53
+ signal: AbortSignal.timeout(5000),
54
+ }).catch(() => null);
55
+ if (statusRes?.ok) {
56
+ const statusData = await statusRes.json();
57
+ if (statusData.data?.walletStatus === "deployed")
58
+ break;
59
+ }
60
+ await new Promise((r) => setTimeout(r, 3000));
61
+ }
62
+ }
63
+ const headers = {
64
+ "Content-Type": "application/json",
65
+ "Authorization": `Bearer ${apiKey}`,
66
+ };
67
+ // Step 2: Determine if this is a wrapped API call or a direct payment
68
+ const rawData = agent.raw;
69
+ const isWrappedApi = rawData?.type === "locus-wrapped-api";
70
+ if (isWrappedApi) {
71
+ // Call the wrapped API directly
72
+ // The endpoint URL is like: /api/wrapped/{provider}/{endpoint}
73
+ // We need to figure out the best endpoint for the task
74
+ const provider = rawData.provider;
75
+ const availableEndpoints = rawData.endpoints || [];
76
+ // Pick the first/most relevant endpoint
77
+ // For now use the first endpoint — the provider slug is already in the URL
78
+ const endpoint = availableEndpoints[0]?.toLowerCase().replace(/\s+/g, "-") || "search";
79
+ const callUrl = `${LOCUS_API}/wrapped/${provider}/${endpoint}`;
80
+ const callRes = await fetch(callUrl, {
81
+ method: "POST",
82
+ headers,
83
+ body: JSON.stringify({ query: task, prompt: task, q: task }),
84
+ signal: AbortSignal.timeout(30000),
85
+ });
86
+ if (!callRes.ok) {
87
+ const errBody = await callRes.text().catch(() => "");
88
+ return {
89
+ success: false,
90
+ deliverable: {
91
+ error: `Locus wrapped API call failed: ${callRes.status}`,
92
+ provider,
93
+ endpoint,
94
+ details: errBody,
95
+ },
96
+ };
97
+ }
98
+ const result = await callRes.json();
99
+ return {
100
+ success: true,
101
+ deliverable: result,
102
+ };
103
+ }
104
+ // Step 3: Direct USDC payment to agent address
105
+ const toAddress = agent.endpoints.acp?.walletAddress ?? agent.endpoints.http;
106
+ const amount = agent.pricing?.amount ?? "0.01";
107
+ if (!toAddress || !toAddress.startsWith("0x")) {
108
+ return {
109
+ success: false,
110
+ deliverable: { error: "No valid target address for Locus payment" },
111
+ };
112
+ }
113
+ const sendRes = await fetch(`${LOCUS_API}/pay/send`, {
114
+ method: "POST",
115
+ headers,
116
+ body: JSON.stringify({
117
+ to_address: toAddress,
118
+ amount: parseFloat(amount),
119
+ memo: `Kompass task: ${task.slice(0, 100)}`,
120
+ }),
121
+ signal: AbortSignal.timeout(30000),
122
+ });
123
+ if (!sendRes.ok) {
124
+ const errBody = await sendRes.text().catch(() => "");
125
+ return {
126
+ success: false,
127
+ deliverable: { error: `Locus payment failed: ${sendRes.status}`, details: errBody },
128
+ };
129
+ }
130
+ const sendData = await sendRes.json();
131
+ return {
132
+ success: true,
133
+ deliverable: sendData,
134
+ txHash: sendData.data?.tx_hash ?? sendData.data?.transaction_id,
135
+ };
136
+ }
137
+ catch (err) {
138
+ return {
139
+ success: false,
140
+ deliverable: { error: err instanceof Error ? err.message : String(err) },
141
+ };
142
+ }
143
+ }
144
+ //# sourceMappingURL=locus.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"locus.js","sourceRoot":"","sources":["../../../src/wallet/handlers/locus.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"payment-router.d.ts","sourceRoot":"","sources":["../../src/wallet/payment-router.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,KAAK,EAAE,YAAY,EAAiB,MAAM,qBAAqB,CAAC;AASvE,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,YAAY,CAChC,MAAM,EAAE,aAAa,EACrB,KAAK,EAAE,YAAY,EACnB,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,GAC7C,OAAO,CAAC,aAAa,CAAC,CAkFxB"}
1
+ {"version":3,"file":"payment-router.d.ts","sourceRoot":"","sources":["../../src/wallet/payment-router.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAChD,OAAO,KAAK,EAAE,YAAY,EAAiB,MAAM,qBAAqB,CAAC;AAWvE,MAAM,WAAW,aAAa;IAC5B,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAsB,YAAY,CAChC,MAAM,EAAE,aAAa,EACrB,KAAK,EAAE,YAAY,EACnB,IAAI,EAAE,MAAM,EACZ,OAAO,CAAC,EAAE;IAAE,MAAM,CAAC,EAAE,MAAM,CAAC;IAAC,MAAM,CAAC,EAAE,MAAM,CAAA;CAAE,GAC7C,OAAO,CAAC,aAAa,CAAC,CA4FxB"}
@@ -8,6 +8,8 @@ import { handleL402Payment } from "./handlers/l402.js";
8
8
  import { handleMPPPayment } from "./handlers/mpp.js";
9
9
  import { handleNanopayment } from "./handlers/nanopayments.js";
10
10
  import { handleFreePayment } from "./handlers/free.js";
11
+ import { handleBankrPayment } from "./handlers/bankr.js";
12
+ import { handleLocusPayment } from "./handlers/locus.js";
11
13
  import { ensureSufficientBalance } from "./bridge.js";
12
14
  export async function routePayment(wallet, agent, task, options) {
13
15
  const protocol = determinePaymentProtocol(agent);
@@ -47,6 +49,14 @@ export async function routePayment(wallet, agent, task, options) {
47
49
  const result = await handleNanopayment(wallet, agent, task);
48
50
  return { ...result, protocol: "circle-nanopayments", costUSDC: parseFloat(agent.pricing?.amount ?? "0") };
49
51
  }
52
+ case "bankr": {
53
+ const result = await handleBankrPayment(wallet, agent, task);
54
+ return { ...result, protocol: "bankr", costUSDC: parseFloat(agent.pricing?.amount ?? "0") };
55
+ }
56
+ case "locus": {
57
+ const result = await handleLocusPayment(wallet, agent, task);
58
+ return { ...result, protocol: "locus", costUSDC: parseFloat(agent.pricing?.amount ?? "0") };
59
+ }
50
60
  case "free":
51
61
  case "mcp": {
52
62
  // MCP servers and free tools — try to execute directly
@@ -106,6 +116,8 @@ function determinePaymentProtocol(agent) {
106
116
  case "l402-directory": return "l402";
107
117
  case "mcp-registry": return "free";
108
118
  case "skills-registry": return "free";
119
+ case "bankr": return "bankr";
120
+ case "locus": return "locus";
109
121
  default: return agent.protocol === "onchain" ? "acp" : "free";
110
122
  }
111
123
  }
@@ -1 +1 @@
1
- {"version":3,"file":"payment-router.js","sourceRoot":"","sources":["../../src/wallet/payment-router.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"payment-router.js","sourceRoot":"","sources":["../../src/wallet/payment-router.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "kompass-sdk",
3
- "version": "0.13.0",
3
+ "version": "0.15.0",
4
4
  "description": "Get any job done. Universal agent capability discovery + coordination across ACP, MCP, x402, A2A, skills, L402, and ERC-8004.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
package/src/matching.ts CHANGED
@@ -147,6 +147,15 @@ function multiCriteriaScore(agent: UnifiedAgent): number {
147
147
  const endpointCount = Object.values(agent.endpoints).filter(Boolean).length;
148
148
  score += endpointCount * 2;
149
149
 
150
+ // MCP servers with remote endpoints are directly callable — boost them
151
+ // They don't have reputation data so they'd otherwise rank too low
152
+ if (agent.protocol === "mcp" && agent.endpoints.mcp) {
153
+ score += 8; // Callable remote MCP server bonus
154
+ }
155
+
156
+ // Free tools get a small accessibility bonus (no wallet needed)
157
+ if (agent.pricing?.model === "free") score += 3;
158
+
150
159
  // Recency
151
160
  if (agent.lastSeen) {
152
161
  const hoursSince = (Date.now() - agent.lastSeen) / (1000 * 60 * 60);
@@ -49,7 +49,7 @@ function mapAcpAgent(agent: any): UnifiedAgent {
49
49
  name: agent.name ?? "Unknown ACP Agent",
50
50
  description: agent.description ?? offerings.map((o: any) => o.description).join(". ") ?? "",
51
51
  categories: extractAcpCategories(agent, offerings),
52
- capabilities: offerings.map((o: any) => `${o.name}: ${o.description ?? ""}`),
52
+ capabilities: offerings.map((o: any) => `${o.name}: ${o.description ?? ""}${o.requirement ? ` [expects: ${typeof o.requirement === 'object' ? Object.keys(o.requirement).join(', ') : o.requirement}]` : ""}`),
53
53
  source: "acp",
54
54
  protocol: "acp",
55
55
  endpoints: {
@@ -0,0 +1,87 @@
1
+ /**
2
+ * Bankr Source Adapter
3
+ * Searches Bankr LLM Gateway for trading/DeFi agent services
4
+ * API at https://api.bankr.bot
5
+ */
6
+
7
+ import type { SourceAdapter, UnifiedAgent, SourceSearchOptions } from "./types.js";
8
+
9
+ const BANKR_API = "https://api.bankr.bot";
10
+
11
+ export const bankrAdapter: SourceAdapter = {
12
+ name: "bankr",
13
+ displayName: "Bankr Trading Gateway",
14
+
15
+ async search(query: string, options?: SourceSearchOptions): Promise<UnifiedAgent[]> {
16
+ const limit = options?.limit ?? 20;
17
+ const timeout = options?.timeout ?? 10000;
18
+
19
+ try {
20
+ const apiKey = process.env.BANKR_API_KEY;
21
+ if (!apiKey) return [];
22
+
23
+ const headers: Record<string, string> = {
24
+ "Content-Type": "application/json",
25
+ "X-API-Key": apiKey,
26
+ };
27
+
28
+ const url = new URL(`${BANKR_API}/agents`);
29
+ if (query) url.searchParams.set("q", query);
30
+ url.searchParams.set("limit", String(limit));
31
+
32
+ const res = await fetch(url.toString(), {
33
+ headers,
34
+ signal: AbortSignal.timeout(timeout),
35
+ });
36
+
37
+ if (!res.ok) return [];
38
+
39
+ const data = await res.json();
40
+ const agents = data.agents ?? data.data ?? data.results ?? data;
41
+
42
+ if (!Array.isArray(agents)) return [];
43
+
44
+ return agents.slice(0, limit).map(mapBankrAgent);
45
+ } catch {
46
+ return [];
47
+ }
48
+ },
49
+
50
+ async ping(): Promise<boolean> {
51
+ try {
52
+ const res = await fetch(`${BANKR_API}/agent/prompt`, {
53
+ method: "POST",
54
+ headers: { "Content-Type": "application/json" },
55
+ body: JSON.stringify({ prompt: "ping" }),
56
+ signal: AbortSignal.timeout(5000),
57
+ });
58
+ // 401 means the API is alive, just needs auth
59
+ return res.status === 401 || res.ok;
60
+ } catch {
61
+ return false;
62
+ }
63
+ },
64
+ };
65
+
66
+ function mapBankrAgent(agent: any): UnifiedAgent {
67
+ return {
68
+ id: `bankr:${agent.id ?? agent.name ?? agent.slug}`,
69
+ nativeId: agent.id ?? agent.slug ?? "",
70
+ name: agent.name ?? "Bankr Agent",
71
+ description: agent.description ?? "",
72
+ categories: agent.categories ?? ["defi", "trading"],
73
+ capabilities: agent.capabilities ?? [agent.description ?? ""].filter(Boolean),
74
+ source: "bankr",
75
+ protocol: "http",
76
+ endpoints: {
77
+ http: agent.endpoint ?? `${BANKR_API}/agent/prompt`,
78
+ },
79
+ pricing: {
80
+ model: agent.pricing?.model ?? "per-call",
81
+ amount: agent.pricing?.amount ?? "0.01",
82
+ currency: agent.pricing?.currency ?? "USDC",
83
+ },
84
+ verified: agent.verified ?? true,
85
+ raw: agent,
86
+ };
87
+ }
@@ -14,6 +14,8 @@ import { a2aWellknownAdapter } from "./a2a-wellknown.js";
14
14
  import { l402DirectoryAdapter } from "./l402-directory.js";
15
15
  import { adpAdapter } from "./adp.js";
16
16
  import { skillsAdapter } from "./skills.js";
17
+ import { bankrAdapter } from "./bankr.js";
18
+ import { locusAdapter } from "./locus.js";
17
19
 
18
20
  export interface SourceRegistryConfig {
19
21
  /** Kompass SDK config (for kompass-registry adapter) */
@@ -34,6 +36,8 @@ export function createAllSources(config?: SourceRegistryConfig): SourceAdapter[]
34
36
  l402DirectoryAdapter,
35
37
  adpAdapter,
36
38
  skillsAdapter,
39
+ bankrAdapter,
40
+ locusAdapter,
37
41
  ];
38
42
 
39
43
  // Add Kompass registry if config provided
@@ -0,0 +1,156 @@
1
+ /**
2
+ * Locus Wrapped API Source Adapter
3
+ * Fetches Locus's live API catalog and indexes 50+ pay-per-use providers
4
+ * as discoverable capabilities. Each wrapped API becomes a searchable agent.
5
+ * Agents pay per-call via USDC on Base — no upstream API keys needed.
6
+ *
7
+ * Docs: https://beta.paywithlocus.com/skill.md
8
+ * Live index: https://beta.paywithlocus.com/wapi/index.md
9
+ */
10
+
11
+ import type { SourceAdapter, UnifiedAgent, SourceSearchOptions } from "./types.js";
12
+
13
+ const LOCUS_API = "https://beta-api.paywithlocus.com/api";
14
+ const WAPI_INDEX_URL = "https://beta.paywithlocus.com/wapi/index.md";
15
+
16
+ interface LocusProvider {
17
+ name: string;
18
+ slug: string;
19
+ category: string;
20
+ endpoints: string;
21
+ description: string;
22
+ }
23
+
24
+ // Cache fetched providers — refresh every 10 minutes
25
+ let providerCache: LocusProvider[] | null = null;
26
+ let cacheTime = 0;
27
+ const CACHE_TTL = 10 * 60 * 1000;
28
+
29
+ /**
30
+ * Parse the live markdown index from Locus into structured provider data.
31
+ * The index is a markdown table with columns: Provider, Category, Endpoints, Description
32
+ */
33
+ function parseMarkdownIndex(md: string): LocusProvider[] {
34
+ const providers: LocusProvider[] = [];
35
+ const lines = md.split("\n");
36
+
37
+ for (const line of lines) {
38
+ // Match table rows: | [Provider Name](url) | Category | Endpoints | Description |
39
+ const match = line.match(/^\| \[([^\]]+)\]\(https:\/\/[^)]*\/wapi\/([^.]+)\.md\)\s*\|\s*([^|]+)\|\s*([^|]+)\|\s*([^|]+)\|/);
40
+ if (match) {
41
+ providers.push({
42
+ name: match[1].trim(),
43
+ slug: match[2].trim(),
44
+ category: match[3].trim().toLowerCase(),
45
+ endpoints: match[4].trim(),
46
+ description: match[5].trim(),
47
+ });
48
+ }
49
+ }
50
+
51
+ return providers;
52
+ }
53
+
54
+ async function fetchProviders(timeout: number): Promise<LocusProvider[]> {
55
+ if (providerCache && Date.now() - cacheTime < CACHE_TTL) {
56
+ return providerCache;
57
+ }
58
+
59
+ try {
60
+ const res = await fetch(WAPI_INDEX_URL, {
61
+ signal: AbortSignal.timeout(timeout),
62
+ });
63
+
64
+ if (!res.ok) return providerCache ?? [];
65
+
66
+ const md = await res.text();
67
+ const parsed = parseMarkdownIndex(md);
68
+
69
+ if (parsed.length > 0) {
70
+ providerCache = parsed;
71
+ cacheTime = Date.now();
72
+ }
73
+
74
+ return providerCache ?? [];
75
+ } catch {
76
+ return providerCache ?? [];
77
+ }
78
+ }
79
+
80
+ export const locusAdapter: SourceAdapter = {
81
+ name: "locus" as any,
82
+ displayName: "Locus Wrapped APIs",
83
+
84
+ async search(query: string, options?: SourceSearchOptions): Promise<UnifiedAgent[]> {
85
+ const limit = options?.limit ?? 20;
86
+ const timeout = options?.timeout ?? 10000;
87
+ const lower = query.toLowerCase();
88
+ const terms = lower.split(/\s+/).filter(t => t.length > 2);
89
+
90
+ const providers = await fetchProviders(timeout);
91
+
92
+ // Score each provider by relevance
93
+ const scored = providers.map(provider => {
94
+ let score = 0;
95
+ const searchText = `${provider.name} ${provider.description} ${provider.category} ${provider.endpoints}`.toLowerCase();
96
+
97
+ for (const term of terms) {
98
+ if (provider.name.toLowerCase().includes(term)) score += 5;
99
+ if (provider.description.toLowerCase().includes(term)) score += 3;
100
+ if (provider.endpoints.toLowerCase().includes(term)) score += 2;
101
+ if (provider.category.includes(term)) score += 4;
102
+ if (searchText.includes(term)) score += 1;
103
+ }
104
+
105
+ return { provider, score };
106
+ })
107
+ .filter(s => s.score > 0)
108
+ .sort((a, b) => b.score - a.score)
109
+ .slice(0, limit);
110
+
111
+ return scored.map(s => mapLocusProvider(s.provider));
112
+ },
113
+
114
+ async ping(): Promise<boolean> {
115
+ try {
116
+ const res = await fetch(WAPI_INDEX_URL, {
117
+ signal: AbortSignal.timeout(5000),
118
+ });
119
+ return res.ok;
120
+ } catch {
121
+ return false;
122
+ }
123
+ },
124
+ };
125
+
126
+ function mapLocusProvider(provider: LocusProvider): UnifiedAgent {
127
+ const endpointList = provider.endpoints.split(",").map(e => e.trim()).slice(0, 5);
128
+
129
+ return {
130
+ id: `locus:${provider.slug}`,
131
+ nativeId: provider.slug,
132
+ name: `${provider.name} (via Locus)`,
133
+ description: `${provider.description} Pay-per-use via USDC — no API key needed.`,
134
+ categories: [provider.category.split(" / ")[0].toLowerCase(), "api", "pay-per-use"],
135
+ capabilities: endpointList.map(e => `${provider.name}: ${e}`),
136
+ source: "locus" as any,
137
+ protocol: "http",
138
+ endpoints: {
139
+ http: `${LOCUS_API}/wrapped/${provider.slug}`,
140
+ },
141
+ pricing: {
142
+ model: "per-call",
143
+ amount: "0.01",
144
+ currency: "USDC",
145
+ },
146
+ verified: true,
147
+ lastSeen: Date.now(),
148
+ raw: {
149
+ type: "locus-wrapped-api",
150
+ provider: provider.slug,
151
+ category: provider.category,
152
+ endpoints: endpointList,
153
+ allEndpoints: provider.endpoints,
154
+ },
155
+ };
156
+ }