@nordsym/apiclaw 1.7.3 → 1.7.5

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 (219) hide show
  1. package/convex/_generated/api.d.ts +115 -0
  2. package/convex/_generated/api.js +23 -0
  3. package/convex/_generated/dataModel.d.ts +60 -0
  4. package/convex/_generated/server.d.ts +143 -0
  5. package/convex/_generated/server.js +93 -0
  6. package/convex/adminActivate.d.ts +3 -0
  7. package/convex/adminActivate.d.ts.map +1 -0
  8. package/convex/adminActivate.js +47 -0
  9. package/convex/adminActivate.js.map +1 -0
  10. package/convex/adminActivate.ts +54 -0
  11. package/convex/adminStats.d.ts +3 -0
  12. package/convex/adminStats.d.ts.map +1 -0
  13. package/convex/adminStats.js +42 -0
  14. package/convex/adminStats.js.map +1 -0
  15. package/convex/adminStats.ts +44 -0
  16. package/convex/agents.d.ts +76 -0
  17. package/convex/agents.d.ts.map +1 -0
  18. package/convex/agents.js +699 -0
  19. package/convex/agents.js.map +1 -0
  20. package/convex/agents.ts +814 -0
  21. package/convex/analytics.d.ts +5 -0
  22. package/convex/analytics.d.ts.map +1 -0
  23. package/convex/analytics.js +166 -0
  24. package/convex/analytics.js.map +1 -0
  25. package/convex/analytics.ts +186 -0
  26. package/convex/billing.d.ts +88 -0
  27. package/convex/billing.d.ts.map +1 -0
  28. package/convex/billing.js +655 -0
  29. package/convex/billing.js.map +1 -0
  30. package/convex/billing.ts +791 -0
  31. package/convex/capabilities.d.ts +9 -0
  32. package/convex/capabilities.d.ts.map +1 -0
  33. package/convex/capabilities.js +145 -0
  34. package/convex/capabilities.js.map +1 -0
  35. package/convex/capabilities.ts +157 -0
  36. package/convex/chains.d.ts +68 -0
  37. package/convex/chains.d.ts.map +1 -0
  38. package/convex/chains.js +1105 -0
  39. package/convex/chains.js.map +1 -0
  40. package/convex/chains.ts +1318 -0
  41. package/convex/credits.d.ts +25 -0
  42. package/convex/credits.d.ts.map +1 -0
  43. package/convex/credits.js +186 -0
  44. package/convex/credits.js.map +1 -0
  45. package/convex/credits.ts +211 -0
  46. package/convex/crons.d.ts +3 -0
  47. package/convex/crons.d.ts.map +1 -0
  48. package/convex/crons.js +17 -0
  49. package/convex/crons.js.map +1 -0
  50. package/convex/crons.ts +28 -0
  51. package/convex/directCall.d.ts +72 -0
  52. package/convex/directCall.d.ts.map +1 -0
  53. package/convex/directCall.js +627 -0
  54. package/convex/directCall.js.map +1 -0
  55. package/convex/directCall.ts +678 -0
  56. package/convex/earnProgress.d.ts +58 -0
  57. package/convex/earnProgress.d.ts.map +1 -0
  58. package/convex/earnProgress.js +649 -0
  59. package/convex/earnProgress.js.map +1 -0
  60. package/convex/earnProgress.ts +753 -0
  61. package/convex/email.d.ts +14 -0
  62. package/convex/email.d.ts.map +1 -0
  63. package/convex/email.js +300 -0
  64. package/convex/email.js.map +1 -0
  65. package/convex/email.ts +329 -0
  66. package/convex/feedback.d.ts +7 -0
  67. package/convex/feedback.d.ts.map +1 -0
  68. package/convex/feedback.js +227 -0
  69. package/convex/feedback.js.map +1 -0
  70. package/convex/feedback.ts +265 -0
  71. package/convex/http.d.ts +3 -0
  72. package/convex/http.d.ts.map +1 -0
  73. package/convex/http.js +1405 -0
  74. package/convex/http.js.map +1 -0
  75. package/convex/http.ts +1577 -0
  76. package/convex/inbound.d.ts +2 -0
  77. package/convex/inbound.d.ts.map +1 -0
  78. package/convex/inbound.js +32 -0
  79. package/convex/inbound.js.map +1 -0
  80. package/convex/inbound.ts +32 -0
  81. package/convex/logs.d.ts +48 -0
  82. package/convex/logs.d.ts.map +1 -0
  83. package/convex/logs.js +592 -0
  84. package/convex/logs.js.map +1 -0
  85. package/convex/logs.ts +662 -0
  86. package/convex/mou.d.ts +6 -0
  87. package/convex/mou.d.ts.map +1 -0
  88. package/convex/mou.js +82 -0
  89. package/convex/mou.js.map +1 -0
  90. package/convex/mou.ts +91 -0
  91. package/convex/providerKeys.d.ts +31 -0
  92. package/convex/providerKeys.d.ts.map +1 -0
  93. package/convex/providerKeys.js +257 -0
  94. package/convex/providerKeys.js.map +1 -0
  95. package/convex/providerKeys.ts +289 -0
  96. package/convex/providers.d.ts +32 -0
  97. package/convex/providers.d.ts.map +1 -0
  98. package/convex/providers.js +814 -0
  99. package/convex/providers.js.map +1 -0
  100. package/convex/providers.ts +909 -0
  101. package/convex/purchases.d.ts +7 -0
  102. package/convex/purchases.d.ts.map +1 -0
  103. package/convex/purchases.js +157 -0
  104. package/convex/purchases.js.map +1 -0
  105. package/convex/purchases.ts +183 -0
  106. package/convex/ratelimit.d.ts +4 -0
  107. package/convex/ratelimit.d.ts.map +1 -0
  108. package/convex/ratelimit.js +91 -0
  109. package/convex/ratelimit.js.map +1 -0
  110. package/convex/ratelimit.ts +104 -0
  111. package/convex/schema.ts +805 -0
  112. package/convex/searchLogs.d.ts +4 -0
  113. package/convex/searchLogs.d.ts.map +1 -0
  114. package/convex/searchLogs.js +129 -0
  115. package/convex/searchLogs.js.map +1 -0
  116. package/convex/searchLogs.ts +146 -0
  117. package/convex/seedAPILayerAPIs.d.ts +7 -0
  118. package/convex/seedAPILayerAPIs.d.ts.map +1 -0
  119. package/convex/seedAPILayerAPIs.js +177 -0
  120. package/convex/seedAPILayerAPIs.js.map +1 -0
  121. package/convex/seedAPILayerAPIs.ts +191 -0
  122. package/convex/seedDirectCallConfigs.d.ts +2 -0
  123. package/convex/seedDirectCallConfigs.d.ts.map +1 -0
  124. package/convex/seedDirectCallConfigs.js +324 -0
  125. package/convex/seedDirectCallConfigs.js.map +1 -0
  126. package/convex/seedDirectCallConfigs.ts +336 -0
  127. package/convex/seedPratham.d.ts +6 -0
  128. package/convex/seedPratham.d.ts.map +1 -0
  129. package/convex/seedPratham.js +150 -0
  130. package/convex/seedPratham.js.map +1 -0
  131. package/convex/seedPratham.ts +161 -0
  132. package/convex/spendAlerts.d.ts +36 -0
  133. package/convex/spendAlerts.d.ts.map +1 -0
  134. package/convex/spendAlerts.js +380 -0
  135. package/convex/spendAlerts.js.map +1 -0
  136. package/convex/spendAlerts.ts +442 -0
  137. package/convex/stripeActions.d.ts +19 -0
  138. package/convex/stripeActions.d.ts.map +1 -0
  139. package/convex/stripeActions.js +411 -0
  140. package/convex/stripeActions.js.map +1 -0
  141. package/convex/stripeActions.ts +512 -0
  142. package/convex/teams.d.ts +21 -0
  143. package/convex/teams.d.ts.map +1 -0
  144. package/convex/teams.js +215 -0
  145. package/convex/teams.js.map +1 -0
  146. package/convex/teams.ts +243 -0
  147. package/convex/telemetry.d.ts +4 -0
  148. package/convex/telemetry.d.ts.map +1 -0
  149. package/convex/telemetry.js +74 -0
  150. package/convex/telemetry.js.map +1 -0
  151. package/convex/telemetry.ts +81 -0
  152. package/convex/tsconfig.json +25 -0
  153. package/convex/updateAPIStatus.d.ts +6 -0
  154. package/convex/updateAPIStatus.d.ts.map +1 -0
  155. package/convex/updateAPIStatus.js +40 -0
  156. package/convex/updateAPIStatus.js.map +1 -0
  157. package/convex/updateAPIStatus.ts +45 -0
  158. package/convex/usage.d.ts +27 -0
  159. package/convex/usage.d.ts.map +1 -0
  160. package/convex/usage.js +229 -0
  161. package/convex/usage.js.map +1 -0
  162. package/convex/usage.ts +260 -0
  163. package/convex/waitlist.d.ts +4 -0
  164. package/convex/waitlist.d.ts.map +1 -0
  165. package/convex/waitlist.js +49 -0
  166. package/convex/waitlist.js.map +1 -0
  167. package/convex/waitlist.ts +55 -0
  168. package/convex/webhooks.d.ts +12 -0
  169. package/convex/webhooks.d.ts.map +1 -0
  170. package/convex/webhooks.js +410 -0
  171. package/convex/webhooks.js.map +1 -0
  172. package/convex/webhooks.ts +494 -0
  173. package/convex/workspaces.d.ts +31 -0
  174. package/convex/workspaces.d.ts.map +1 -0
  175. package/convex/workspaces.js +975 -0
  176. package/convex/workspaces.js.map +1 -0
  177. package/convex/workspaces.ts +1130 -0
  178. package/dist/bin.js +0 -0
  179. package/dist/index.js +9 -0
  180. package/dist/index.js.map +1 -1
  181. package/package.json +1 -1
  182. package/src/index.ts +10 -0
  183. package/dist/chain-types.d.ts +0 -187
  184. package/dist/chain-types.d.ts.map +0 -1
  185. package/dist/chain-types.js +0 -33
  186. package/dist/chain-types.js.map +0 -1
  187. package/dist/registry/apis.json.bak +0 -248811
  188. package/dist/src/bin.js +0 -17
  189. package/dist/src/capability-router.js +0 -240
  190. package/dist/src/chainExecutor.js +0 -451
  191. package/dist/src/chainResolver.js +0 -518
  192. package/dist/src/cli/commands/doctor.js +0 -324
  193. package/dist/src/cli/commands/mcp-install.js +0 -255
  194. package/dist/src/cli/commands/restore.js +0 -259
  195. package/dist/src/cli/commands/setup.js +0 -205
  196. package/dist/src/cli/commands/uninstall.js +0 -188
  197. package/dist/src/cli/index.js +0 -111
  198. package/dist/src/cli.js +0 -302
  199. package/dist/src/confirmation.js +0 -240
  200. package/dist/src/credentials.js +0 -357
  201. package/dist/src/credits.js +0 -260
  202. package/dist/src/crypto.js +0 -66
  203. package/dist/src/discovery.js +0 -504
  204. package/dist/src/enterprise/env.js +0 -123
  205. package/dist/src/enterprise/script-generator.js +0 -460
  206. package/dist/src/execute-dynamic.js +0 -473
  207. package/dist/src/execute.js +0 -1727
  208. package/dist/src/index.js +0 -2062
  209. package/dist/src/metered.js +0 -80
  210. package/dist/src/open-apis.js +0 -276
  211. package/dist/src/proxy.js +0 -28
  212. package/dist/src/session.js +0 -86
  213. package/dist/src/stripe.js +0 -407
  214. package/dist/src/telemetry.js +0 -49
  215. package/dist/src/types.js +0 -2
  216. package/dist/src/utils/backup.js +0 -181
  217. package/dist/src/utils/config.js +0 -220
  218. package/dist/src/utils/os.js +0 -105
  219. package/dist/src/utils/paths.js +0 -159
