jishushell 0.6.18 → 0.7.3

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 (343) hide show
  1. package/apps/anythingllm-container.yaml +1 -0
  2. package/apps/browserless-chromium-container.yaml +1 -0
  3. package/apps/filebrowser-container.yaml +1 -0
  4. package/apps/hermes-container.yaml +1 -7
  5. package/apps/immich-container-lite.yaml +337 -0
  6. package/apps/immich-container.yaml +371 -0
  7. package/apps/jishu-kb-container.yaml +26 -21
  8. package/apps/ollama-binary.yaml +1 -0
  9. package/apps/ollama-cpu-container.yaml +1 -0
  10. package/apps/ollama-with-hollama-binary.yaml +2 -0
  11. package/apps/openclaw-binary.yaml +4 -8
  12. package/apps/openclaw-container.yaml +1 -7
  13. package/apps/openclaw-with-ollama-container.yaml +1 -0
  14. package/apps/openclaw-with-searxng-container.yaml +20 -0
  15. package/apps/searxng-container.yaml +20 -0
  16. package/apps/weknora-container.yaml +5 -0
  17. package/dependencies/jishushell-panel-0.7.3.tgz +0 -0
  18. package/dist/cli/core.js +1 -1
  19. package/dist/cli/core.js.map +1 -1
  20. package/dist/cli/doctor.js +96 -0
  21. package/dist/cli/doctor.js.map +1 -1
  22. package/dist/config.d.ts +9 -1
  23. package/dist/config.js +72 -2
  24. package/dist/config.js.map +1 -1
  25. package/dist/install.js +60 -19
  26. package/dist/install.js.map +1 -1
  27. package/dist/routes/admin.d.ts +2 -0
  28. package/dist/routes/admin.js +72 -0
  29. package/dist/routes/admin.js.map +1 -0
  30. package/dist/routes/docker.d.ts +2 -0
  31. package/dist/routes/docker.js +58 -0
  32. package/dist/routes/docker.js.map +1 -0
  33. package/dist/routes/file-mounts.js +5 -8
  34. package/dist/routes/file-mounts.js.map +1 -1
  35. package/dist/routes/instances.d.ts +0 -14
  36. package/dist/routes/instances.js +44 -1184
  37. package/dist/routes/instances.js.map +1 -1
  38. package/dist/server.d.ts +6 -0
  39. package/dist/server.js +53 -20
  40. package/dist/server.js.map +1 -1
  41. package/dist/services/app-common/catalog-service.js +15 -5
  42. package/dist/services/app-common/catalog-service.js.map +1 -1
  43. package/dist/services/app-common/delete-service.js +5 -0
  44. package/dist/services/app-common/delete-service.js.map +1 -1
  45. package/dist/services/app-common/instance-store.js +3 -0
  46. package/dist/services/app-common/instance-store.js.map +1 -1
  47. package/dist/services/app-common/lifecycle-service.js +12 -4
  48. package/dist/services/app-common/lifecycle-service.js.map +1 -1
  49. package/dist/services/app-common/ownership.d.ts +3 -0
  50. package/dist/services/app-common/ownership.js +11 -0
  51. package/dist/services/app-common/ownership.js.map +1 -0
  52. package/dist/services/app-common/runtime-facts.js +2 -0
  53. package/dist/services/app-common/runtime-facts.js.map +1 -1
  54. package/dist/services/app-common/spec-materializer.d.ts +0 -1
  55. package/dist/services/app-common/spec-materializer.js +21 -87
  56. package/dist/services/app-common/spec-materializer.js.map +1 -1
  57. package/dist/services/app-common/status-refresh.js +25 -13
  58. package/dist/services/app-common/status-refresh.js.map +1 -1
  59. package/dist/services/app-modules/browserless/routes.js +5 -3
  60. package/dist/services/app-modules/browserless/routes.js.map +1 -1
  61. package/dist/services/capabilities/contract.d.ts +1 -2
  62. package/dist/services/capabilities/contract.js +0 -10
  63. package/dist/services/capabilities/contract.js.map +1 -1
  64. package/dist/services/capabilities/endpoint-validator.js +0 -1
  65. package/dist/services/capabilities/endpoint-validator.js.map +1 -1
  66. package/dist/services/capabilities/health.js +1 -1
  67. package/dist/services/capabilities/health.js.map +1 -1
  68. package/dist/services/capability-proxy/http.d.ts +7 -0
  69. package/dist/services/capability-proxy/http.js +555 -0
  70. package/dist/services/capability-proxy/http.js.map +1 -0
  71. package/dist/services/capability-proxy/terminal.d.ts +4 -0
  72. package/dist/services/capability-proxy/terminal.js +179 -0
  73. package/dist/services/capability-proxy/terminal.js.map +1 -0
  74. package/dist/services/connections/admin.js +19 -9
  75. package/dist/services/connections/admin.js.map +1 -1
  76. package/dist/services/connections/apply.d.ts +3 -9
  77. package/dist/services/connections/apply.js +0 -29
  78. package/dist/services/connections/apply.js.map +1 -1
  79. package/dist/services/connections/transactor.js +2 -2
  80. package/dist/services/connections/transactor.js.map +1 -1
  81. package/dist/services/files/bootstrap.d.ts +7 -0
  82. package/dist/services/files/bootstrap.js +16 -0
  83. package/dist/services/files/bootstrap.js.map +1 -0
  84. package/dist/services/files/photos/upload-page.d.ts +2 -0
  85. package/dist/services/files/photos/upload-page.js +248 -0
  86. package/dist/services/files/photos/upload-page.js.map +1 -0
  87. package/dist/services/files/photos/upload-store.d.ts +74 -0
  88. package/dist/services/files/photos/upload-store.js +432 -0
  89. package/dist/services/files/photos/upload-store.js.map +1 -0
  90. package/dist/services/http/proxy-utils.d.ts +7 -0
  91. package/dist/services/http/proxy-utils.js +29 -0
  92. package/dist/services/http/proxy-utils.js.map +1 -0
  93. package/dist/services/http/request-utils.d.ts +3 -0
  94. package/dist/services/http/request-utils.js +23 -0
  95. package/dist/services/http/request-utils.js.map +1 -0
  96. package/dist/services/instances/manager.d.ts +6 -5
  97. package/dist/services/instances/manager.js +45 -51
  98. package/dist/services/instances/manager.js.map +1 -1
  99. package/dist/services/instances/pairing.d.ts +17 -0
  100. package/dist/services/instances/pairing.js +53 -0
  101. package/dist/services/instances/pairing.js.map +1 -0
  102. package/dist/services/instances/status.d.ts +2 -0
  103. package/dist/services/instances/status.js +11 -0
  104. package/dist/services/instances/status.js.map +1 -0
  105. package/dist/services/integrations/hermes/integration.d.ts +1 -1
  106. package/dist/services/integrations/hermes/integration.js +7 -8
  107. package/dist/services/integrations/hermes/integration.js.map +1 -1
  108. package/dist/services/integrations/immich/client.d.ts +93 -0
  109. package/dist/services/integrations/immich/client.js +458 -0
  110. package/dist/services/integrations/immich/client.js.map +1 -0
  111. package/dist/services/integrations/immich/config.d.ts +15 -0
  112. package/dist/services/integrations/immich/config.js +178 -0
  113. package/dist/services/integrations/immich/config.js.map +1 -0
  114. package/dist/services/integrations/immich/discovery.d.ts +9 -0
  115. package/dist/services/integrations/immich/discovery.js +101 -0
  116. package/dist/services/integrations/immich/discovery.js.map +1 -0
  117. package/dist/services/integrations/immich/gallery-renderer.d.ts +5 -0
  118. package/dist/services/integrations/immich/gallery-renderer.js +150 -0
  119. package/dist/services/integrations/immich/gallery-renderer.js.map +1 -0
  120. package/dist/services/integrations/immich/immich-shim.d.ts +11 -0
  121. package/dist/services/integrations/immich/immich-shim.js +439 -0
  122. package/dist/services/integrations/immich/immich-shim.js.map +1 -0
  123. package/dist/services/integrations/immich/integration.d.ts +18 -0
  124. package/dist/services/integrations/immich/integration.js +64 -0
  125. package/dist/services/integrations/immich/integration.js.map +1 -0
  126. package/dist/services/integrations/immich/photo-library.d.ts +4 -0
  127. package/dist/services/integrations/immich/photo-library.js +63 -0
  128. package/dist/services/integrations/immich/photo-library.js.map +1 -0
  129. package/dist/services/integrations/immich/review-executor.d.ts +3 -0
  130. package/dist/services/integrations/immich/review-executor.js +41 -0
  131. package/dist/services/integrations/immich/review-executor.js.map +1 -0
  132. package/dist/services/integrations/immich/review-session-service.d.ts +27 -0
  133. package/dist/services/integrations/immich/review-session-service.js +206 -0
  134. package/dist/services/integrations/immich/review-session-service.js.map +1 -0
  135. package/dist/services/integrations/immich/review-store.d.ts +47 -0
  136. package/dist/services/integrations/immich/review-store.js +347 -0
  137. package/dist/services/integrations/immich/review-store.js.map +1 -0
  138. package/dist/services/integrations/immich/routes.d.ts +7 -0
  139. package/dist/services/integrations/immich/routes.js +363 -0
  140. package/dist/services/integrations/immich/routes.js.map +1 -0
  141. package/dist/services/integrations/immich/types.d.ts +186 -0
  142. package/dist/services/integrations/immich/types.js +2 -0
  143. package/dist/services/integrations/immich/types.js.map +1 -0
  144. package/dist/services/integrations/index.d.ts +1 -0
  145. package/dist/services/integrations/index.js +1 -0
  146. package/dist/services/integrations/index.js.map +1 -1
  147. package/dist/services/integrations/installable/installers/integration.js +113 -7
  148. package/dist/services/integrations/installable/installers/integration.js.map +1 -1
  149. package/dist/services/integrations/jishukb/integration.d.ts +3 -1
  150. package/dist/services/integrations/jishukb/integration.js +121 -10
  151. package/dist/services/integrations/jishukb/integration.js.map +1 -1
  152. package/dist/services/integrations/openclaw/integration.d.ts +21 -7
  153. package/dist/services/integrations/openclaw/integration.js +385 -158
  154. package/dist/services/integrations/openclaw/integration.js.map +1 -1
  155. package/dist/services/integrations/openclaw/jishukb-native-mcp.d.ts +58 -0
  156. package/dist/services/integrations/openclaw/jishukb-native-mcp.js +373 -0
  157. package/dist/services/integrations/openclaw/jishukb-native-mcp.js.map +1 -0
  158. package/dist/services/integrations/openclaw/jishukb-shim.d.ts +8 -4
  159. package/dist/services/integrations/openclaw/jishukb-shim.js +624 -17
  160. package/dist/services/integrations/openclaw/jishukb-shim.js.map +1 -1
  161. package/dist/services/integrations/openclaw/mcporter.d.ts +13 -0
  162. package/dist/services/integrations/openclaw/mcporter.js +31 -0
  163. package/dist/services/integrations/openclaw/mcporter.js.map +1 -1
  164. package/dist/services/integrations/openclaw/native-mcp.d.ts +48 -0
  165. package/dist/services/integrations/openclaw/native-mcp.js +125 -0
  166. package/dist/services/integrations/openclaw/native-mcp.js.map +1 -0
  167. package/dist/services/integrations/openclaw/routes.js +4 -1
  168. package/dist/services/integrations/openclaw/routes.js.map +1 -1
  169. package/dist/services/integrations/types.d.ts +5 -17
  170. package/dist/services/repair/runtime-repair.js +68 -1
  171. package/dist/services/repair/runtime-repair.js.map +1 -1
  172. package/dist/services/runtime/docker-network.d.ts +8 -0
  173. package/dist/services/runtime/docker-network.js +123 -0
  174. package/dist/services/runtime/docker-network.js.map +1 -0
  175. package/dist/services/runtime/driver-registry.d.ts +4 -0
  176. package/dist/services/runtime/driver-registry.js.map +1 -1
  177. package/dist/services/runtime/drivers/nomad.d.ts +1 -0
  178. package/dist/services/runtime/drivers/nomad.js +35 -5
  179. package/dist/services/runtime/drivers/nomad.js.map +1 -1
  180. package/dist/services/runtime/service-manager.d.ts +2 -0
  181. package/dist/services/runtime/service-manager.js +18 -0
  182. package/dist/services/runtime/service-manager.js.map +1 -0
  183. package/dist/services/runtime/types.d.ts +1 -0
  184. package/dist/services/runtime/workload-compiler.js +29 -4
  185. package/dist/services/runtime/workload-compiler.js.map +1 -1
  186. package/dist/services/setup/setup-manager.js +29 -73
  187. package/dist/services/setup/setup-manager.js.map +1 -1
  188. package/dist/services/system/runtime-ownership.d.ts +36 -0
  189. package/dist/services/system/runtime-ownership.js +250 -0
  190. package/dist/services/system/runtime-ownership.js.map +1 -0
  191. package/dist/services/system/system-reconciler.js +53 -0
  192. package/dist/services/system/system-reconciler.js.map +1 -1
  193. package/dist/types.d.ts +19 -3
  194. package/dist/utils/path-safety.js +1 -1
  195. package/dist/utils/service-user.d.ts +13 -0
  196. package/dist/utils/service-user.js +129 -0
  197. package/dist/utils/service-user.js.map +1 -0
  198. package/install/jishu-install.sh +0 -1
  199. package/node_modules/brace-expansion/dist/commonjs/index.js +24 -14
  200. package/node_modules/brace-expansion/dist/commonjs/index.js.map +1 -1
  201. package/node_modules/brace-expansion/dist/esm/index.js +24 -14
  202. package/node_modules/brace-expansion/dist/esm/index.js.map +1 -1
  203. package/node_modules/brace-expansion/package.json +2 -2
  204. package/node_modules/fast-uri/index.js +1 -1
  205. package/node_modules/fast-uri/package.json +1 -1
  206. package/node_modules/fast-uri/test/security.test.js +28 -0
  207. package/node_modules/fastify/SECURITY.md +1 -1
  208. package/node_modules/fastify/SPONSORS.md +6 -4
  209. package/node_modules/fastify/docs/Guides/Database.md +0 -28
  210. package/node_modules/fastify/docs/Guides/Ecosystem.md +13 -2
  211. package/node_modules/fastify/docs/Guides/Serverless.md +2 -2
  212. package/node_modules/fastify/docs/Guides/Write-Plugin.md +1 -1
  213. package/node_modules/fastify/docs/Reference/Encapsulation.md +27 -26
  214. package/node_modules/fastify/docs/Reference/Errors.md +10 -4
  215. package/node_modules/fastify/docs/Reference/HTTP2.md +10 -10
  216. package/node_modules/fastify/docs/Reference/Hooks.md +4 -4
  217. package/node_modules/fastify/docs/Reference/Index.md +14 -16
  218. package/node_modules/fastify/docs/Reference/LTS.md +12 -13
  219. package/node_modules/fastify/docs/Reference/Lifecycle.md +9 -8
  220. package/node_modules/fastify/docs/Reference/Logging.md +44 -39
  221. package/node_modules/fastify/docs/Reference/Middleware.md +21 -25
  222. package/node_modules/fastify/docs/Reference/Principles.md +2 -2
  223. package/node_modules/fastify/docs/Reference/Reply.md +6 -1
  224. package/node_modules/fastify/docs/Reference/Request.md +27 -16
  225. package/node_modules/fastify/docs/Reference/Routes.md +5 -2
  226. package/node_modules/fastify/docs/Reference/Server.md +31 -3
  227. package/node_modules/fastify/docs/Reference/Type-Providers.md +29 -5
  228. package/node_modules/fastify/docs/Reference/Validation-and-Serialization.md +15 -2
  229. package/node_modules/fastify/docs/Reference/Warnings.md +7 -6
  230. package/node_modules/fastify/eslint.config.js +7 -2
  231. package/node_modules/fastify/fastify.d.ts +8 -3
  232. package/node_modules/fastify/fastify.js +43 -14
  233. package/node_modules/fastify/lib/content-type-parser.js +13 -1
  234. package/node_modules/fastify/lib/decorate.js +11 -3
  235. package/node_modules/fastify/lib/error-handler.js +4 -3
  236. package/node_modules/fastify/lib/error-serializer.js +59 -59
  237. package/node_modules/fastify/lib/errors.js +16 -1
  238. package/node_modules/fastify/lib/four-oh-four.js +14 -9
  239. package/node_modules/fastify/lib/handle-request.js +11 -5
  240. package/node_modules/fastify/lib/plugin-override.js +2 -1
  241. package/node_modules/fastify/lib/plugin-utils.js +5 -5
  242. package/node_modules/fastify/lib/reply.js +63 -8
  243. package/node_modules/fastify/lib/request.js +14 -4
  244. package/node_modules/fastify/lib/route.js +20 -6
  245. package/node_modules/fastify/lib/schema-controller.js +1 -1
  246. package/node_modules/fastify/lib/schemas.js +37 -30
  247. package/node_modules/fastify/lib/symbols.js +3 -1
  248. package/node_modules/fastify/lib/validation.js +1 -13
  249. package/node_modules/fastify/lib/warnings.js +3 -3
  250. package/node_modules/fastify/package.json +13 -15
  251. package/node_modules/fastify/scripts/validate-ecosystem-links.js +1 -0
  252. package/node_modules/fastify/test/bundler/esbuild/package.json +1 -1
  253. package/node_modules/fastify/test/close-pipelining.test.js +1 -2
  254. package/node_modules/fastify/test/custom-http-server.test.js +38 -0
  255. package/node_modules/fastify/test/decorator-instance-properties.test.js +63 -0
  256. package/node_modules/fastify/test/diagnostics-channel/async-error-handler.test.js +74 -0
  257. package/node_modules/fastify/test/hooks.test.js +23 -0
  258. package/node_modules/fastify/test/http-methods/get.test.js +1 -1
  259. package/node_modules/fastify/test/http2/plain.test.js +135 -0
  260. package/node_modules/fastify/test/http2/secure-with-fallback.test.js +1 -1
  261. package/node_modules/fastify/test/https/https.test.js +1 -2
  262. package/node_modules/fastify/test/internals/errors.test.js +31 -1
  263. package/node_modules/fastify/test/internals/plugin.test.js +3 -1
  264. package/node_modules/fastify/test/internals/request.test.js +27 -3
  265. package/node_modules/fastify/test/internals/schema-controller-perf.test.js +33 -0
  266. package/node_modules/fastify/test/logger/logging.test.js +18 -1
  267. package/node_modules/fastify/test/logger/options.test.js +38 -1
  268. package/node_modules/fastify/test/reply-error.test.js +1 -1
  269. package/node_modules/fastify/test/reply-trailers.test.js +70 -0
  270. package/node_modules/fastify/test/request-media-type.test.js +105 -0
  271. package/node_modules/fastify/test/route-prefix.test.js +34 -0
  272. package/node_modules/fastify/test/router-options.test.js +222 -11
  273. package/node_modules/fastify/test/schema-serialization.test.js +108 -0
  274. package/node_modules/fastify/test/schema-validation.test.js +24 -0
  275. package/node_modules/fastify/test/scripts/validate-ecosystem-links.test.js +40 -57
  276. package/node_modules/fastify/test/throw.test.js +14 -0
  277. package/node_modules/fastify/test/trust-proxy.test.js +21 -0
  278. package/node_modules/fastify/test/types/content-type-parser.tst.ts +70 -0
  279. package/node_modules/fastify/test/types/{decorate-request-reply.test-d.ts → decorate-request-reply.tst.ts} +4 -4
  280. package/node_modules/fastify/test/types/{dummy-plugin.ts → dummy-plugin.mts} +1 -1
  281. package/node_modules/fastify/test/types/errors.tst.ts +91 -0
  282. package/node_modules/fastify/test/types/fastify.tst.ts +351 -0
  283. package/node_modules/fastify/test/types/hooks.tst.ts +578 -0
  284. package/node_modules/fastify/test/types/instance.tst.ts +597 -0
  285. package/node_modules/fastify/test/types/{logger.test-d.ts → logger.tst.ts} +61 -62
  286. package/node_modules/fastify/test/types/plugin.tst.ts +96 -0
  287. package/node_modules/fastify/test/types/register.tst.ts +245 -0
  288. package/node_modules/fastify/test/types/reply.tst.ts +297 -0
  289. package/node_modules/fastify/test/types/request.tst.ts +199 -0
  290. package/node_modules/fastify/test/types/route.tst.ts +576 -0
  291. package/node_modules/fastify/test/types/{schema.test-d.ts → schema.tst.ts} +22 -22
  292. package/node_modules/fastify/test/types/{serverFactory.test-d.ts → serverFactory.tst.ts} +4 -4
  293. package/node_modules/fastify/test/types/tsconfig.json +9 -0
  294. package/node_modules/fastify/test/types/{type-provider.test-d.ts → type-provider.tst.ts} +256 -250
  295. package/node_modules/fastify/test/types/using.tst.ts +14 -0
  296. package/node_modules/fastify/types/errors.d.ts +3 -0
  297. package/node_modules/fastify/types/request.d.ts +23 -2
  298. package/node_modules/jishushell-panel/output/public/assets/{ApiKeyField-NKcbHjNz.js → ApiKeyField-Ce5d1xna.js} +1 -1
  299. package/node_modules/jishushell-panel/output/public/assets/{Dashboard-Da1fL38t.js → Dashboard-BXame3yg.js} +1 -1
  300. package/node_modules/jishushell-panel/output/public/assets/{HermesChatPanel-DZvmYsoh.js → HermesChatPanel-BHZtPCJd.js} +1 -1
  301. package/node_modules/jishushell-panel/output/public/assets/{HermesConfigForm-BLUWlKwm.js → HermesConfigForm-CB3GbNX9.js} +1 -1
  302. package/node_modules/jishushell-panel/output/public/assets/{InitPassword-BAKsshzk.js → InitPassword-Boab9F6g.js} +1 -1
  303. package/node_modules/jishushell-panel/output/public/assets/InstanceDetail-DrIWCqo-.js +14 -0
  304. package/node_modules/jishushell-panel/output/public/assets/{Login-DHeOmwI8.js → Login-CzpOkNau.js} +1 -1
  305. package/node_modules/jishushell-panel/output/public/assets/NewInstance-CANXyCcL.js +1 -0
  306. package/node_modules/jishushell-panel/output/public/assets/{ProviderRecommendations-H0ByEYF0.js → ProviderRecommendations-BABo9VOC.js} +1 -1
  307. package/node_modules/jishushell-panel/output/public/assets/Settings-CKp5XxFh.js +1 -0
  308. package/node_modules/jishushell-panel/output/public/assets/Setup-C7xVDPow.js +1 -0
  309. package/node_modules/jishushell-panel/output/public/assets/{WeixinLoginPanel-D-T6BxkQ.js → WeixinLoginPanel-B765Xz4C.js} +1 -1
  310. package/node_modules/jishushell-panel/output/public/assets/{index-ERt6_ngA.js → index-Bs6DSbiR.js} +6 -6
  311. package/node_modules/jishushell-panel/output/public/assets/{registry-DF93EzIb.js → registry-sWIZsIEF.js} +2 -2
  312. package/node_modules/jishushell-panel/output/public/assets/{usePolling-DeoThIQn.js → usePolling-D4IDOQd_.js} +1 -1
  313. package/node_modules/jishushell-panel/output/public/assets/vendor-i18n-Df8aUdv8.js +1 -0
  314. package/node_modules/jishushell-panel/output/public/assets/{vendor-react-Cc84NArf.js → vendor-react-0L0rjmYG.js} +3 -3
  315. package/node_modules/jishushell-panel/output/public/index.html +3 -3
  316. package/node_modules/jishushell-panel/package.json +1 -1
  317. package/node_modules/semver/classes/range.js +6 -2
  318. package/node_modules/semver/package.json +1 -1
  319. package/package.json +4 -4
  320. package/scripts/check-app-spec.mjs +4 -12
  321. package/scripts/check-architecture-boundaries.mjs +178 -0
  322. package/scripts/pack-gui-and-send-pi.sh +5 -3
  323. package/dependencies/jishushell-panel-0.6.18.tgz +0 -0
  324. package/dist/services/connections/suggestions.d.ts +0 -27
  325. package/dist/services/connections/suggestions.js +0 -124
  326. package/dist/services/connections/suggestions.js.map +0 -1
  327. package/node_modules/fastify/test/types/content-type-parser.test-d.ts +0 -72
  328. package/node_modules/fastify/test/types/errors.test-d.ts +0 -90
  329. package/node_modules/fastify/test/types/fastify.test-d.ts +0 -352
  330. package/node_modules/fastify/test/types/hooks.test-d.ts +0 -550
  331. package/node_modules/fastify/test/types/import.ts +0 -2
  332. package/node_modules/fastify/test/types/instance.test-d.ts +0 -588
  333. package/node_modules/fastify/test/types/plugin.test-d.ts +0 -97
  334. package/node_modules/fastify/test/types/register.test-d.ts +0 -237
  335. package/node_modules/fastify/test/types/reply.test-d.ts +0 -254
  336. package/node_modules/fastify/test/types/request.test-d.ts +0 -188
  337. package/node_modules/fastify/test/types/route.test-d.ts +0 -553
  338. package/node_modules/fastify/test/types/using.test-d.ts +0 -17
  339. package/node_modules/jishushell-panel/output/public/assets/InstanceDetail-Dgyc_TX5.js +0 -14
  340. package/node_modules/jishushell-panel/output/public/assets/NewInstance-CIy0cYtp.js +0 -1
  341. package/node_modules/jishushell-panel/output/public/assets/Settings-DAT-UMfP.js +0 -1
  342. package/node_modules/jishushell-panel/output/public/assets/Setup-g3uckFYR.js +0 -1
  343. package/node_modules/jishushell-panel/output/public/assets/vendor-i18n-CS8DFbkQ.js +0 -1
