pilothub 0.0.1 → 0.0.2

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 (388) hide show
  1. package/LICENSE +1 -0
  2. package/README.md +36 -129
  3. package/dist/browserAuth.d.ts +20 -0
  4. package/dist/browserAuth.js +156 -0
  5. package/dist/browserAuth.js.map +1 -0
  6. package/dist/browserAuth.test.d.ts +1 -0
  7. package/dist/browserAuth.test.js +83 -0
  8. package/dist/browserAuth.test.js.map +1 -0
  9. package/dist/cli/buildInfo.d.ts +3 -0
  10. package/dist/cli/buildInfo.js +103 -0
  11. package/dist/cli/buildInfo.js.map +1 -0
  12. package/dist/cli/commands/auth.d.ts +9 -0
  13. package/dist/cli/commands/auth.js +75 -0
  14. package/dist/cli/commands/auth.js.map +1 -0
  15. package/dist/cli/commands/delete.d.ts +11 -0
  16. package/dist/cli/commands/delete.js +67 -0
  17. package/dist/cli/commands/delete.js.map +1 -0
  18. package/dist/cli/commands/delete.test.d.ts +1 -0
  19. package/dist/cli/commands/delete.test.js +52 -0
  20. package/dist/cli/commands/delete.test.js.map +1 -0
  21. package/dist/cli/commands/publish.d.ts +9 -0
  22. package/dist/cli/commands/publish.js +87 -0
  23. package/dist/cli/commands/publish.js.map +1 -0
  24. package/dist/cli/commands/publish.test.d.ts +1 -0
  25. package/dist/cli/commands/publish.test.js +104 -0
  26. package/dist/cli/commands/publish.test.js.map +1 -0
  27. package/dist/cli/commands/skills.d.ts +23 -0
  28. package/dist/cli/commands/skills.js +298 -0
  29. package/dist/cli/commands/skills.js.map +1 -0
  30. package/dist/cli/commands/skills.test.d.ts +1 -0
  31. package/dist/cli/commands/skills.test.js +156 -0
  32. package/dist/cli/commands/skills.test.js.map +1 -0
  33. package/dist/cli/commands/star.d.ts +8 -0
  34. package/dist/cli/commands/star.js +38 -0
  35. package/dist/cli/commands/star.js.map +1 -0
  36. package/dist/cli/commands/sync.d.ts +3 -0
  37. package/dist/cli/commands/sync.js +160 -0
  38. package/dist/cli/commands/sync.js.map +1 -0
  39. package/dist/cli/commands/sync.test.d.ts +1 -0
  40. package/dist/cli/commands/sync.test.js +277 -0
  41. package/dist/cli/commands/sync.test.js.map +1 -0
  42. package/dist/cli/commands/syncHelpers.d.ts +76 -0
  43. package/dist/cli/commands/syncHelpers.js +349 -0
  44. package/dist/cli/commands/syncHelpers.js.map +1 -0
  45. package/dist/cli/commands/syncHelpers.test.d.ts +1 -0
  46. package/dist/cli/commands/syncHelpers.test.js +22 -0
  47. package/dist/cli/commands/syncHelpers.test.js.map +1 -0
  48. package/dist/cli/commands/syncTypes.d.ts +24 -0
  49. package/dist/cli/commands/syncTypes.js +2 -0
  50. package/dist/cli/commands/syncTypes.js.map +1 -0
  51. package/dist/cli/commands/unstar.d.ts +8 -0
  52. package/dist/cli/commands/unstar.js +38 -0
  53. package/dist/cli/commands/unstar.js.map +1 -0
  54. package/dist/cli/helpStyle.d.ts +13 -0
  55. package/dist/cli/helpStyle.js +38 -0
  56. package/dist/cli/helpStyle.js.map +1 -0
  57. package/dist/cli/pilotbotConfig.d.ts +6 -0
  58. package/dist/cli/pilotbotConfig.js +110 -0
  59. package/dist/cli/pilotbotConfig.js.map +1 -0
  60. package/dist/cli/pilotbotConfig.test.d.ts +1 -0
  61. package/dist/cli/pilotbotConfig.test.js +133 -0
  62. package/dist/cli/pilotbotConfig.test.js.map +1 -0
  63. package/dist/cli/registry.d.ts +7 -0
  64. package/dist/cli/registry.js +42 -0
  65. package/dist/cli/registry.js.map +1 -0
  66. package/dist/cli/registry.test.d.ts +1 -0
  67. package/dist/cli/registry.test.js +48 -0
  68. package/dist/cli/registry.test.js.map +1 -0
  69. package/dist/cli/scanSkills.d.ts +7 -0
  70. package/dist/cli/scanSkills.js +75 -0
  71. package/dist/cli/scanSkills.js.map +1 -0
  72. package/dist/cli/scanSkills.test.d.ts +1 -0
  73. package/dist/cli/scanSkills.test.js +60 -0
  74. package/dist/cli/scanSkills.test.js.map +1 -0
  75. package/dist/cli/slug.d.ts +2 -0
  76. package/dist/cli/slug.js +16 -0
  77. package/dist/cli/slug.js.map +1 -0
  78. package/dist/cli/types.d.ts +15 -0
  79. package/dist/cli/types.js +2 -0
  80. package/dist/cli/types.js.map +1 -0
  81. package/dist/cli/ui.d.ts +7 -0
  82. package/dist/cli/ui.js +72 -0
  83. package/dist/cli/ui.js.map +1 -0
  84. package/dist/cli.d.ts +2 -0
  85. package/dist/cli.js +268 -0
  86. package/dist/cli.js.map +1 -0
  87. package/dist/config.d.ts +4 -0
  88. package/dist/config.js +38 -0
  89. package/dist/config.js.map +1 -0
  90. package/dist/discovery.d.ts +5 -0
  91. package/dist/discovery.js +21 -0
  92. package/dist/discovery.js.map +1 -0
  93. package/dist/discovery.test.d.ts +1 -0
  94. package/dist/discovery.test.js +46 -0
  95. package/dist/discovery.test.js.map +1 -0
  96. package/dist/http.d.ts +32 -0
  97. package/dist/http.js +261 -0
  98. package/dist/http.js.map +1 -0
  99. package/dist/http.test.d.ts +1 -0
  100. package/dist/http.test.js +135 -0
  101. package/dist/http.test.js.map +1 -0
  102. package/dist/schema/ark.js.map +1 -0
  103. package/dist/schema/index.js.map +1 -0
  104. package/dist/schema/routes.js.map +1 -0
  105. package/{packages/schema/dist → dist/schema}/schemas.d.ts +0 -39
  106. package/{packages/schema/dist → dist/schema}/schemas.js +0 -22
  107. package/dist/schema/schemas.js.map +1 -0
  108. package/dist/schema/textFiles.js.map +1 -0
  109. package/dist/schema/textFiles.test.d.ts +1 -0
  110. package/dist/schema/textFiles.test.js +20 -0
  111. package/dist/schema/textFiles.test.js.map +1 -0
  112. package/dist/skills.d.ts +43 -0
  113. package/dist/skills.js +163 -0
  114. package/dist/skills.js.map +1 -0
  115. package/dist/skills.test.d.ts +1 -0
  116. package/dist/skills.test.js +144 -0
  117. package/dist/skills.test.js.map +1 -0
  118. package/dist/types.d.ts +7 -0
  119. package/dist/types.js +2 -0
  120. package/dist/types.js.map +1 -0
  121. package/package.json +27 -70
  122. package/.env.local.example +0 -19
  123. package/.github/workflows/ci.yml +0 -40
  124. package/.oxlintrc.json +0 -3
  125. package/AGENTS.md +0 -45
  126. package/CHANGELOG.md +0 -138
  127. package/DEPRECATIONS.md +0 -7
  128. package/biome.json +0 -41
  129. package/convex/_generated/api.d.ts +0 -153
  130. package/convex/_generated/api.js +0 -23
  131. package/convex/_generated/dataModel.d.ts +0 -60
  132. package/convex/_generated/server.d.ts +0 -143
  133. package/convex/_generated/server.js +0 -93
  134. package/convex/auth.config.ts +0 -8
  135. package/convex/auth.ts +0 -19
  136. package/convex/comments.ts +0 -88
  137. package/convex/crons.ts +0 -34
  138. package/convex/devSeed.ts +0 -459
  139. package/convex/devSeedExtra.ts +0 -541
  140. package/convex/downloads.ts +0 -78
  141. package/convex/githubBackups.ts +0 -170
  142. package/convex/githubBackupsNode.ts +0 -183
  143. package/convex/githubImport.ts +0 -317
  144. package/convex/githubSoulBackups.ts +0 -170
  145. package/convex/githubSoulBackupsNode.ts +0 -186
  146. package/convex/http.ts +0 -194
  147. package/convex/httpApi.handlers.test.ts +0 -488
  148. package/convex/httpApi.test.ts +0 -70
  149. package/convex/httpApi.ts +0 -305
  150. package/convex/httpApiV1.handlers.test.ts +0 -584
  151. package/convex/httpApiV1.ts +0 -1172
  152. package/convex/leaderboards.ts +0 -39
  153. package/convex/lib/access.ts +0 -36
  154. package/convex/lib/apiTokenAuth.ts +0 -36
  155. package/convex/lib/badges.ts +0 -50
  156. package/convex/lib/changelog.test.ts +0 -34
  157. package/convex/lib/changelog.ts +0 -278
  158. package/convex/lib/embeddings.ts +0 -38
  159. package/convex/lib/githubBackup.ts +0 -443
  160. package/convex/lib/githubImport.test.ts +0 -247
  161. package/convex/lib/githubImport.ts +0 -425
  162. package/convex/lib/githubSoulBackup.ts +0 -443
  163. package/convex/lib/leaderboards.ts +0 -103
  164. package/convex/lib/moderation.ts +0 -42
  165. package/convex/lib/public.ts +0 -89
  166. package/convex/lib/searchText.test.ts +0 -46
  167. package/convex/lib/searchText.ts +0 -27
  168. package/convex/lib/skillBackfill.test.ts +0 -34
  169. package/convex/lib/skillBackfill.ts +0 -67
  170. package/convex/lib/skillPublish.test.ts +0 -28
  171. package/convex/lib/skillPublish.ts +0 -284
  172. package/convex/lib/skillStats.ts +0 -80
  173. package/convex/lib/skills.test.ts +0 -197
  174. package/convex/lib/skills.ts +0 -273
  175. package/convex/lib/soulChangelog.ts +0 -273
  176. package/convex/lib/soulPublish.ts +0 -236
  177. package/convex/lib/tokens.test.ts +0 -33
  178. package/convex/lib/tokens.ts +0 -51
  179. package/convex/lib/webhooks.test.ts +0 -91
  180. package/convex/lib/webhooks.ts +0 -112
  181. package/convex/maintenance.test.ts +0 -270
  182. package/convex/maintenance.ts +0 -840
  183. package/convex/rateLimits.ts +0 -50
  184. package/convex/schema.ts +0 -472
  185. package/convex/search.test.ts +0 -12
  186. package/convex/search.ts +0 -254
  187. package/convex/seed.test.ts +0 -37
  188. package/convex/seed.ts +0 -254
  189. package/convex/seedSouls.ts +0 -111
  190. package/convex/skillStatEvents.ts +0 -568
  191. package/convex/skills.ts +0 -1606
  192. package/convex/soulComments.ts +0 -88
  193. package/convex/soulDownloads.ts +0 -14
  194. package/convex/soulStars.ts +0 -71
  195. package/convex/souls.ts +0 -570
  196. package/convex/stars.ts +0 -108
  197. package/convex/statsMaintenance.ts +0 -205
  198. package/convex/telemetry.ts +0 -434
  199. package/convex/tokens.ts +0 -88
  200. package/convex/tsconfig.json +0 -7
  201. package/convex/uploads.ts +0 -20
  202. package/convex/users.ts +0 -122
  203. package/convex/webhooks.ts +0 -50
  204. package/convex.json +0 -3
  205. package/docs/README.md +0 -32
  206. package/docs/api.md +0 -51
  207. package/docs/architecture.md +0 -61
  208. package/docs/auth.md +0 -54
  209. package/docs/cli.md +0 -117
  210. package/docs/deploy.md +0 -78
  211. package/docs/diffing.md +0 -84
  212. package/docs/github-import.md +0 -171
  213. package/docs/http-api.md +0 -187
  214. package/docs/manual-testing.md +0 -64
  215. package/docs/mintlify.md +0 -43
  216. package/docs/quickstart.md +0 -120
  217. package/docs/skill-format.md +0 -58
  218. package/docs/soul-format.md +0 -37
  219. package/docs/spec.md +0 -177
  220. package/docs/telemetry.md +0 -91
  221. package/docs/troubleshooting.md +0 -49
  222. package/docs/webhook.md +0 -51
  223. package/e2e/menu-smoke.pw.test.ts +0 -49
  224. package/e2e/pilothub.e2e.test.ts +0 -494
  225. package/e2e/search-exact.pw.test.ts +0 -97
  226. package/packages/pilothub/LICENSE +0 -22
  227. package/packages/pilothub/README.md +0 -57
  228. package/packages/pilothub/package.json +0 -41
  229. package/packages/pilothub/src/browserAuth.test.ts +0 -96
  230. package/packages/pilothub/src/browserAuth.ts +0 -174
  231. package/packages/pilothub/src/cli/buildInfo.ts +0 -94
  232. package/packages/pilothub/src/cli/commands/auth.ts +0 -97
  233. package/packages/pilothub/src/cli/commands/delete.test.ts +0 -73
  234. package/packages/pilothub/src/cli/commands/delete.ts +0 -83
  235. package/packages/pilothub/src/cli/commands/publish.test.ts +0 -122
  236. package/packages/pilothub/src/cli/commands/publish.ts +0 -108
  237. package/packages/pilothub/src/cli/commands/skills.test.ts +0 -191
  238. package/packages/pilothub/src/cli/commands/skills.ts +0 -380
  239. package/packages/pilothub/src/cli/commands/star.ts +0 -46
  240. package/packages/pilothub/src/cli/commands/sync.test.ts +0 -310
  241. package/packages/pilothub/src/cli/commands/sync.ts +0 -200
  242. package/packages/pilothub/src/cli/commands/syncHelpers.test.ts +0 -26
  243. package/packages/pilothub/src/cli/commands/syncHelpers.ts +0 -427
  244. package/packages/pilothub/src/cli/commands/syncTypes.ts +0 -27
  245. package/packages/pilothub/src/cli/commands/unstar.ts +0 -48
  246. package/packages/pilothub/src/cli/helpStyle.ts +0 -45
  247. package/packages/pilothub/src/cli/pilotbotConfig.test.ts +0 -159
  248. package/packages/pilothub/src/cli/pilotbotConfig.ts +0 -147
  249. package/packages/pilothub/src/cli/registry.test.ts +0 -63
  250. package/packages/pilothub/src/cli/registry.ts +0 -43
  251. package/packages/pilothub/src/cli/scanSkills.test.ts +0 -64
  252. package/packages/pilothub/src/cli/scanSkills.ts +0 -84
  253. package/packages/pilothub/src/cli/slug.ts +0 -16
  254. package/packages/pilothub/src/cli/types.ts +0 -12
  255. package/packages/pilothub/src/cli/ui.ts +0 -75
  256. package/packages/pilothub/src/cli.ts +0 -311
  257. package/packages/pilothub/src/config.ts +0 -36
  258. package/packages/pilothub/src/discovery.test.ts +0 -75
  259. package/packages/pilothub/src/discovery.ts +0 -19
  260. package/packages/pilothub/src/http.test.ts +0 -156
  261. package/packages/pilothub/src/http.ts +0 -301
  262. package/packages/pilothub/src/schema/ark.ts +0 -29
  263. package/packages/pilothub/src/schema/index.ts +0 -5
  264. package/packages/pilothub/src/schema/routes.ts +0 -22
  265. package/packages/pilothub/src/schema/schemas.ts +0 -260
  266. package/packages/pilothub/src/schema/textFiles.test.ts +0 -23
  267. package/packages/pilothub/src/schema/textFiles.ts +0 -66
  268. package/packages/pilothub/src/skills.test.ts +0 -191
  269. package/packages/pilothub/src/skills.ts +0 -172
  270. package/packages/pilothub/src/types.ts +0 -10
  271. package/packages/pilothub/tsconfig.json +0 -14
  272. package/packages/schema/README.md +0 -3
  273. package/packages/schema/dist/ark.js.map +0 -1
  274. package/packages/schema/dist/index.js.map +0 -1
  275. package/packages/schema/dist/routes.js.map +0 -1
  276. package/packages/schema/dist/schemas.js.map +0 -1
  277. package/packages/schema/dist/textFiles.js.map +0 -1
  278. package/packages/schema/package.json +0 -26
  279. package/packages/schema/src/ark.ts +0 -29
  280. package/packages/schema/src/index.ts +0 -5
  281. package/packages/schema/src/routes.ts +0 -22
  282. package/packages/schema/src/schemas.test.ts +0 -123
  283. package/packages/schema/src/schemas.ts +0 -287
  284. package/packages/schema/src/textFiles.test.ts +0 -23
  285. package/packages/schema/src/textFiles.ts +0 -66
  286. package/packages/schema/tsconfig.json +0 -15
  287. package/pilothub +0 -46
  288. package/playwright.config.ts +0 -33
  289. package/public/.well-known/pilothub.json +0 -6
  290. package/public/api/v1/openapi.json +0 -379
  291. package/public/favicon.ico +0 -0
  292. package/public/logo192.png +0 -0
  293. package/public/logo512.png +0 -0
  294. package/public/manifest.json +0 -25
  295. package/public/og.png +0 -0
  296. package/public/og.svg +0 -98
  297. package/public/pilot-logo.png +0 -0
  298. package/public/pilot-mark.png +0 -0
  299. package/public/robots.txt +0 -3
  300. package/public/tanstack-circle-logo.png +0 -0
  301. package/public/tanstack-word-logo-white.svg +0 -1
  302. package/scripts/check-peer-deps.ts +0 -56
  303. package/scripts/docs-list.ts +0 -148
  304. package/scripts/run-playwright-local.sh +0 -14
  305. package/server/og/fetchSkillOgMeta.ts +0 -27
  306. package/server/og/fetchSoulOgMeta.ts +0 -27
  307. package/server/og/ogAssets.ts +0 -80
  308. package/server/og/skillOgSvg.test.ts +0 -59
  309. package/server/og/skillOgSvg.ts +0 -258
  310. package/server/og/soulOgSvg.ts +0 -209
  311. package/server/routes/og/skill.png.ts +0 -103
  312. package/server/routes/og/soul.png.ts +0 -111
  313. package/src/__tests__/skill-detail-page.test.tsx +0 -86
  314. package/src/__tests__/skills-index.test.tsx +0 -145
  315. package/src/__tests__/upload.route.test.tsx +0 -228
  316. package/src/components/AppProviders.tsx +0 -19
  317. package/src/components/ClientOnly.tsx +0 -18
  318. package/src/components/Footer.tsx +0 -29
  319. package/src/components/Header.tsx +0 -295
  320. package/src/components/InstallSwitcher.tsx +0 -53
  321. package/src/components/SkillCard.tsx +0 -36
  322. package/src/components/SkillDetailPage.tsx +0 -817
  323. package/src/components/SkillDiffCard.tsx +0 -485
  324. package/src/components/SoulCard.tsx +0 -19
  325. package/src/components/SoulDetailPage.tsx +0 -263
  326. package/src/components/UserBootstrap.tsx +0 -18
  327. package/src/components/ui/dropdown-menu.tsx +0 -67
  328. package/src/components/ui/toggle-group.tsx +0 -35
  329. package/src/convex/client.ts +0 -3
  330. package/src/lib/badges.ts +0 -29
  331. package/src/lib/diffing.test.ts +0 -163
  332. package/src/lib/diffing.ts +0 -106
  333. package/src/lib/gravatar.test.ts +0 -9
  334. package/src/lib/gravatar.ts +0 -158
  335. package/src/lib/og.test.ts +0 -142
  336. package/src/lib/og.ts +0 -156
  337. package/src/lib/publicUser.ts +0 -39
  338. package/src/lib/roles.ts +0 -19
  339. package/src/lib/site.test.ts +0 -130
  340. package/src/lib/site.ts +0 -84
  341. package/src/lib/theme-transition.test.ts +0 -134
  342. package/src/lib/theme-transition.ts +0 -134
  343. package/src/lib/theme.test.tsx +0 -88
  344. package/src/lib/theme.ts +0 -43
  345. package/src/lib/uploadFiles.jsdom.test.ts +0 -33
  346. package/src/lib/uploadFiles.test.ts +0 -123
  347. package/src/lib/uploadFiles.ts +0 -245
  348. package/src/lib/uploadUtils.test.ts +0 -78
  349. package/src/lib/uploadUtils.ts +0 -93
  350. package/src/lib/useAuthStatus.ts +0 -12
  351. package/src/lib/utils.test.ts +0 -9
  352. package/src/lib/utils.ts +0 -6
  353. package/src/logo.svg +0 -12
  354. package/src/routeTree.gen.ts +0 -345
  355. package/src/router.tsx +0 -17
  356. package/src/routes/$owner/$slug.tsx +0 -55
  357. package/src/routes/__root.tsx +0 -136
  358. package/src/routes/admin.tsx +0 -11
  359. package/src/routes/cli/auth.tsx +0 -168
  360. package/src/routes/dashboard.tsx +0 -97
  361. package/src/routes/import.tsx +0 -415
  362. package/src/routes/index.tsx +0 -252
  363. package/src/routes/management.tsx +0 -529
  364. package/src/routes/settings.tsx +0 -203
  365. package/src/routes/skills/index.tsx +0 -422
  366. package/src/routes/souls/$slug.tsx +0 -55
  367. package/src/routes/souls/index.tsx +0 -243
  368. package/src/routes/stars.tsx +0 -68
  369. package/src/routes/u/$handle.tsx +0 -307
  370. package/src/routes/upload/utils.ts +0 -81
  371. package/src/routes/upload.tsx +0 -499
  372. package/src/styles.css +0 -2718
  373. package/tsconfig.json +0 -24
  374. package/tsconfig.oxlint.json +0 -16
  375. package/vercel.json +0 -8
  376. package/vite.config.ts +0 -48
  377. package/vitest.config.ts +0 -47
  378. package/vitest.e2e.config.ts +0 -11
  379. package/vitest.setup.ts +0 -1
  380. /package/{packages/pilothub/bin → bin}/pilothub.js +0 -0
  381. /package/{packages/schema/dist → dist/schema}/ark.d.ts +0 -0
  382. /package/{packages/schema/dist → dist/schema}/ark.js +0 -0
  383. /package/{packages/schema/dist → dist/schema}/index.d.ts +0 -0
  384. /package/{packages/schema/dist → dist/schema}/index.js +0 -0
  385. /package/{packages/schema/dist → dist/schema}/routes.d.ts +0 -0
  386. /package/{packages/schema/dist → dist/schema}/routes.js +0 -0
  387. /package/{packages/schema/dist → dist/schema}/textFiles.d.ts +0 -0
  388. /package/{packages/schema/dist → dist/schema}/textFiles.js +0 -0