@@ -0,0 +1,336 @@
1
+ import { mutation } from "./_generated/server";
2
+ import { v } from "convex/values";
3
+
4
+ /**
5
+ * Seed Direct Call configs + actions for all 27 APILayer APIs
6
+ * Sets status: "live" and creates action records matching MCP proxy
7
+ *
8
+ * Run: npx convex run seedDirectCallConfigs:seed
9
+ */
10
+
11
+ const API_CONFIGS: Record<string, {
12
+ baseUrl: string;
13
+ actions: { name: string; displayName: string; description: string; method: string; path: string; params: { name: string; type: string; required: boolean; description: string; in: string }[] }[];
14
+ }> = {
15
+ "ExchangeRate API": {
16
+ baseUrl: "https://api.apilayer.com/exchangerates_data",
17
+ actions: [
18
+ { name: "exchange_rates", displayName: "Get Exchange Rates", description: "Get latest exchange rates", method: "GET", path: "/latest", params: [
19
+ { name: "base", type: "string", required: false, description: "Base currency (default: EUR)", in: "query" },
20
+ { name: "symbols", type: "string", required: false, description: "Comma-separated target currencies", in: "query" },
21
+ ]},
22
+ ],
23
+ },
24
+ "Marketstack": {
25
+ baseUrl: "http://api.marketstack.com/v1",
26
+ actions: [
27
+ { name: "market_data", displayName: "End of Day Data", description: "Get end-of-day stock market data", method: "GET", path: "/eod", params: [
28
+ { name: "symbols", type: "string", required: true, description: "Stock ticker symbol(s)", in: "query" },
29
+ ]},
30
+ ],
31
+ },
32
+ "AviationStack": {
33
+ baseUrl: "http://api.aviationstack.com/v1",
34
+ actions: [
35
+ { name: "aviation", displayName: "Flight Status", description: "Get real-time flight status", method: "GET", path: "/flights", params: [
36
+ { name: "flight_iata", type: "string", required: false, description: "Flight IATA code", in: "query" },
37
+ { name: "dep_iata", type: "string", required: false, description: "Departure airport IATA", in: "query" },
38
+ ]},
39
+ ],
40
+ },
41
+ "PDF Layer": {
42
+ baseUrl: "https://api.pdflayer.com/api",
43
+ actions: [
44
+ { name: "pdf_generate", displayName: "Generate PDF", description: "Convert HTML/URL to PDF", method: "POST", path: "/convert", params: [
45
+ { name: "document_url", type: "string", required: false, description: "URL to convert", in: "query" },
46
+ { name: "document_html", type: "string", required: false, description: "HTML to convert", in: "body" },
47
+ ]},
48
+ ],
49
+ },
50
+ "Screenshot Layer": {
51
+ baseUrl: "https://api.apilayer.com/screenshot",
52
+ actions: [
53
+ { name: "screenshot", displayName: "Capture Screenshot", description: "Capture website screenshot", method: "GET", path: "/capture", params: [
54
+ { name: "url", type: "string", required: true, description: "URL to screenshot", in: "query" },
55
+ ]},
56
+ ],
57
+ },
58
+ "Email Verification API": {
59
+ baseUrl: "https://api.apilayer.com/email_verification",
60
+ actions: [
61
+ { name: "verify_email", displayName: "Verify Email", description: "Verify email address validity", method: "GET", path: "/check", params: [
62
+ { name: "email", type: "string", required: true, description: "Email to verify", in: "query" },
63
+ ]},
64
+ ],
65
+ },
66
+ "Number Verification API": {
67
+ baseUrl: "https://api.apilayer.com/number_verification",
68
+ actions: [
69
+ { name: "verify_number", displayName: "Verify Number", description: "Validate phone number", method: "GET", path: "/validate", params: [
70
+ { name: "number", type: "string", required: true, description: "Phone number to validate", in: "query" },
71
+ ]},
72
+ ],
73
+ },
74
+ "VAT Layer": {
75
+ baseUrl: "https://api.apilayer.com/vat_layer",
76
+ actions: [
77
+ { name: "vat_check", displayName: "Validate VAT", description: "Validate EU VAT number", method: "GET", path: "/validate", params: [
78
+ { name: "vat_number", type: "string", required: true, description: "VAT number to validate", in: "query" },
79
+ ]},
80
+ ],
81
+ },
82
+ "World News API": {
83
+ baseUrl: "https://api.apilayer.com/world_news",
84
+ actions: [
85
+ { name: "world_news", displayName: "Extract News", description: "Extract news from URL", method: "GET", path: "/extract-news", params: [
86
+ { name: "url", type: "string", required: true, description: "News URL to extract", in: "query" },
87
+ ]},
88
+ ],
89
+ },
90
+ "Finance News API": {
91
+ baseUrl: "https://api.apilayer.com/financelayer",
92
+ actions: [
93
+ { name: "finance_news", displayName: "Financial News", description: "Get financial news feed", method: "GET", path: "/news", params: [
94
+ { name: "tickers", type: "string", required: false, description: "Stock tickers to filter", in: "query" },
95
+ ]},
96
+ ],
97
+ },
98
+ "Advanced Scraper API": {
99
+ baseUrl: "https://api.apilayer.com/adv_scraper",
100
+ actions: [
101
+ { name: "scrape", displayName: "Scrape URL", description: "Scrape web page content", method: "GET", path: "/scraper", params: [
102
+ { name: "url", type: "string", required: true, description: "URL to scrape", in: "query" },
103
+ ]},
104
+ ],
105
+ },
106
+ "Image Crop API": {
107
+ baseUrl: "https://api.apilayer.com/smart_crop",
108
+ actions: [
109
+ { name: "image_crop", displayName: "Smart Crop", description: "AI-powered image cropping", method: "POST", path: "/url", params: [
110
+ { name: "url", type: "string", required: true, description: "Image URL to crop", in: "query" },
111
+ ]},
112
+ ],
113
+ },
114
+ "Skills API": {
115
+ baseUrl: "https://api.apilayer.com/skills",
116
+ actions: [
117
+ { name: "skills", displayName: "Search Skills", description: "Search skill database", method: "GET", path: "/", params: [
118
+ { name: "q", type: "string", required: true, description: "Search query", in: "query" },
119
+ ]},
120
+ ],
121
+ },
122
+ "Form API": {
123
+ baseUrl: "https://api.apilayer.com/form_api",
124
+ actions: [
125
+ { name: "form_submit", displayName: "Submit Form", description: "Form submission handling", method: "POST", path: "/submit", params: [
126
+ { name: "endpoint", type: "string", required: true, description: "Form endpoint", in: "path" },
127
+ ]},
128
+ ],
129
+ },
130
+ "Fixer API": {
131
+ baseUrl: "http://data.fixer.io/api",
132
+ actions: [
133
+ { name: "fixer_convert", displayName: "Convert Currency", description: "Convert between currencies", method: "GET", path: "/convert", params: [
134
+ { name: "from", type: "string", required: true, description: "Source currency", in: "query" },
135
+ { name: "to", type: "string", required: true, description: "Target currency", in: "query" },
136
+ { name: "amount", type: "number", required: true, description: "Amount to convert", in: "query" },
137
+ ]},
138
+ { name: "fixer_latest", displayName: "Latest Rates", description: "Get latest exchange rates", method: "GET", path: "/latest", params: [
139
+ { name: "base", type: "string", required: false, description: "Base currency", in: "query" },
140
+ { name: "symbols", type: "string", required: false, description: "Target currencies", in: "query" },
141
+ ]},
142
+ ],
143
+ },
144
+ "Currencylayer": {
145
+ baseUrl: "http://api.currencylayer.com",
146
+ actions: [
147
+ { name: "currencylayer_live", displayName: "Live Rates", description: "Get live exchange rates", method: "GET", path: "/live", params: [
148
+ { name: "currencies", type: "string", required: false, description: "Target currencies", in: "query" },
149
+ ]},
150
+ { name: "currencylayer_convert", displayName: "Convert", description: "Convert currency amount", method: "GET", path: "/convert", params: [
151
+ { name: "from", type: "string", required: true, description: "Source currency", in: "query" },
152
+ { name: "to", type: "string", required: true, description: "Target currency", in: "query" },
153
+ { name: "amount", type: "number", required: true, description: "Amount", in: "query" },
154
+ ]},
155
+ ],
156
+ },
157
+ "Coinlayer": {
158
+ baseUrl: "http://api.coinlayer.com",
159
+ actions: [
160
+ { name: "coinlayer_live", displayName: "Live Crypto Rates", description: "Get live cryptocurrency rates", method: "GET", path: "/live", params: [
161
+ { name: "symbols", type: "string", required: false, description: "Crypto symbols", in: "query" },
162
+ ]},
163
+ ],
164
+ },
165
+ "Exchangerate.host": {
166
+ baseUrl: "https://api.exchangerate.host",
167
+ actions: [
168
+ { name: "exchangeratehost_latest", displayName: "Latest Rates", description: "Free exchange rates", method: "GET", path: "/latest", params: [
169
+ { name: "base", type: "string", required: false, description: "Base currency", in: "query" },
170
+ ]},
171
+ ],
172
+ },
173
+ "Weatherstack": {
174
+ baseUrl: "http://api.weatherstack.com",
175
+ actions: [
176
+ { name: "weatherstack_current", displayName: "Current Weather", description: "Get current weather data", method: "GET", path: "/current", params: [
177
+ { name: "query", type: "string", required: true, description: "Location (city, IP, coordinates)", in: "query" },
178
+ ]},
179
+ { name: "weatherstack_forecast", displayName: "Weather Forecast", description: "Get weather forecast", method: "GET", path: "/forecast", params: [
180
+ { name: "query", type: "string", required: true, description: "Location", in: "query" },
181
+ { name: "forecast_days", type: "number", required: false, description: "Days to forecast", in: "query" },
182
+ ]},
183
+ ],
184
+ },
185
+ "IPstack": {
186
+ baseUrl: "http://api.ipstack.com",
187
+ actions: [
188
+ { name: "ipstack_lookup", displayName: "IP Lookup", description: "Geolocate IP address", method: "GET", path: "/{ip}", params: [
189
+ { name: "ip", type: "string", required: true, description: "IP address to lookup", in: "path" },
190
+ ]},
191
+ ],
192
+ },
193
+ "IPapi": {
194
+ baseUrl: "http://api.ipapi.com",
195
+ actions: [
196
+ { name: "ipapi_lookup", displayName: "IP Geolocation", description: "IP address geolocation", method: "GET", path: "/{ip}", params: [
197
+ { name: "ip", type: "string", required: true, description: "IP address", in: "path" },
198
+ ]},
199
+ ],
200
+ },
201
+ "Positionstack": {
202
+ baseUrl: "http://api.positionstack.com/v1",
203
+ actions: [
204
+ { name: "positionstack_forward", displayName: "Forward Geocode", description: "Address to coordinates", method: "GET", path: "/forward", params: [
205
+ { name: "query", type: "string", required: true, description: "Address to geocode", in: "query" },
206
+ ]},
207
+ { name: "positionstack_reverse", displayName: "Reverse Geocode", description: "Coordinates to address", method: "GET", path: "/reverse", params: [
208
+ { name: "query", type: "string", required: true, description: "Lat,lng coordinates", in: "query" },
209
+ ]},
210
+ ],
211
+ },
212
+ "Languagelayer": {
213
+ baseUrl: "https://api.languagelayer.com",
214
+ actions: [
215
+ { name: "languagelayer_detect", displayName: "Detect Language", description: "Detect text language", method: "POST", path: "/detect", params: [
216
+ { name: "query", type: "string", required: true, description: "Text to analyze", in: "body" },
217
+ ]},
218
+ ],
219
+ },
220
+ "Scrapestack": {
221
+ baseUrl: "http://api.scrapestack.com",
222
+ actions: [
223
+ { name: "scrapestack_scrape", displayName: "Scrape Page", description: "Web scraping proxy", method: "GET", path: "/scrape", params: [
224
+ { name: "url", type: "string", required: true, description: "URL to scrape", in: "query" },
225
+ ]},
226
+ ],
227
+ },
228
+ "Serpstack": {
229
+ baseUrl: "http://api.serpstack.com",
230
+ actions: [
231
+ { name: "serpstack_search", displayName: "Search Google", description: "Google search results", method: "GET", path: "/search", params: [
232
+ { name: "query", type: "string", required: true, description: "Search query", in: "query" },
233
+ ]},
234
+ ],
235
+ },
236
+ "Mediastack": {
237
+ baseUrl: "http://api.mediastack.com/v1",
238
+ actions: [
239
+ { name: "mediastack_news", displayName: "Get News", description: "Live news articles", method: "GET", path: "/news", params: [
240
+ { name: "keywords", type: "string", required: false, description: "News keywords", in: "query" },
241
+ { name: "countries", type: "string", required: false, description: "Country codes", in: "query" },
242
+ ]},
243
+ ],
244
+ },
245
+ "Userstack": {
246
+ baseUrl: "http://api.userstack.com",
247
+ actions: [
248
+ { name: "userstack_detect", displayName: "Detect User Agent", description: "Parse user agent string", method: "GET", path: "/detect", params: [
249
+ { name: "ua", type: "string", required: true, description: "User agent string", in: "query" },
250
+ ]},
251
+ ],
252
+ },
253
+ };
254
+
255
+ export const seed = mutation({
256
+ args: {},
257
+ handler: async (ctx) => {
258
+ const providerId = "k97cvcvadnyz8x8m4we7xqmh1s83p0ph" as any; // APILayer provider ID
259
+ const now = Date.now();
260
+
261
+ // Get all provider APIs
262
+ const apis = await ctx.db
263
+ .query("providerAPIs")
264
+ .withIndex("by_providerId", (q: any) => q.eq("providerId", providerId))
265
+ .collect();
266
+
267
+ let configsCreated = 0;
268
+ let actionsCreated = 0;
269
+
270
+ for (const api of apis) {
271
+ const config = API_CONFIGS[api.name];
272
+ if (!config) continue;
273
+
274
+ // Check if Direct Call config already exists
275
+ const existing = await ctx.db
276
+ .query("providerDirectCall")
277
+ .withIndex("by_apiId", (q: any) => q.eq("apiId", api._id))
278
+ .first();
279
+
280
+ let directCallId;
281
+ if (existing) {
282
+ // Update to live
283
+ await ctx.db.patch(existing._id, { status: "live", updatedAt: now, publishedAt: now });
284
+ directCallId = existing._id;
285
+ } else {
286
+ // Create new config
287
+ directCallId = await ctx.db.insert("providerDirectCall", {
288
+ providerId,
289
+ apiId: api._id,
290
+ baseUrl: config.baseUrl,
291
+ authType: "bearer",
292
+ authHeader: "apikey",
293
+ authPrefix: "",
294
+ encryptedMasterKey: "managed-by-apiclaw",
295
+ rateLimitPerUser: 60,
296
+ rateLimitPerDay: 1000,
297
+ pricePerRequest: 0,
298
+ status: "live",
299
+ allowCustomerKeys: false,
300
+ requireCustomerKeys: false,
301
+ createdAt: now,
302
+ updatedAt: now,
303
+ publishedAt: now,
304
+ });
305
+ configsCreated++;
306
+ }
307
+
308
+ // Create actions (skip if already exist)
309
+ for (const action of config.actions) {
310
+ const existingAction = await ctx.db
311
+ .query("providerActions")
312
+ .withIndex("by_directCallId_name", (q: any) => q.eq("directCallId", directCallId).eq("name", action.name))
313
+ .first();
314
+
315
+ if (!existingAction) {
316
+ await ctx.db.insert("providerActions", {
317
+ directCallId,
318
+ name: action.name,
319
+ displayName: action.displayName,
320
+ description: action.description,
321
+ method: action.method,
322
+ path: action.path,
323
+ params: action.params,
324
+ responseMapping: [],
325
+ enabled: true,
326
+ createdAt: now,
327
+ updatedAt: now,
328
+ });
329
+ actionsCreated++;
330
+ }
331
+ }
332
+ }
333
+
334
+ return { success: true, configsCreated, actionsCreated, totalApis: apis.length };
335
+ },
336
+ });
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Seed Pratham's workspace with all 27 APILayer APIs
3
+ * Run with: npx convex run seedPratham:seedPrathamWorkspace
4
+ */
5
+ export declare const seedPrathamWorkspace: any;
6
+ //# sourceMappingURL=seedPratham.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seedPratham.d.ts","sourceRoot":"","sources":["seedPratham.ts"],"names":[],"mappings":"AAEA;;;GAGG;AAEH,eAAO,MAAM,oBAAoB,KAyJ/B,CAAC"}
@@ -0,0 +1,150 @@
1
+ import { mutation } from "./_generated/server";
2
+ /**
3
+ * Seed Pratham's workspace with all 27 APILayer APIs
4
+ * Run with: npx convex run seedPratham:seedPrathamWorkspace
5
+ */
6
+ export const seedPrathamWorkspace = mutation({
7
+ args: {},
8
+ handler: async (ctx) => {
9
+ const email = "gustav_hemmingsson@hotmail.com"; // Gustav's personal email for testing
10
+ // 1. Create or get workspace
11
+ let workspace = await ctx.db
12
+ .query("workspaces")
13
+ .withIndex("by_email", (q) => q.eq("email", email))
14
+ .first();
15
+ if (!workspace) {
16
+ const workspaceId = await ctx.db.insert("workspaces", {
17
+ email,
18
+ status: "active",
19
+ tier: "backer", // Give him backer tier (unlimited)
20
+ usageCount: 0,
21
+ usageLimit: -1, // unlimited
22
+ weeklyUsageCount: 0,
23
+ weeklyUsageLimit: -1, // unlimited
24
+ hourlyUsageCount: 0,
25
+ backerUntil: new Date("2027-12-31").getTime(), // Backer until end of 2027
26
+ mainAgentName: "APILayer Dashboard",
27
+ createdAt: Date.now(),
28
+ updatedAt: Date.now(),
29
+ });
30
+ workspace = await ctx.db.get(workspaceId);
31
+ console.log(`✓ Created workspace for ${email}`);
32
+ }
33
+ else {
34
+ console.log(`✓ Workspace exists for ${email}`);
35
+ }
36
+ if (!workspace)
37
+ throw new Error("Failed to create workspace");
38
+ // 2. Create provider profile
39
+ let provider = await ctx.db
40
+ .query("providers")
41
+ .withIndex("by_email", (q) => q.eq("email", email))
42
+ .first();
43
+ if (!provider) {
44
+ const providerId = await ctx.db.insert("providers", {
45
+ email,
46
+ name: "Pratham (APILayer)",
47
+ company: "APILayer",
48
+ website: "https://apilayer.com",
49
+ status: "approved",
50
+ stripeOnboardingComplete: false,
51
+ createdAt: Date.now(),
52
+ updatedAt: Date.now(),
53
+ approvedAt: Date.now(),
54
+ });
55
+ provider = await ctx.db.get(providerId);
56
+ console.log(`✓ Created provider profile`);
57
+ }
58
+ else {
59
+ console.log(`✓ Provider profile exists`);
60
+ }
61
+ if (!provider)
62
+ throw new Error("Failed to create provider");
63
+ // 3. Create all 27 APILayer APIs
64
+ const apis = [
65
+ // Unified APIs (14)
66
+ { name: "ExchangeRate API", description: "Real-time exchange rates", category: "finance", action: "exchange_rates" },
67
+ { name: "Marketstack", description: "Real-time market data", category: "finance", action: "market_data" },
68
+ { name: "AviationStack", description: "Flight data API", category: "geolocation", action: "aviation" },
69
+ { name: "PDF Layer", description: "HTML to PDF conversion", category: "business", action: "pdf_generate" },
70
+ { name: "Screenshot Layer", description: "Website screenshots", category: "marketing", action: "screenshot" },
71
+ { name: "Email Verification API", description: "Verify email addresses", category: "devtools", action: "verify_email" },
72
+ { name: "Number Verification API", description: "Validate phone numbers", category: "devtools", action: "verify_number" },
73
+ { name: "VAT Layer", description: "VAT number validation", category: "finance", action: "vat_check" },
74
+ { name: "World News API", description: "Extract news from URLs", category: "news", action: "world_news" },
75
+ { name: "Finance News API", description: "Financial news feed", category: "news", action: "finance_news" },
76
+ { name: "Advanced Scraper API", description: "Web scraping", category: "scraping", action: "scrape" },
77
+ { name: "Image Crop API", description: "Smart image cropping", category: "marketing", action: "image_crop" },
78
+ { name: "Skills API", description: "Skill database search", category: "devtools", action: "skills" },
79
+ { name: "Form API", description: "Form submission handling", category: "devtools", action: "form_submit" },
80
+ // Legacy APIs (13)
81
+ { name: "Fixer API", description: "Currency conversion (legacy)", category: "finance", action: "fixer_convert" },
82
+ { name: "Fixer Latest Rates", description: "Latest exchange rates", category: "finance", action: "fixer_latest" },
83
+ { name: "Currencylayer Live", description: "Live currency rates", category: "finance", action: "currencylayer_live" },
84
+ { name: "Currencylayer Convert", description: "Currency conversion", category: "finance", action: "currencylayer_convert" },
85
+ { name: "Coinlayer", description: "Crypto exchange rates", category: "finance", action: "coinlayer_live" },
86
+ { name: "Exchangerate.host", description: "Exchange rates API", category: "finance", action: "exchangeratehost_latest" },
87
+ { name: "Weatherstack Current", description: "Current weather data", category: "geolocation", action: "weatherstack_current" },
88
+ { name: "Weatherstack Forecast", description: "Weather forecasts", category: "geolocation", action: "weatherstack_forecast" },
89
+ { name: "IPstack", description: "IP geolocation lookup", category: "geolocation", action: "ipstack_lookup" },
90
+ { name: "IPapi", description: "IP address lookup", category: "geolocation", action: "ipapi_lookup" },
91
+ { name: "Positionstack Forward", description: "Geocoding (address → coords)", category: "geolocation", action: "positionstack_forward" },
92
+ { name: "Positionstack Reverse", description: "Reverse geocoding (coords → address)", category: "geolocation", action: "positionstack_reverse" },
93
+ { name: "Languagelayer", description: "Language detection", category: "devtools", action: "languagelayer_detect" },
94
+ { name: "Scrapestack", description: "Web scraping service", category: "scraping", action: "scrapestack_scrape" },
95
+ { name: "Serpstack", description: "Google search results", category: "scraping", action: "serpstack_search" },
96
+ { name: "Mediastack", description: "News and blog articles", category: "news", action: "mediastack_news" },
97
+ { name: "Userstack", description: "User agent detection", category: "devtools", action: "userstack_detect" },
98
+ ];
99
+ let createdCount = 0;
100
+ let existingCount = 0;
101
+ for (const api of apis) {
102
+ // Check if already exists
103
+ const existing = await ctx.db
104
+ .query("providerAPIs")
105
+ .withIndex("by_providerId", (q) => q.eq("providerId", provider._id))
106
+ .filter((q) => q.eq(q.field("name"), api.name))
107
+ .first();
108
+ if (!existing) {
109
+ await ctx.db.insert("providerAPIs", {
110
+ providerId: provider._id,
111
+ name: api.name,
112
+ description: api.description,
113
+ category: api.category,
114
+ pricingModel: "freemium",
115
+ pricingNotes: "Free tier available, paid tiers for higher limits",
116
+ status: "approved",
117
+ createdAt: Date.now(),
118
+ approvedAt: Date.now(),
119
+ discoveryCount: 0,
120
+ });
121
+ createdCount++;
122
+ }
123
+ else {
124
+ existingCount++;
125
+ }
126
+ }
127
+ console.log(`✓ APIs: ${createdCount} created, ${existingCount} already existed`);
128
+ return {
129
+ success: true,
130
+ workspace: {
131
+ email: workspace.email,
132
+ tier: workspace.tier,
133
+ id: workspace._id,
134
+ },
135
+ provider: {
136
+ name: provider.name,
137
+ company: provider.company,
138
+ id: provider._id,
139
+ },
140
+ apis: {
141
+ total: apis.length,
142
+ created: createdCount,
143
+ existing: existingCount,
144
+ },
145
+ dashboardUrl: `https://apiclaw.nordsym.com/workspace`,
146
+ loginInstructions: "Test account using Gustav's personal email. Magic link will be sent to gustav_hemmingsson@hotmail.com",
147
+ };
148
+ },
149
+ });
150
+ //# sourceMappingURL=seedPratham.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"seedPratham.js","sourceRoot":"","sources":["seedPratham.ts"],"names":[],"mappings":"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"}