@@ -1,39 +1,40 @@
1
1
  import * as fs from 'node:fs'
2
2
  import { IncomingMessage, Server, ServerResponse } from 'node:http'
3
3
  import P from 'pino'
4
- import { expectAssignable, expectDeprecated, expectError, expectNotAssignable, expectType } from 'tsd'
4
+ import { expect } from 'tstyche'
5
5
  import fastify, {
6
6
  FastifyBaseLogger,
7
+ FastifyError,
7
8
  FastifyLogFn,
8
9
  FastifyReply,
9
10
  FastifyRequest,
10
11
  LogLevel
11
- } from '../../fastify'
12
- import { FastifyLoggerInstance, ResSerializerReply } from '../../types/logger'
12
+ } from '../../fastify.js'
13
+ import { ResSerializerReply } from '../../types/logger.js'
13
14
 
14
- expectType<FastifyBaseLogger>(fastify().log)
15
+ expect(fastify().log).type.toBe<FastifyBaseLogger>()
15
16
 
16
17
  class Foo { }
17
18
 
18
19
  ['trace', 'debug', 'info', 'warn', 'error', 'fatal'].forEach(logLevel => {
19
- expectType<FastifyLogFn>(
20
+ expect(
20
21
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel]
21
- )
22
- expectType<void>(
22
+ ).type.toBe<FastifyLogFn>()
23
+ expect(
23
24
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel]('')
24
- )
25
- expectType<void>(
25
+ ).type.toBe<void>()
26
+ expect(
26
27
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel]({})
27
- )
28
- expectType<void>(
28
+ ).type.toBe<void>()
29
+ expect(
29
30
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel]({ foo: 'bar' })
30
- )
31
- expectType<void>(
31
+ ).type.toBe<void>()
32
+ expect(
32
33
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel](new Error())
33
- )
34
- expectType<void>(
34
+ ).type.toBe<void>()
35
+ expect(
35
36
  fastify<Server, IncomingMessage, ServerResponse, FastifyBaseLogger>().log[logLevel as LogLevel](new Foo())
36
- )
37
+ ).type.toBe<void>()
37
38
  })