@@ -1,584 +0,0 @@
1
- /* @vitest-environment node */
2
- import { beforeEach, describe, expect, it, vi } from 'vitest'
3
-
4
- vi.mock('./lib/apiTokenAuth', () => ({
5
- requireApiTokenUser: vi.fn(),
6
- }))
7
-
8
- vi.mock('./skills', () => ({
9
- publishVersionForUser: vi.fn(),
10
- }))
11
-
12
- const { requireApiTokenUser } = await import('./lib/apiTokenAuth')
13
- const { publishVersionForUser } = await import('./skills')
14
- const { __handlers } = await import('./httpApiV1')
15
-
16
- type ActionCtx = import('./_generated/server').ActionCtx
17
-
18
- function makeCtx(partial: Record<string, unknown>) {
19
- return partial as unknown as ActionCtx
20
- }
21
-
22
- const okRate = () => ({
23
- allowed: true,
24
- remaining: 10,
25
- limit: 100,
26
- resetAt: Date.now() + 60_000,
27
- })
28
-
29
- const blockedRate = () => ({
30
- allowed: false,
31
- remaining: 0,
32
- limit: 100,
33
- resetAt: Date.now() + 60_000,
34
- })
35
-
36
- beforeEach(() => {
37
- vi.mocked(requireApiTokenUser).mockReset()
38
- vi.mocked(publishVersionForUser).mockReset()
39
- })
40
-
41
- describe('httpApiV1 handlers', () => {
42
- it('search returns empty results for blank query', async () => {
43
- const runAction = vi.fn()
44
- const runMutation = vi.fn().mockResolvedValue(okRate())
45
- const response = await __handlers.searchSkillsV1Handler(
46
- makeCtx({ runAction, runMutation }),
47
- new Request('https://example.com/api/v1/search?q=%20%20'),
48
- )
49
- if (response.status !== 200) {
50
- throw new Error(await response.text())
51
- }
52
- expect(await response.json()).toEqual({ results: [] })
53
- expect(runAction).not.toHaveBeenCalled()
54
- })
55
-
56
- it('search forwards limit and highlightedOnly', async () => {
57
- const runAction = vi.fn().mockResolvedValue([
58
- {
59
- score: 1,
60
- skill: { slug: 'a', displayName: 'A', summary: null, updatedAt: 1 },
61
- version: { version: '1.0.0' },
62
- },
63
- ])
64
- const runMutation = vi.fn().mockResolvedValue(okRate())
65
- const response = await __handlers.searchSkillsV1Handler(
66
- makeCtx({ runAction, runMutation }),
67
- new Request('https://example.com/api/v1/search?q=test&limit=5&highlightedOnly=true'),
68
- )
69
- if (response.status !== 200) {
70
- throw new Error(await response.text())
71
- }
72
- expect(runAction).toHaveBeenCalledWith(expect.anything(), {
73
- query: 'test',
74
- limit: 5,
75
- highlightedOnly: true,
76
- })
77
- })
78
-
79
- it('search rate limits', async () => {
80
- const runMutation = vi.fn().mockResolvedValue(blockedRate())
81
- const response = await __handlers.searchSkillsV1Handler(
82
- makeCtx({ runAction: vi.fn(), runMutation }),
83
- new Request('https://example.com/api/v1/search?q=test'),
84
- )
85
- expect(response.status).toBe(429)
86
- })
87
-
88
- it('resolve validates hash', async () => {
89
- const runMutation = vi.fn().mockResolvedValue(okRate())
90
- const response = await __handlers.resolveSkillVersionV1Handler(
91
- makeCtx({ runQuery: vi.fn(), runMutation }),
92
- new Request('https://example.com/api/v1/resolve?slug=demo&hash=bad'),
93
- )
94
- expect(response.status).toBe(400)
95
- })
96
-
97
- it('resolve returns 404 when missing', async () => {
98
- const runQuery = vi.fn().mockResolvedValue(null)
99
- const runMutation = vi.fn().mockResolvedValue(okRate())
100
- const response = await __handlers.resolveSkillVersionV1Handler(
101
- makeCtx({ runQuery, runMutation }),
102
- new Request(
103
- 'https://example.com/api/v1/resolve?slug=demo&hash=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
104
- ),
105
- )
106
- expect(response.status).toBe(404)
107
- })
108
-
109
- it('resolve returns match and latestVersion', async () => {
110
- const runQuery = vi.fn().mockResolvedValue({
111
- match: { version: '1.0.0' },
112
- latestVersion: { version: '2.0.0' },
113
- })
114
- const runMutation = vi.fn().mockResolvedValue(okRate())
115
- const response = await __handlers.resolveSkillVersionV1Handler(
116
- makeCtx({ runQuery, runMutation }),
117
- new Request(
118
- 'https://example.com/api/v1/resolve?slug=demo&hash=aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa',
119
- ),
120
- )
121
- expect(response.status).toBe(200)
122
- const json = await response.json()
123
- expect(json.match.version).toBe('1.0.0')
124
- })
125
-
126
- it('lists skills with resolved tags', async () => {
127
- const runQuery = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
128
- if ('cursor' in args || 'limit' in args) {
129
- return {
130
- items: [
131
- {
132
- skill: {
133
- _id: 'skills:1',
134
- slug: 'demo',
135
- displayName: 'Demo',
136
- summary: 's',
137
- tags: { latest: 'versions:1' },
138
- stats: { downloads: 0, stars: 0, versions: 1, comments: 0 },
139
- createdAt: 1,
140
- updatedAt: 2,
141
- },
142
- latestVersion: { version: '1.0.0', createdAt: 3, changelog: 'c' },
143
- },
144
- ],
145
- nextCursor: null,
146
- }
147
- }
148
- if ('versionId' in args) return { version: '1.0.0' }
149
- return null
150
- })
151
- const runMutation = vi.fn().mockResolvedValue(okRate())
152
- const response = await __handlers.listSkillsV1Handler(
153
- makeCtx({ runQuery, runMutation }),
154
- new Request('https://example.com/api/v1/skills?limit=1'),
155
- )
156
- expect(response.status).toBe(200)
157
- const json = await response.json()
158
- expect(json.items[0].tags.latest).toBe('1.0.0')
159
- })
160
-
161
- it('lists skills supports sort aliases', async () => {
162
- const checks: Array<[string, string]> = [
163
- ['rating', 'stars'],
164
- ['installs', 'installsCurrent'],
165
- ['installs-all-time', 'installsAllTime'],
166
- ['trending', 'trending'],
167
- ]
168
-
169
- for (const [input, expected] of checks) {
170
- const runQuery = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
171
- if ('sort' in args || 'cursor' in args || 'limit' in args) {
172
- expect(args.sort).toBe(expected)
173
- return { items: [], nextCursor: null }
174
- }
175
- return null
176
- })
177
- const runMutation = vi.fn().mockResolvedValue(okRate())
178
- const response = await __handlers.listSkillsV1Handler(
179
- makeCtx({ runQuery, runMutation }),
180
- new Request(`https://example.com/api/v1/skills?sort=${input}`),
181
- )
182
- expect(response.status).toBe(200)
183
- }
184
- })
185
-
186
- it('get skill returns 404 when missing', async () => {
187
- const runQuery = vi.fn().mockResolvedValue(null)
188
- const runMutation = vi.fn().mockResolvedValue(okRate())
189
- const response = await __handlers.skillsGetRouterV1Handler(
190
- makeCtx({ runQuery, runMutation }),
191
- new Request('https://example.com/api/v1/skills/missing'),
192
- )
193
- expect(response.status).toBe(404)
194
- })
195
-
196
- it('get skill returns payload', async () => {
197
- const runQuery = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
198
- if ('slug' in args) {
199
- return {
200
- skill: {
201
- _id: 'skills:1',
202
- slug: 'demo',
203
- displayName: 'Demo',
204
- summary: 's',
205
- tags: { latest: 'versions:1' },
206
- stats: { downloads: 0, stars: 0, versions: 1, comments: 0 },
207
- createdAt: 1,
208
- updatedAt: 2,
209
- },
210
- latestVersion: {
211
- version: '1.0.0',
212
- createdAt: 3,
213
- changelog: 'c',
214
- files: [],
215
- },
216
- owner: { handle: 'p', displayName: 'Peter', image: null },
217
- }
218
- }
219
- if ('versionId' in args) return { version: '1.0.0' }
220
- return null
221
- })
222
- const runMutation = vi.fn().mockResolvedValue(okRate())
223
- const response = await __handlers.skillsGetRouterV1Handler(
224
- makeCtx({ runQuery, runMutation }),
225
- new Request('https://example.com/api/v1/skills/demo'),
226
- )
227
- expect(response.status).toBe(200)
228
- const json = await response.json()
229
- expect(json.skill.slug).toBe('demo')
230
- expect(json.latestVersion.version).toBe('1.0.0')
231
- })
232
-
233
- it('lists versions', async () => {
234
- const runQuery = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
235
- if ('slug' in args) {
236
- return { _id: 'skills:1', slug: 'demo', displayName: 'Demo' }
237
- }
238
- if ('skillId' in args && 'cursor' in args) {
239
- return {
240
- items: [
241
- {
242
- version: '1.0.0',
243
- createdAt: 1,
244
- changelog: 'c',
245
- changelogSource: 'user',
246
- files: [],
247
- },
248
- ],
249
- nextCursor: null,
250
- }
251
- }
252
- return null
253
- })
254
- const runMutation = vi.fn().mockResolvedValue(okRate())
255
- const response = await __handlers.skillsGetRouterV1Handler(
256
- makeCtx({ runQuery, runMutation }),
257
- new Request('https://example.com/api/v1/skills/demo/versions?limit=1'),
258
- )
259
- expect(response.status).toBe(200)
260
- const json = await response.json()
261
- expect(json.items[0].version).toBe('1.0.0')
262
- })
263
-
264
- it('returns version detail', async () => {
265
- const runQuery = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
266
- if ('slug' in args) {
267
- return { _id: 'skills:1', slug: 'demo', displayName: 'Demo' }
268
- }
269
- if ('skillId' in args && 'version' in args) {
270
- return {
271
- version: '1.0.0',
272
- createdAt: 1,
273
- changelog: 'c',
274
- changelogSource: 'auto',
275
- files: [
276
- {
277
- path: 'SKILL.md',
278
- size: 1,
279
- storageId: 'storage:1',
280
- sha256: 'abc',
281
- contentType: 'text/plain',
282
- },
283
- ],
284
- }
285
- }
286
- return null
287
- })
288
- const runMutation = vi.fn().mockResolvedValue(okRate())
289
- const response = await __handlers.skillsGetRouterV1Handler(
290
- makeCtx({ runQuery, runMutation }),
291
- new Request('https://example.com/api/v1/skills/demo/versions/1.0.0'),
292
- )
293
- expect(response.status).toBe(200)
294
- const json = await response.json()
295
- expect(json.version.files[0].path).toBe('SKILL.md')
296
- })
297
-
298
- it('returns raw file content', async () => {
299
- const version = {
300
- version: '1.0.0',
301
- createdAt: 1,
302
- changelog: 'c',
303
- files: [
304
- {
305
- path: 'SKILL.md',
306
- size: 5,
307
- storageId: 'storage:1',
308
- sha256: 'abcd',
309
- contentType: 'text/plain',
310
- },
311
- ],
312
- softDeletedAt: undefined,
313
- }
314
- const runQuery = vi.fn().mockResolvedValue({
315
- skill: {
316
- _id: 'skills:1',
317
- slug: 'demo',
318
- displayName: 'Demo',
319
- summary: 's',
320
- tags: {},
321
- stats: {},
322
- createdAt: 1,
323
- updatedAt: 2,
324
- },
325
- latestVersion: version,
326
- owner: null,
327
- })
328
- const runMutation = vi.fn().mockResolvedValue(okRate())
329
- const storage = {
330
- get: vi.fn().mockResolvedValue(new Blob(['hello'], { type: 'text/plain' })),
331
- }
332
- const response = await __handlers.skillsGetRouterV1Handler(
333
- makeCtx({ runQuery, runMutation, storage }),
334
- new Request('https://example.com/api/v1/skills/demo/file?path=SKILL.md'),
335
- )
336
- expect(response.status).toBe(200)
337
- expect(await response.text()).toBe('hello')
338
- expect(response.headers.get('X-Content-SHA256')).toBe('abcd')
339
- })
340
-
341
- it('returns 413 when raw file too large', async () => {
342
- const version = {
343
- version: '1.0.0',
344
- createdAt: 1,
345
- changelog: 'c',
346
- files: [
347
- {
348
- path: 'SKILL.md',
349
- size: 210 * 1024,
350
- storageId: 'storage:1',
351
- sha256: 'abcd',
352
- contentType: 'text/plain',
353
- },
354
- ],
355
- softDeletedAt: undefined,
356
- }
357
- const runQuery = vi.fn().mockResolvedValue({
358
- skill: {
359
- _id: 'skills:1',
360
- slug: 'demo',
361
- displayName: 'Demo',
362
- summary: 's',
363
- tags: {},
364
- stats: {},
365
- createdAt: 1,
366
- updatedAt: 2,
367
- },
368
- latestVersion: version,
369
- owner: null,
370
- })
371
- const runMutation = vi.fn().mockResolvedValue(okRate())
372
- const response = await __handlers.skillsGetRouterV1Handler(
373
- makeCtx({ runQuery, runMutation, storage: { get: vi.fn() } }),
374
- new Request('https://example.com/api/v1/skills/demo/file?path=SKILL.md'),
375
- )
376
- expect(response.status).toBe(413)
377
- })
378
-
379
- it('publish json succeeds', async () => {
380
- vi.mocked(requireApiTokenUser).mockResolvedValueOnce({
381
- userId: 'users:1',
382
- user: { handle: 'p' },
383
- } as never)
384
- vi.mocked(publishVersionForUser).mockResolvedValueOnce({
385
- skillId: 's',
386
- versionId: 'v',
387
- embeddingId: 'e',
388
- } as never)
389
- const runMutation = vi.fn().mockResolvedValue(okRate())
390
- const body = JSON.stringify({
391
- slug: 'demo',
392
- displayName: 'Demo',
393
- version: '1.0.0',
394
- changelog: 'c',
395
- files: [
396
- {
397
- path: 'SKILL.md',
398
- size: 1,
399
- storageId: 'storage:1',
400
- sha256: 'abc',
401
- contentType: 'text/plain',
402
- },
403
- ],
404
- })
405
- const response = await __handlers.publishSkillV1Handler(
406
- makeCtx({ runMutation }),
407
- new Request('https://example.com/api/v1/skills', {
408
- method: 'POST',
409
- headers: { 'Content-Type': 'application/json', Authorization: 'Bearer clh_test' },
410
- body,
411
- }),
412
- )
413
- expect(response.status).toBe(200)
414
- const json = await response.json()
415
- expect(json.ok).toBe(true)
416
- expect(publishVersionForUser).toHaveBeenCalled()
417
- })
418
-
419
- it('publish multipart succeeds', async () => {
420
- vi.mocked(requireApiTokenUser).mockResolvedValueOnce({
421
- userId: 'users:1',
422
- user: { handle: 'p' },
423
- } as never)
424
- vi.mocked(publishVersionForUser).mockResolvedValueOnce({
425
- skillId: 's',
426
- versionId: 'v',
427
- embeddingId: 'e',
428
- } as never)
429
- const runMutation = vi.fn().mockResolvedValue(okRate())
430
- const form = new FormData()
431
- form.set(
432
- 'payload',
433
- JSON.stringify({
434
- slug: 'demo',
435
- displayName: 'Demo',
436
- version: '1.0.0',
437
- changelog: '',
438
- tags: ['latest'],
439
- }),
440
- )
441
- form.append('files', new Blob(['hello'], { type: 'text/plain' }), 'SKILL.md')
442
- const response = await __handlers.publishSkillV1Handler(
443
- makeCtx({ runMutation, storage: { store: vi.fn().mockResolvedValue('storage:1') } }),
444
- new Request('https://example.com/api/v1/skills', {
445
- method: 'POST',
446
- headers: { Authorization: 'Bearer clh_test' },
447
- body: form,
448
- }),
449
- )
450
- if (response.status !== 200) {
451
- throw new Error(await response.text())
452
- }
453
- })
454
-
455
- it('publish rejects missing token', async () => {
456
- const runMutation = vi.fn().mockResolvedValue(okRate())
457
- const response = await __handlers.publishSkillV1Handler(
458
- makeCtx({ runMutation }),
459
- new Request('https://example.com/api/v1/skills', { method: 'POST' }),
460
- )
461
- expect(response.status).toBe(401)
462
- })
463
-
464
- it('whoami returns user payload', async () => {
465
- vi.mocked(requireApiTokenUser).mockResolvedValueOnce({
466
- userId: 'users:1',
467
- user: { handle: 'p', displayName: 'Peter', image: null },
468
- } as never)
469
- const runMutation = vi.fn().mockResolvedValue(okRate())
470
- const response = await __handlers.whoamiV1Handler(
471
- makeCtx({ runMutation }),
472
- new Request('https://example.com/api/v1/whoami', {
473
- headers: { Authorization: 'Bearer clh_test' },
474
- }),
475
- )
476
- expect(response.status).toBe(200)
477
- const json = await response.json()
478
- expect(json.user.handle).toBe('p')
479
- })
480
-
481
- it('delete and undelete require auth', async () => {
482
- vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
483
- const runMutation = vi.fn().mockResolvedValue(okRate())
484
- const response = await __handlers.skillsDeleteRouterV1Handler(
485
- makeCtx({ runMutation }),
486
- new Request('https://example.com/api/v1/skills/demo', { method: 'DELETE' }),
487
- )
488
- expect(response.status).toBe(401)
489
-
490
- vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
491
- const response2 = await __handlers.skillsPostRouterV1Handler(
492
- makeCtx({ runMutation }),
493
- new Request('https://example.com/api/v1/skills/demo/undelete', { method: 'POST' }),
494
- )
495
- expect(response2.status).toBe(401)
496
- })
497
-
498
- it('delete and undelete succeed', async () => {
499
- vi.mocked(requireApiTokenUser).mockResolvedValue({
500
- userId: 'users:1',
501
- user: { handle: 'p' },
502
- } as never)
503
- const runMutation = vi.fn(async (_query: unknown, args: Record<string, unknown>) => {
504
- if ('key' in args) return okRate()
505
- return { ok: true }
506
- })
507
-
508
- const response = await __handlers.skillsDeleteRouterV1Handler(
509
- makeCtx({ runMutation }),
510
- new Request('https://example.com/api/v1/skills/demo', {
511
- method: 'DELETE',
512
- headers: { Authorization: 'Bearer clh_test' },
513
- }),
514
- )
515
- expect(response.status).toBe(200)
516
-
517
- const response2 = await __handlers.skillsPostRouterV1Handler(
518
- makeCtx({ runMutation }),
519
- new Request('https://example.com/api/v1/skills/demo/undelete', {
520
- method: 'POST',
521
- headers: { Authorization: 'Bearer clh_test' },
522
- }),
523
- )
524
- expect(response2.status).toBe(200)
525
- })
526
-
527
- it('stars require auth', async () => {
528
- vi.mocked(requireApiTokenUser).mockRejectedValueOnce(new Error('Unauthorized'))
529
- const runMutation = vi.fn().mockResolvedValue(okRate())
530
- const response = await __handlers.starsPostRouterV1Handler(
531
- makeCtx({ runMutation }),
532
- new Request('https://example.com/api/v1/stars/demo', { method: 'POST' }),
533
- )
534
- expect(response.status).toBe(401)
535
- })
536
-
537
- it('stars add succeeds', async () => {
538
- vi.mocked(requireApiTokenUser).mockResolvedValue({
539
- userId: 'users:1',
540
- user: { handle: 'p' },
541
- } as never)
542
- const runQuery = vi.fn().mockResolvedValue({ _id: 'skills:1' })
543
- const runMutation = vi
544
- .fn()
545
- .mockResolvedValueOnce(okRate())
546
- .mockResolvedValueOnce(okRate())
547
- .mockResolvedValueOnce({ ok: true, starred: true, alreadyStarred: false })
548
- const response = await __handlers.starsPostRouterV1Handler(
549
- makeCtx({ runQuery, runMutation }),
550
- new Request('https://example.com/api/v1/stars/demo', {
551
- method: 'POST',
552
- headers: { Authorization: 'Bearer clh_test' },
553
- }),
554
- )
555
- expect(response.status).toBe(200)
556
- const json = await response.json()
557
- expect(json.ok).toBe(true)
558
- expect(json.starred).toBe(true)
559
- })
560
-
561
- it('stars delete succeeds', async () => {
562
- vi.mocked(requireApiTokenUser).mockResolvedValue({
563
- userId: 'users:1',
564
- user: { handle: 'p' },
565
- } as never)
566
- const runQuery = vi.fn().mockResolvedValue({ _id: 'skills:1' })
567
- const runMutation = vi
568
- .fn()
569
- .mockResolvedValueOnce(okRate())
570
- .mockResolvedValueOnce(okRate())
571
- .mockResolvedValueOnce({ ok: true, unstarred: true, alreadyUnstarred: false })
572
- const response = await __handlers.starsDeleteRouterV1Handler(
573
- makeCtx({ runQuery, runMutation }),
574
- new Request('https://example.com/api/v1/stars/demo', {
575
- method: 'DELETE',
576
- headers: { Authorization: 'Bearer clh_test' },
577
- }),
578
- )
579
- expect(response.status).toBe(200)
580
- const json = await response.json()
581
- expect(json.ok).toBe(true)
582
- expect(json.unstarred).toBe(true)
583
- })
584
- })