38
39
 
39
40
  interface CustomLogger extends FastifyBaseLogger {
@@ -68,7 +69,7 @@ const serverWithCustomLogger = fastify<
68
69
  CustomLoggerImpl
69
70
  >({ logger: customLogger })
70
71
 
71
- expectType<CustomLoggerImpl>(serverWithCustomLogger.log)
72
+ expect(serverWithCustomLogger.log).type.toBe<CustomLoggerImpl>()
72
73
 
73
74
  const serverWithPino = fastify<
74
75
  Server,
@@ -82,20 +83,20 @@ const serverWithPino = fastify<
82
83
  })
83
84
  })
84
85
 
85
- expectType<P.Logger>(serverWithPino.log)
86
+ expect(serverWithPino.log).type.toBe<P.Logger>()
86
87
 
87
88
  serverWithPino.route({
88
89
  method: 'GET',
89
90
  url: '/',
90
91
  handler (request) {
91
- expectType<P.Logger>(this.log)
92
- expectType<P.Logger>(request.log)
92
+ expect(this.log).type.toBe<P.Logger>()
93
+ expect(request.log).type.toBe<P.Logger>()
93
94
  }
94
95
  })
95
96
 
96
97
  serverWithPino.get('/', function (request) {
97
- expectType<P.Logger>(this.log)
98
- expectType<P.Logger>(request.log)
98
+ expect(this.log).type.toBe<P.Logger>()
99
+ expect(request.log).type.toBe<P.Logger>()
99
100
  })
100
101
 
101
102
  const serverWithLogOptions = fastify<
@@ -108,7 +109,7 @@ const serverWithLogOptions = fastify<
108
109
  }
109
110
  })
110
111
 
111
- expectType<FastifyBaseLogger>(serverWithLogOptions.log)
112
+ expect(serverWithLogOptions.log).type.toBe<FastifyBaseLogger>()
112
113
 
113
114
  const serverWithFileOption = fastify<
114
115
  Server,
@@ -121,7 +122,7 @@ const serverWithFileOption = fastify<
121
122
  }
122
123
  })
123
124
 
124
- expectType<FastifyBaseLogger>(serverWithFileOption.log)
125
+ expect(serverWithFileOption.log).type.toBe<FastifyBaseLogger>()
125
126
 
126
127
  const serverAutoInferringTypes = fastify({
127
128
  logger: {
@@ -129,7 +130,7 @@ const serverAutoInferringTypes = fastify({
129
130
  }
130
131
  })
131
132
 
132
- expectType<FastifyBaseLogger>(serverAutoInferringTypes.log)
133
+ expect(serverAutoInferringTypes.log).type.toBe<FastifyBaseLogger>()
133
134
 
134
135
  const serverWithLoggerInstance = fastify({
135
136
  loggerInstance: P({
@@ -138,14 +139,14 @@ const serverWithLoggerInstance = fastify({
138
139
  })
139
140
  })
140
141
 
141
- expectType<P.Logger>(serverWithLoggerInstance.log)
142
+ expect(serverWithLoggerInstance.log).type.toBe<P.Logger>()
142
143
 
143
144
  const serverWithPinoConfig = fastify({
144
145
  logger: {
145
146
  level: 'info',
146
147
  serializers: {
147
- req (IncomingMessage) {
148
- expectType<FastifyRequest>(IncomingMessage)
148
+ req (request) {
149
+ expect(request).type.toBe<FastifyRequest>()
149
150
  return {
150
151
  method: 'method',
151
152
  url: 'url',
@@ -156,15 +157,17 @@ const serverWithPinoConfig = fastify({
156
157
  other: ''
157
158
  }
158
159
  },
159
- res (ServerResponse) {
160
- expectType<ResSerializerReply<Server, FastifyReply>>(ServerResponse)
161
- expectAssignable<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>(ServerResponse)
162
- expectNotAssignable<FastifyReply>(ServerResponse)
160
+ res (reply) {
161
+ expect(reply).type.toBe<ResSerializerReply<Server, FastifyReply>>()
162
+ expect(reply).type.toBeAssignableTo<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>()
163
+ expect(reply).type.not.toBeAssignableTo<FastifyReply>()
163
164
  return {
164
165
  statusCode: 'statusCode'
165
166
  }
166
167
  },
167
- err (FastifyError) {
168
+ err (error) {
169
+ expect(error).type.toBe<FastifyError>()
170
+
168
171
  return {
169
172
  other: '',
170
173
  type: 'type',
@@ -176,7 +179,7 @@ const serverWithPinoConfig = fastify({
176
179
  }
177
180
  })
178
181
 
179
- expectType<FastifyBaseLogger>(serverWithPinoConfig.log)
182
+ expect(serverWithPinoConfig.log).type.toBe<FastifyBaseLogger>()
180
183
 
181
184
  const serverAutoInferredFileOption = fastify({
182
185
  logger: {
@@ -185,15 +188,15 @@ const serverAutoInferredFileOption = fastify({
185
188
  }
186
189
  })
187
190
 
188
- expectType<FastifyBaseLogger>(serverAutoInferredFileOption.log)
191
+ expect(serverAutoInferredFileOption.log).type.toBe<FastifyBaseLogger>()
189
192
 
190
193
  const serverAutoInferredSerializerResponseObjectOption = fastify({
191
194
  logger: {
192
195
  serializers: {
193
- res (ServerResponse) {
194
- expectType<ResSerializerReply<Server, FastifyReply>>(ServerResponse)
195
- expectAssignable<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>(ServerResponse)
196
- expectNotAssignable<FastifyReply>(ServerResponse)
196
+ res (reply) {
197
+ expect(reply).type.toBe<ResSerializerReply<Server, FastifyReply>>()
198
+ expect(reply).type.toBeAssignableTo<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>()
199
+ expect(reply).type.not.toBeAssignableTo<FastifyReply>()
197
200
  return {
198
201
  status: '200'
199
202
  }
@@ -202,13 +205,13 @@ const serverAutoInferredSerializerResponseObjectOption = fastify({
202
205
  }
203
206
  })
204
207
 
205
- expectType<FastifyBaseLogger>(serverAutoInferredSerializerResponseObjectOption.log)
208
+ expect(serverAutoInferredSerializerResponseObjectOption.log).type.toBe<FastifyBaseLogger>()
206
209
 
207
210
  const serverAutoInferredSerializerObjectOption = fastify({
208
211
  logger: {
209
212
  serializers: {
210
- req (IncomingMessage) {
211
- expectType<FastifyRequest>(IncomingMessage)
213
+ req (request) {
214
+ expect(request).type.toBe<FastifyRequest>()
212
215
  return {
213
216
  method: 'method',
214
217
  url: 'url',
@@ -219,10 +222,10 @@ const serverAutoInferredSerializerObjectOption = fastify({
219
222
  other: ''
220
223
  }
221
224
  },
222
- res (ServerResponse) {
223
- expectType<ResSerializerReply<Server, FastifyReply>>(ServerResponse)
224
- expectAssignable<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>(ServerResponse)
225
- expectNotAssignable<FastifyReply>(ServerResponse)
225
+ res (reply) {
226
+ expect(reply).type.toBe<ResSerializerReply<Server, FastifyReply>>()
227
+ expect(reply).type.toBeAssignableTo<Partial<FastifyReply> & Pick<FastifyReply, 'statusCode'>>()
228
+ expect(reply).type.not.toBeAssignableTo<FastifyReply>()
226
229
  return {
227
230
  statusCode: 'statusCode'
228
231
  }
@@ -239,7 +242,7 @@ const serverAutoInferredSerializerObjectOption = fastify({
239
242
  }
240
243
  })
241
244
 
242
- expectType<FastifyBaseLogger>(serverAutoInferredSerializerObjectOption.log)
245
+ expect(serverAutoInferredSerializerObjectOption.log).type.toBe<FastifyBaseLogger>()
243
246
 
244
247
  const passStreamAsOption = fastify({
245
248
  logger: {
@@ -247,7 +250,7 @@ const passStreamAsOption = fastify({
247
250
  }
248
251
  })
249
252
 
250
- expectType<FastifyBaseLogger>(passStreamAsOption.log)
253
+ expect(passStreamAsOption.log).type.toBe<FastifyBaseLogger>()
251
254
 
252
255
  const passPinoOption = fastify({
253
256
  logger: {
@@ -258,20 +261,16 @@ const passPinoOption = fastify({
258
261
  }
259
262
  })
260
263
 
261
- expectType<FastifyBaseLogger>(passPinoOption.log)
262
-
263
- // FastifyLoggerInstance is deprecated
264
- expectDeprecated({} as FastifyLoggerInstance)
264
+ expect(passPinoOption.log).type.toBe<FastifyBaseLogger>()
265
265
 
266
266
  const childParent = fastify().log
267
267
  // we test different option variant here
268
- expectType<FastifyBaseLogger>(childParent.child({}, { level: 'info' }))
269
- expectType<FastifyBaseLogger>(childParent.child({}, { level: 'silent' }))
270
- expectType<FastifyBaseLogger>(childParent.child({}, { redact: ['pass', 'pin'] }))
271
- expectType<FastifyBaseLogger>(childParent.child({}, { serializers: { key: () => { } } }))
272
- expectType<FastifyBaseLogger>(childParent.child({}, { level: 'info', redact: ['pass', 'pin'], serializers: { key: () => { } } }))
273
-
274
- // no option pass
275
- expectError(childParent.child())
276
- // wrong option
277
- expectError(childParent.child({}, { nonExist: true }))
268
+ expect(childParent.child({}, { level: 'info' })).type.toBe<FastifyBaseLogger>()
269
+ expect(childParent.child({}, { level: 'silent' })).type.toBe<FastifyBaseLogger>()
270
+ expect(childParent.child({}, { redact: ['pass', 'pin'] })).type.toBe<FastifyBaseLogger>()
271
+ expect(childParent.child({}, { serializers: { key: () => { } } })).type.toBe<FastifyBaseLogger>()
272
+ expect(childParent.child({}, { level: 'info', redact: ['pass', 'pin'], serializers: { key: () => { } } })).type.toBe<FastifyBaseLogger>()
273
+
274
+ expect(childParent.child).type.not.toBeCallableWith()
275
+
276
+ expect(childParent.child).type.not.toBeCallableWith({}, { nonExist: true })
@@ -0,0 +1,96 @@
1
+ import * as http from 'node:http'
2
+ import * as https from 'node:https'
3
+ import { FastifyError } from '@fastify/error'
4
+ import { expect } from 'tstyche'
5
+ import fastify, { FastifyInstance, FastifyPluginOptions, SafePromiseLike } from '../../fastify.js'
6
+ import { FastifyPluginCallback, FastifyPluginAsync } from '../../types/plugin.js'
7
+
8
+ // FastifyPlugin & FastifyRegister
9
+ interface TestOptions extends FastifyPluginOptions {
10
+ option1: string;
11
+ option2: boolean;
12
+ }
13
+ const testOptions: TestOptions = {
14
+ option1: 'a',
15
+ option2: false
16
+ }
17
+ const testPluginOpts: FastifyPluginCallback<TestOptions> = function (instance, opts, done) {
18
+ expect(opts).type.toBe<TestOptions>()
19
+ }
20
+ const testPluginOptsAsync: FastifyPluginAsync<TestOptions> = async function (instance, opts) {
21
+ expect(opts).type.toBe<TestOptions>()
22
+ }
23
+
24
+ const testPluginOptsWithType = (
25
+ instance: FastifyInstance,
26
+ opts: FastifyPluginOptions,
27
+ done: (error?: FastifyError) => void
28
+ ) => { }
29
+ const testPluginOptsWithTypeAsync = async (
30
+ instance: FastifyInstance,
31
+ opts: FastifyPluginOptions
32
+ ) => { }
33
+
34
+ expect(fastify().register).type.not.toBeCallableWith(testPluginOpts, {}) // must provide required options
35
+ expect(fastify().register).type.not.toBeCallableWith(testPluginOptsAsync, {}) // must provide required options
36
+
37
+ expect(fastify().register(testPluginOpts, { option1: '', option2: true })).type.toBeAssignableTo<FastifyInstance>()
38
+ expect(fastify().register(testPluginOptsAsync, { option1: '', option2: true })).type.toBeAssignableTo<FastifyInstance>()
39
+
40
+ expect(fastify().register(function (instance, opts, done) { })).type.toBeAssignableTo<FastifyInstance>()
41
+ expect(fastify().register(function (instance, opts, done) { }, () => { })).type.toBeAssignableTo<FastifyInstance>()
42
+ expect(fastify().register(function (instance, opts, done) { }, { logLevel: 'info', prefix: 'foobar' })).type.toBeAssignableTo<FastifyInstance>()
43
+
44
+ expect(fastify().register(import('./dummy-plugin.mjs'))).type.toBeAssignableTo<FastifyInstance>()
45
+ expect(fastify().register(import('./dummy-plugin.mjs'), { foo: 1 })).type.toBeAssignableTo<FastifyInstance>()
46
+
47
+ const testPluginCallback: FastifyPluginCallback = function (instance, opts, done) { }
48
+ expect(fastify().register(testPluginCallback, {})).type.toBeAssignableTo<FastifyInstance>()
49
+
50
+ const testPluginAsync: FastifyPluginAsync = async function (instance, opts) { }
51
+ expect(fastify().register(testPluginAsync, {})).type.toBeAssignableTo<FastifyInstance>()
52
+
53
+ expect(
54
+ fastify().register(function (instance, opts): Promise<void> { return Promise.resolve() })
55
+ ).type.toBeAssignableTo<FastifyInstance>()
56
+ expect(fastify().register(async function (instance, opts) { }, () => { })).type.toBeAssignableTo<FastifyInstance>()
57
+ expect(fastify().register(async function (instance, opts) { }, { logLevel: 'info', prefix: 'foobar' })).type.toBeAssignableTo<FastifyInstance>()
58
+
59
+ expect(fastify().register).type.not.toBeCallableWith(function () { }, { logLevel: '', prefix: 'foobar' }) // must provide valid logLevel
60
+
61
+ const httpsServer = fastify({ https: {} })
62
+ expect(httpsServer).type.not.toBeAssignableTo<
63
+ FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse> &
64
+ Promise<FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse>>
65
+ >()
66
+ expect(httpsServer).type.toBeAssignableTo<
67
+ FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse> &
68
+ PromiseLike<FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse>>
69
+ >()
70
+ expect(httpsServer).type.toBe<
71
+ FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse> &
72
+ SafePromiseLike<FastifyInstance<https.Server, http.IncomingMessage, http.ServerResponse>>
73
+ >()
74
+
75
+ // Chainable
76
+ httpsServer
77
+ .register(testPluginOpts, testOptions)
78
+ .after((_error) => { })
79
+ .ready((_error) => { })
80
+ .close(() => { })
81
+
82
+ // Thenable
83
+ expect(httpsServer.after()).type.toBeAssignableTo<PromiseLike<undefined>>()
84
+ expect(httpsServer.close()).type.toBeAssignableTo<PromiseLike<undefined>>()
85
+ expect(httpsServer.ready()).type.toBeAssignableTo<PromiseLike<undefined>>()
86
+ expect(httpsServer.register(testPluginOpts, testOptions)).type.toBeAssignableTo<PromiseLike<undefined>>()
87
+ expect(httpsServer.register(testPluginOptsWithType)).type.toBeAssignableTo<PromiseLike<undefined>>()
88
+ expect(httpsServer.register(testPluginOptsWithTypeAsync)).type.toBeAssignableTo<PromiseLike<undefined>>()
89
+ expect(httpsServer.register(testPluginOptsWithType, { prefix: '/test' })).type.toBeAssignableTo<PromiseLike<undefined>>()
90
+ expect(httpsServer.register(testPluginOptsWithTypeAsync, { prefix: '/test' })).type.toBeAssignableTo<PromiseLike<undefined>>()
91
+
92
+ async function testAsync (): Promise<void> {
93
+ await httpsServer
94
+ .register(testPluginOpts, testOptions)
95
+ .register(testPluginOpts, testOptions)
96
+ }
@@ -0,0 +1,245 @@
1
+ import { IncomingMessage, Server, ServerResponse } from 'node:http'
2
+ import { Http2Server, Http2ServerRequest, Http2ServerResponse } from 'node:http2'
3
+ import { expect } from 'tstyche'
4
+ import fastify, {
5
+ FastifyInstance,
6
+ FastifyError,
7
+ FastifyBaseLogger,
8
+ FastifyPluginAsync,
9
+ FastifyPluginCallback,
10
+ FastifyPluginOptions,
11
+ RawServerDefault
12
+ } from '../../fastify.js'
13
+
14
+ const testPluginCallback: FastifyPluginCallback = function (instance, opts, done) { }
15
+ const testPluginAsync: FastifyPluginAsync = async function (instance, opts) { }
16
+
17
+ const testPluginOpts: FastifyPluginCallback = function (instance, opts, done) { }
18
+ const testPluginOptsAsync: FastifyPluginAsync = async function (instance, opts) { }
19
+
20
+ const testPluginOptsWithType = (
21
+ instance: FastifyInstance,
22
+ opts: FastifyPluginOptions,
23
+ done: (error?: FastifyError) => void
24
+ ) => { }
25
+ const testPluginOptsWithTypeAsync = async (instance: FastifyInstance, opts: FastifyPluginOptions) => { }
26
+
27
+ interface TestOptions extends FastifyPluginOptions {
28
+ option1: string;
29
+ option2: boolean;
30
+ }
31
+
32
+ // Type validation
33
+ expect(fastify().register).type.not.toBeCallableWith(testPluginOptsAsync, { prefix: 1 })
34
+ expect(fastify().register).type.not.toBeCallableWith(testPluginOptsAsync, { logLevel: () => ({}) })
35
+ expect(fastify().register).type.not.toBeCallableWith(testPluginOptsAsync, { logSerializers: () => ({}) })
36
+ expect(fastify().register).type.not.toBeCallableWith({})
37
+
38
+ expect(
39
+ fastify().register(
40
+ testPluginOptsAsync, { prefix: '/example', logLevel: 'info', logSerializers: { key: (value: any) => `${value}` } }
41
+ )
42
+ ).type.toBeAssignableTo<FastifyInstance>()
43
+
44
+ expect(
45
+ fastify().register(testPluginOptsAsync, () => {
46
+ return {}
47
+ })
48
+ ).type.toBeAssignableTo<FastifyInstance>()
49
+
50
+ expect(
51
+ fastify().register(testPluginOptsAsync, (instance) => {
52
+ expect(instance).type.toBe<FastifyInstance>()
53
+ })
54
+ ).type.toBeAssignableTo<FastifyInstance>()
55
+
56
+ // With Http2
57
+ const serverWithHttp2 = fastify({ http2: true })
58
+ type ServerWithHttp2 = FastifyInstance<Http2Server, Http2ServerRequest, Http2ServerResponse>
59
+ const testPluginWithHttp2: FastifyPluginCallback<TestOptions, Http2Server> = function (instance, opts, done) { }
60
+ const testPluginWithHttp2Async: FastifyPluginAsync<TestOptions, Http2Server> = async function (instance, opts) { }
61
+ const testPluginWithHttp2WithType = (
62
+ instance: ServerWithHttp2,
63
+ opts: FastifyPluginOptions,
64
+ done: (error?: FastifyError) => void
65
+ ) => { }
66
+ const testPluginWithHttp2WithTypeAsync = async (
67
+ instance: ServerWithHttp2,
68
+ opts: FastifyPluginOptions
69
+ ) => { }
70
+ const testOptions: TestOptions = {
71
+ option1: 'a',
72
+ option2: false
73
+ }
74
+ expect(serverWithHttp2.register(testPluginCallback)).type.toBeAssignableTo<ServerWithHttp2>()
75
+ expect(serverWithHttp2.register(testPluginAsync)).type.toBeAssignableTo<ServerWithHttp2>()
76
+ expect(serverWithHttp2.register(testPluginOpts)).type.toBeAssignableTo<ServerWithHttp2>()
77
+ expect(serverWithHttp2.register(testPluginOptsAsync)).type.toBeAssignableTo<ServerWithHttp2>()
78
+ expect(serverWithHttp2.register(testPluginOptsWithType)).type.toBeAssignableTo<ServerWithHttp2>()
79
+ expect(serverWithHttp2.register(testPluginOptsWithTypeAsync)).type.toBeAssignableTo<ServerWithHttp2>()
80
+ expect(serverWithHttp2.register).type.not.toBeCallableWith(testPluginWithHttp2)
81
+ expect(serverWithHttp2.register(testPluginWithHttp2, testOptions)).type.toBeAssignableTo<ServerWithHttp2>()
82
+ expect(serverWithHttp2.register).type.not.toBeCallableWith(testPluginWithHttp2Async)
83
+ expect(serverWithHttp2.register(testPluginWithHttp2Async, testOptions)).type.toBeAssignableTo<ServerWithHttp2>()
84
+ expect(serverWithHttp2.register(testPluginWithHttp2WithType)).type.toBeAssignableTo<ServerWithHttp2>()
85
+ expect(serverWithHttp2.register(testPluginWithHttp2WithTypeAsync)).type.toBeAssignableTo<ServerWithHttp2>()
86
+ expect(serverWithHttp2.register((instance) => {
87
+ expect(instance).type.toBe<FastifyInstance>()
88
+ })).type.toBeAssignableTo<ServerWithHttp2>()
89
+ expect(serverWithHttp2.register((instance: ServerWithHttp2) => {
90
+ expect(instance).type.toBe<ServerWithHttp2>()
91
+ })).type.toBeAssignableTo<ServerWithHttp2>()
92
+ expect(serverWithHttp2.register(async (instance) => {
93
+ expect(instance).type.toBe<FastifyInstance>()
94
+ })).type.toBeAssignableTo<ServerWithHttp2>()
95
+ expect(serverWithHttp2.register(async (instance: ServerWithHttp2) => {
96
+ expect(instance).type.toBe<ServerWithHttp2>()
97
+ })).type.toBeAssignableTo<ServerWithHttp2>()
98
+
99
+ // With Type Provider
100
+ type TestTypeProvider = { schema: 'test', validator: 'test', serializer: 'test' }
101
+ const serverWithTypeProvider = fastify().withTypeProvider<TestTypeProvider>()
102
+ type ServerWithTypeProvider = FastifyInstance<
103
+ Server,
104
+ IncomingMessage,
105
+ ServerResponse,
106
+ FastifyBaseLogger,
107
+ TestTypeProvider
108
+ >
109
+ const testPluginWithTypeProvider: FastifyPluginCallback<
110
+ TestOptions,
111
+ RawServerDefault,
112
+ TestTypeProvider
113
+ > = function (instance, opts, done) { }
114
+ const testPluginWithTypeProviderAsync: FastifyPluginAsync<
115
+ TestOptions,
116
+ RawServerDefault,
117
+ TestTypeProvider
118
+ > = async function (instance, opts) { }
119
+ const testPluginWithTypeProviderWithType = (
120
+ instance: ServerWithTypeProvider,
121
+ opts: FastifyPluginOptions,
122
+ done: (error?: FastifyError) => void
123
+ ) => { }
124
+ const testPluginWithTypeProviderWithTypeAsync = async (
125
+ instance: ServerWithTypeProvider,
126
+ opts: FastifyPluginOptions
127
+ ) => { }
128
+ expect(serverWithTypeProvider.register(testPluginCallback)).type.toBeAssignableTo<ServerWithTypeProvider>()
129
+ expect(serverWithTypeProvider.register(testPluginAsync)).type.toBeAssignableTo<ServerWithTypeProvider>()
130
+ expect(serverWithTypeProvider.register(testPluginOpts)).type.toBeAssignableTo<ServerWithTypeProvider>()
131
+ expect(serverWithTypeProvider.register(testPluginOptsAsync)).type.toBeAssignableTo<ServerWithTypeProvider>()
132
+ expect(serverWithTypeProvider.register(testPluginOptsWithType)).type.toBeAssignableTo<ServerWithTypeProvider>()
133
+ expect(serverWithTypeProvider.register(testPluginOptsWithTypeAsync)).type.toBeAssignableTo<ServerWithTypeProvider>()
134
+ expect(serverWithTypeProvider.register).type.not.toBeCallableWith(testPluginWithTypeProvider)
135
+ expect(serverWithTypeProvider.register(testPluginWithTypeProvider, testOptions))
136
+ .type.toBeAssignableTo<ServerWithTypeProvider>()
137
+ expect(serverWithTypeProvider.register).type.not.toBeCallableWith(testPluginWithTypeProviderAsync)
138
+ expect(serverWithTypeProvider.register(testPluginWithTypeProviderAsync, testOptions))
139
+ .type.toBeAssignableTo<ServerWithTypeProvider>()
140
+ expect(serverWithTypeProvider.register(testPluginWithTypeProviderWithType))
141
+ .type.toBeAssignableTo<ServerWithTypeProvider>()
142
+ expect(serverWithTypeProvider.register(testPluginWithTypeProviderWithTypeAsync))
143
+ .type.toBeAssignableTo<ServerWithTypeProvider>()
144
+ expect(serverWithTypeProvider.register((instance) => {
145
+ expect(instance).type.toBe<FastifyInstance>()
146
+ })).type.toBeAssignableTo<ServerWithTypeProvider>()
147
+ expect(serverWithTypeProvider.register((instance: ServerWithTypeProvider) => {
148
+ expect(instance).type.toBe<ServerWithTypeProvider>()
149
+ })).type.toBeAssignableTo<ServerWithTypeProvider>()
150
+ expect(serverWithTypeProvider.register(async (instance) => {
151
+ expect(instance).type.toBe<FastifyInstance>()
152
+ })).type.toBeAssignableTo<ServerWithTypeProvider>()
153
+ expect(serverWithTypeProvider.register(async (instance: ServerWithTypeProvider) => {
154
+ expect(instance).type.toBe<ServerWithTypeProvider>()
155
+ })).type.toBeAssignableTo<ServerWithTypeProvider>()
156
+
157
+ // With Type Provider and logger
158
+ const customLogger = {
159
+ level: 'info',
160
+ info: () => { },
161
+ warn: () => { },
162
+ error: () => { },
163
+ fatal: () => { },
164
+ trace: () => { },
165
+ debug: () => { },
166
+ child: () => customLogger,
167
+ silent: () => { }
168
+ }
169
+ const serverWithTypeProviderAndLogger = fastify({
170
+ loggerInstance: customLogger
171
+ }).withTypeProvider<TestTypeProvider>()
172
+ type ServerWithTypeProviderAndLogger = FastifyInstance<
173
+ Server,
174
+ IncomingMessage,
175
+ ServerResponse,
176
+ typeof customLogger,
177
+ TestTypeProvider
178
+ >
179
+ const testPluginWithTypeProviderAndLogger: FastifyPluginCallback<
180
+ TestOptions,
181
+ RawServerDefault,
182
+ TestTypeProvider,
183
+ typeof customLogger
184
+ > = function (instance, opts, done) { }
185
+ const testPluginWithTypeProviderAndLoggerAsync: FastifyPluginAsync<
186
+ TestOptions,
187
+ RawServerDefault,
188
+ TestTypeProvider,
189
+ typeof customLogger
190
+ > = async function (instance, opts) { }
191
+ const testPluginWithTypeProviderAndLoggerWithType = (
192
+ instance: ServerWithTypeProviderAndLogger,
193
+ opts: FastifyPluginOptions,
194
+ done: (error?: FastifyError) => void
195
+ ) => { }
196
+ const testPluginWithTypeProviderAndLoggerWithTypeAsync = async (
197
+ instance: ServerWithTypeProviderAndLogger,
198
+ opts: FastifyPluginOptions
199
+ ) => { }
200
+ expect(serverWithTypeProviderAndLogger.register(testPluginCallback))
201
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
202
+ expect(serverWithTypeProviderAndLogger.register(testPluginAsync))
203
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
204
+ expect(serverWithTypeProviderAndLogger.register(testPluginOpts))
205
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
206
+ expect(serverWithTypeProviderAndLogger.register(testPluginOptsAsync))
207
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
208
+ expect(serverWithTypeProviderAndLogger.register(testPluginOptsWithType))
209
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
210
+ expect(serverWithTypeProviderAndLogger.register(testPluginOptsWithTypeAsync))
211
+ .type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
212
+ expect(serverWithTypeProviderAndLogger.register).type.not.toBeCallableWith(testPluginWithTypeProviderAndLogger)
213
+ expect(
214
+ serverWithTypeProviderAndLogger.register(testPluginWithTypeProviderAndLogger, testOptions)
215
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
216
+ expect(serverWithTypeProviderAndLogger.register).type.not.toBeCallableWith(testPluginWithTypeProviderAndLoggerAsync)
217
+ expect(
218
+ serverWithTypeProviderAndLogger.register(testPluginWithTypeProviderAndLoggerAsync, testOptions)
219
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
220
+ expect(
221
+ serverWithTypeProviderAndLogger.register(testPluginWithTypeProviderAndLoggerWithType)
222
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
223
+ expect(
224
+ serverWithTypeProviderAndLogger.register(testPluginWithTypeProviderAndLoggerWithTypeAsync)
225
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
226
+ expect(
227
+ serverWithTypeProviderAndLogger.register((instance) => {
228
+ expect(instance).type.toBe<FastifyInstance>()
229
+ })
230
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
231
+ expect(
232
+ serverWithTypeProviderAndLogger.register((instance: ServerWithTypeProviderAndLogger) => {
233
+ expect(instance).type.toBe<ServerWithTypeProviderAndLogger>()
234
+ })
235
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
236
+ expect(
237
+ serverWithTypeProviderAndLogger.register(async (instance) => {
238
+ expect(instance).type.toBe<FastifyInstance>()
239
+ })
240
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()
241
+ expect(
242
+ serverWithTypeProviderAndLogger.register(async (instance: ServerWithTypeProviderAndLogger) => {
243
+ expect(instance).type.toBe<ServerWithTypeProviderAndLogger>()
244
+ })
245
+ ).type.toBeAssignableTo<ServerWithTypeProviderAndLogger>()