@trpc/server 11.0.0-next.91 → 11.0.0-rc.329
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.
- package/README.md +6 -6
- package/adapters/next-app-dir/index.d.ts +1 -0
- package/adapters/next-app-dir/index.js +1 -0
- package/dist/@trpc/server/http.d.ts +8 -0
- package/dist/@trpc/server/http.d.ts.map +1 -0
- package/dist/@trpc/server/index.d.ts +61 -0
- package/dist/@trpc/server/index.d.ts.map +1 -0
- package/dist/@trpc/server/rpc.d.ts +3 -0
- package/dist/@trpc/server/rpc.d.ts.map +1 -0
- package/dist/adapters/aws-lambda/index.d.ts +11 -2
- package/dist/adapters/aws-lambda/index.d.ts.map +1 -1
- package/dist/adapters/aws-lambda/index.js +28 -106
- package/dist/adapters/aws-lambda/index.mjs +15 -91
- package/dist/adapters/aws-lambda/utils.d.ts +14 -14
- package/dist/adapters/aws-lambda/utils.d.ts.map +1 -1
- package/dist/adapters/aws-lambda/utils.js +101 -0
- package/dist/adapters/aws-lambda/utils.mjs +94 -0
- package/dist/adapters/express.d.ts +11 -2
- package/dist/adapters/express.d.ts.map +1 -1
- package/dist/adapters/express.js +2 -14
- package/dist/adapters/express.mjs +2 -12
- package/dist/adapters/fastify/fastifyRequestHandler.d.ts +4 -4
- package/dist/adapters/fastify/fastifyRequestHandler.d.ts.map +1 -1
- package/dist/adapters/fastify/fastifyRequestHandler.js +81 -0
- package/dist/adapters/fastify/fastifyRequestHandler.mjs +79 -0
- package/dist/adapters/fastify/fastifyTRPCPlugin.d.ts +13 -4
- package/dist/adapters/fastify/fastifyTRPCPlugin.d.ts.map +1 -1
- package/dist/adapters/fastify/fastifyTRPCPlugin.js +48 -0
- package/dist/adapters/fastify/fastifyTRPCPlugin.mjs +46 -0
- package/dist/adapters/fastify/index.js +4 -125
- package/dist/adapters/fastify/index.mjs +2 -125
- package/dist/adapters/fetch/fetchRequestHandler.d.ts +11 -2
- package/dist/adapters/fetch/fetchRequestHandler.d.ts.map +1 -1
- package/dist/adapters/fetch/fetchRequestHandler.js +119 -0
- package/dist/adapters/fetch/fetchRequestHandler.mjs +117 -0
- package/dist/adapters/fetch/index.js +2 -106
- package/dist/adapters/fetch/index.mjs +1 -107
- package/dist/adapters/fetch/types.d.ts +13 -4
- package/dist/adapters/fetch/types.d.ts.map +1 -1
- package/dist/adapters/next-app-dir/formDataToObject.d.ts +2 -0
- package/dist/adapters/next-app-dir/formDataToObject.d.ts.map +1 -0
- package/dist/adapters/next-app-dir/formDataToObject.js +34 -0
- package/dist/adapters/next-app-dir/formDataToObject.mjs +32 -0
- package/dist/adapters/next-app-dir/nextAppDirCaller.d.ts +24 -0
- package/dist/adapters/next-app-dir/nextAppDirCaller.d.ts.map +1 -0
- package/dist/adapters/next-app-dir/nextAppDirCaller.js +86 -0
- package/dist/adapters/next-app-dir/nextAppDirCaller.mjs +84 -0
- package/dist/adapters/next-app-dir/notFound.d.ts +7 -0
- package/dist/adapters/next-app-dir/notFound.d.ts.map +1 -0
- package/dist/adapters/next-app-dir/notFound.js +16 -0
- package/dist/adapters/next-app-dir/notFound.mjs +14 -0
- package/dist/adapters/next-app-dir/redirect.d.ts +18 -0
- package/dist/adapters/next-app-dir/redirect.d.ts.map +1 -0
- package/dist/adapters/next-app-dir/redirect.js +34 -0
- package/dist/adapters/next-app-dir/redirect.mjs +31 -0
- package/dist/adapters/next-app-dir/rethrowNextErrors.d.ts +6 -0
- package/dist/adapters/next-app-dir/rethrowNextErrors.d.ts.map +1 -0
- package/dist/adapters/next-app-dir/rethrowNextErrors.js +23 -0
- package/dist/adapters/next-app-dir/rethrowNextErrors.mjs +21 -0
- package/dist/adapters/next-app-dir.d.ts +4 -0
- package/dist/adapters/next-app-dir.d.ts.map +1 -0
- package/dist/adapters/next-app-dir.js +11 -0
- package/dist/adapters/next-app-dir.mjs +3 -0
- package/dist/adapters/next.d.ts +16 -3
- package/dist/adapters/next.d.ts.map +1 -1
- package/dist/adapters/next.js +20 -19
- package/dist/adapters/next.mjs +19 -16
- package/dist/adapters/node-http/content-type/form-data/fileUploadHandler.d.ts +6 -3
- package/dist/adapters/node-http/content-type/form-data/fileUploadHandler.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/form-data/fileUploadHandler.js +161 -0
- package/dist/adapters/node-http/content-type/form-data/fileUploadHandler.mjs +157 -0
- package/dist/adapters/node-http/content-type/form-data/index.d.ts +6 -8
- package/dist/adapters/node-http/content-type/form-data/index.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/form-data/index.js +21 -647
- package/dist/adapters/node-http/content-type/form-data/index.mjs +10 -632
- package/dist/adapters/node-http/content-type/form-data/memoryUploadHandler.d.ts +2 -2
- package/dist/adapters/node-http/content-type/form-data/memoryUploadHandler.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/form-data/memoryUploadHandler.js +29 -0
- package/dist/adapters/node-http/content-type/form-data/memoryUploadHandler.mjs +27 -0
- package/dist/adapters/node-http/content-type/form-data/streamSlice.d.ts +2 -1
- package/dist/adapters/node-http/content-type/form-data/streamSlice.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/form-data/streamSlice.js +46 -0
- package/dist/adapters/node-http/content-type/form-data/streamSlice.mjs +44 -0
- package/dist/adapters/node-http/content-type/form-data/uploadHandler.d.ts +2 -2
- package/dist/adapters/node-http/content-type/form-data/uploadHandler.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/form-data/uploadHandler.js +30 -0
- package/dist/adapters/node-http/content-type/form-data/uploadHandler.mjs +26 -0
- package/dist/adapters/node-http/content-type/json/getPostBody.d.ts +2 -2
- package/dist/adapters/node-http/content-type/json/getPostBody.d.ts.map +1 -1
- package/dist/adapters/node-http/content-type/json/getPostBody.js +54 -0
- package/dist/adapters/node-http/content-type/json/getPostBody.mjs +52 -0
- package/dist/adapters/node-http/content-type/json/index.js +6 -42
- package/dist/adapters/node-http/content-type/json/index.mjs +5 -39
- package/dist/adapters/node-http/index.js +1 -14
- package/dist/adapters/node-http/index.mjs +1 -12
- package/dist/adapters/node-http/internals/contentType.d.ts +3 -3
- package/dist/adapters/node-http/internals/contentType.d.ts.map +1 -1
- package/dist/{contentType-8c16408e.js → adapters/node-http/internals/contentType.js} +1 -0
- package/dist/{contentType-3194ed5f.mjs → adapters/node-http/internals/contentType.mjs} +2 -1
- package/dist/adapters/node-http/nodeHTTPRequestHandler.d.ts +11 -2
- package/dist/adapters/node-http/nodeHTTPRequestHandler.d.ts.map +1 -1
- package/dist/{nodeHTTPRequestHandler-18f3370e.js → adapters/node-http/nodeHTTPRequestHandler.js} +19 -10
- package/dist/{nodeHTTPRequestHandler-0986c5a1.mjs → adapters/node-http/nodeHTTPRequestHandler.mjs} +19 -10
- package/dist/adapters/node-http/types.d.ts +18 -9
- package/dist/adapters/node-http/types.d.ts.map +1 -1
- package/dist/adapters/standalone.d.ts +11 -2
- package/dist/adapters/standalone.d.ts.map +1 -1
- package/dist/adapters/standalone.js +10 -22
- package/dist/adapters/standalone.mjs +10 -16
- package/dist/adapters/ws.d.ts +18 -20
- package/dist/adapters/ws.d.ts.map +1 -1
- package/dist/adapters/ws.js +35 -74
- package/dist/adapters/ws.mjs +29 -66
- package/dist/bundle-analysis.json +386 -482
- package/dist/http.d.ts +2 -0
- package/dist/http.d.ts.map +1 -0
- package/dist/http.js +18 -0
- package/dist/http.mjs +7 -0
- package/dist/index.d.ts +1 -14
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -86
- package/dist/index.mjs +9 -81
- package/dist/observable/index.d.ts +4 -4
- package/dist/observable/index.d.ts.map +1 -1
- package/dist/observable/index.js +6 -149
- package/dist/observable/index.mjs +2 -147
- package/dist/observable/observable.d.ts +9 -1
- package/dist/observable/observable.d.ts.map +1 -1
- package/dist/{observable-464116ac.js → observable/observable.js} +50 -20
- package/dist/{observable-ade1bad8.mjs → observable/observable.mjs} +50 -21
- package/dist/observable/operators.d.ts +8 -0
- package/dist/observable/operators.d.ts.map +1 -0
- package/dist/observable/operators.js +99 -0
- package/dist/observable/operators.mjs +95 -0
- package/dist/observable/types.d.ts +2 -5
- package/dist/observable/types.d.ts.map +1 -1
- package/dist/rpc.d.ts +2 -0
- package/dist/rpc.d.ts.map +1 -0
- package/dist/rpc.js +12 -0
- package/dist/rpc.mjs +4 -0
- package/dist/shared.d.ts +26 -0
- package/dist/shared.d.ts.map +1 -0
- package/dist/shared.js +11 -0
- package/dist/shared.mjs +4 -0
- package/dist/unstable-core-do-not-import/clientish/inference.d.ts +17 -0
- package/dist/unstable-core-do-not-import/clientish/inference.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/clientish/inferrable.d.ts +32 -0
- package/dist/unstable-core-do-not-import/clientish/inferrable.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/clientish/serialize.d.ts +62 -0
- package/dist/unstable-core-do-not-import/clientish/serialize.d.ts.map +1 -0
- package/dist/{shared/createProxy/index.d.ts → unstable-core-do-not-import/createProxy.d.ts} +1 -1
- package/dist/unstable-core-do-not-import/createProxy.d.ts.map +1 -0
- package/dist/{index-784ff647.js → unstable-core-do-not-import/createProxy.js} +0 -51
- package/dist/unstable-core-do-not-import/createProxy.mjs +49 -0
- package/dist/{error → unstable-core-do-not-import/error}/TRPCError.d.ts +3 -2
- package/dist/unstable-core-do-not-import/error/TRPCError.d.ts.map +1 -0
- package/dist/{TRPCError-ae7b67e8.js → unstable-core-do-not-import/error/TRPCError.js} +25 -25
- package/dist/{TRPCError-816ff32e.mjs → unstable-core-do-not-import/error/TRPCError.mjs} +24 -25
- package/dist/{error → unstable-core-do-not-import/error}/formatter.d.ts +11 -6
- package/dist/unstable-core-do-not-import/error/formatter.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/error/formatter.js +7 -0
- package/dist/unstable-core-do-not-import/error/formatter.mjs +5 -0
- package/dist/unstable-core-do-not-import/error/getErrorShape.d.ts +15 -0
- package/dist/unstable-core-do-not-import/error/getErrorShape.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/error/getErrorShape.js +32 -0
- package/dist/unstable-core-do-not-import/error/getErrorShape.mjs +30 -0
- package/dist/unstable-core-do-not-import/http/batchStreamFormatter.d.ts.map +1 -0
- package/dist/{batchStreamFormatter-fc1ffb26.mjs → unstable-core-do-not-import/http/batchStreamFormatter.mjs} +1 -1
- package/dist/{http → unstable-core-do-not-import/http}/contentType.d.ts +3 -3
- package/dist/unstable-core-do-not-import/http/contentType.d.ts.map +1 -0
- package/dist/{contentType-90bad7bb.js → unstable-core-do-not-import/http/contentType.js} +1 -1
- package/dist/{contentType-93515a46.mjs → unstable-core-do-not-import/http/contentType.mjs} +2 -2
- package/dist/unstable-core-do-not-import/http/getHTTPStatusCode.d.ts +5 -0
- package/dist/unstable-core-do-not-import/http/getHTTPStatusCode.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/http/getHTTPStatusCode.js +53 -0
- package/dist/unstable-core-do-not-import/http/getHTTPStatusCode.mjs +50 -0
- package/dist/unstable-core-do-not-import/http/index.d.ts +12 -0
- package/dist/unstable-core-do-not-import/http/index.d.ts.map +1 -0
- package/dist/{http → unstable-core-do-not-import/http}/resolveHTTPResponse.d.ts +4 -5
- package/dist/unstable-core-do-not-import/http/resolveHTTPResponse.d.ts.map +1 -0
- package/dist/{resolveHTTPResponse-5def1b0c.js → unstable-core-do-not-import/http/resolveHTTPResponse.js} +60 -63
- package/dist/{resolveHTTPResponse-55c648bd.mjs → unstable-core-do-not-import/http/resolveHTTPResponse.mjs} +54 -57
- package/dist/unstable-core-do-not-import/http/toURL.d.ts +2 -0
- package/dist/unstable-core-do-not-import/http/toURL.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/http/toURL.js +8 -0
- package/dist/unstable-core-do-not-import/http/toURL.mjs +6 -0
- package/dist/unstable-core-do-not-import/http/types.d.ts +109 -0
- package/dist/unstable-core-do-not-import/http/types.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/initTRPC.d.ts +102 -0
- package/dist/unstable-core-do-not-import/initTRPC.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/initTRPC.js +82 -0
- package/dist/unstable-core-do-not-import/initTRPC.mjs +80 -0
- package/dist/unstable-core-do-not-import/middleware.d.ts +106 -0
- package/dist/unstable-core-do-not-import/middleware.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/middleware.js +96 -0
- package/dist/unstable-core-do-not-import/middleware.mjs +90 -0
- package/dist/{core → unstable-core-do-not-import}/parser.d.ts +3 -7
- package/dist/unstable-core-do-not-import/parser.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/parser.js +37 -0
- package/dist/unstable-core-do-not-import/parser.mjs +35 -0
- package/dist/{core → unstable-core-do-not-import}/procedure.d.ts +26 -27
- package/dist/unstable-core-do-not-import/procedure.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/procedure.js +9 -0
- package/dist/unstable-core-do-not-import/procedure.mjs +7 -0
- package/dist/unstable-core-do-not-import/procedureBuilder.d.ts +134 -0
- package/dist/unstable-core-do-not-import/procedureBuilder.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/procedureBuilder.js +204 -0
- package/dist/unstable-core-do-not-import/procedureBuilder.mjs +201 -0
- package/dist/{core/internals/config.d.ts → unstable-core-do-not-import/rootConfig.d.ts} +19 -27
- package/dist/unstable-core-do-not-import/rootConfig.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/rootConfig.js +8 -0
- package/dist/unstable-core-do-not-import/rootConfig.mjs +6 -0
- package/dist/unstable-core-do-not-import/router.d.ts +81 -0
- package/dist/unstable-core-do-not-import/router.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/router.js +168 -0
- package/dist/unstable-core-do-not-import/router.mjs +163 -0
- package/dist/{rpc → unstable-core-do-not-import/rpc}/codes.d.ts +8 -16
- package/dist/unstable-core-do-not-import/rpc/codes.d.ts.map +1 -0
- package/dist/{codes-87f6824b.js → unstable-core-do-not-import/rpc/codes.js} +19 -13
- package/dist/{codes-c924c3db.mjs → unstable-core-do-not-import/rpc/codes.mjs} +20 -13
- package/dist/{rpc → unstable-core-do-not-import/rpc}/envelopes.d.ts +6 -4
- package/dist/unstable-core-do-not-import/rpc/envelopes.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/rpc/index.d.ts +5 -0
- package/dist/unstable-core-do-not-import/rpc/index.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/rpc/parseTRPCMessage.d.ts +5 -0
- package/dist/unstable-core-do-not-import/rpc/parseTRPCMessage.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/rpc/parseTRPCMessage.js +59 -0
- package/dist/unstable-core-do-not-import/rpc/parseTRPCMessage.mjs +57 -0
- package/dist/unstable-core-do-not-import/transformer.d.ts +101 -0
- package/dist/unstable-core-do-not-import/transformer.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/transformer.js +106 -0
- package/dist/unstable-core-do-not-import/transformer.mjs +101 -0
- package/dist/unstable-core-do-not-import/types.d.ts +103 -0
- package/dist/unstable-core-do-not-import/types.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/types.js +11 -0
- package/dist/unstable-core-do-not-import/types.mjs +9 -0
- package/dist/unstable-core-do-not-import/utils.d.ts +24 -0
- package/dist/unstable-core-do-not-import/utils.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/utils.js +46 -0
- package/dist/unstable-core-do-not-import/utils.mjs +40 -0
- package/dist/unstable-core-do-not-import.d.ts +31 -0
- package/dist/unstable-core-do-not-import.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import.js +67 -0
- package/dist/unstable-core-do-not-import.mjs +21 -0
- package/package.json +51 -69
- package/src/@trpc/server/http.ts +27 -0
- package/src/@trpc/server/index.ts +100 -0
- package/src/@trpc/server/rpc.ts +26 -0
- package/src/adapters/aws-lambda/index.ts +21 -10
- package/src/adapters/aws-lambda/utils.ts +33 -26
- package/src/adapters/express.ts +18 -4
- package/src/adapters/fastify/fastifyRequestHandler.ts +22 -12
- package/src/adapters/fastify/fastifyTRPCPlugin.ts +21 -9
- package/src/adapters/fetch/fetchRequestHandler.ts +36 -12
- package/src/adapters/fetch/types.ts +18 -4
- package/src/adapters/next-app-dir/formDataToObject.ts +36 -0
- package/src/adapters/next-app-dir/nextAppDirCaller.ts +129 -0
- package/src/adapters/next-app-dir/notFound.ts +12 -0
- package/src/adapters/next-app-dir/redirect.ts +30 -0
- package/src/adapters/next-app-dir/rethrowNextErrors.ts +25 -0
- package/src/adapters/next-app-dir.ts +3 -0
- package/src/adapters/next.ts +30 -14
- package/src/adapters/node-http/content-type/form-data/fileUploadHandler.ts +11 -4
- package/src/adapters/node-http/content-type/form-data/index.ts +18 -18
- package/src/adapters/node-http/content-type/form-data/memoryUploadHandler.ts +3 -2
- package/src/adapters/node-http/content-type/form-data/streamSlice.ts +7 -2
- package/src/adapters/node-http/content-type/form-data/uploadHandler.ts +2 -2
- package/src/adapters/node-http/content-type/json/getPostBody.ts +20 -3
- package/src/adapters/node-http/content-type/json/index.ts +1 -1
- package/src/adapters/node-http/internals/contentType.ts +5 -3
- package/src/adapters/node-http/nodeHTTPRequestHandler.ts +28 -16
- package/src/adapters/node-http/types.ts +24 -9
- package/src/adapters/standalone.ts +22 -8
- package/src/adapters/ws.ts +67 -114
- package/src/http.ts +1 -0
- package/src/index.ts +1 -20
- package/src/observable/index.ts +10 -4
- package/src/observable/observable.ts +63 -3
- package/src/observable/operators.ts +114 -0
- package/src/observable/types.ts +1 -5
- package/src/rpc.ts +1 -0
- package/src/shared.ts +26 -0
- package/src/unstable-core-do-not-import/clientish/inference.ts +60 -0
- package/src/unstable-core-do-not-import/clientish/inferrable.ts +49 -0
- package/src/unstable-core-do-not-import/clientish/serialize.ts +122 -0
- package/src/{error → unstable-core-do-not-import/error}/TRPCError.ts +33 -27
- package/src/{error → unstable-core-do-not-import/error}/formatter.ts +12 -19
- package/src/{shared → unstable-core-do-not-import/error}/getErrorShape.ts +8 -8
- package/src/{http → unstable-core-do-not-import/http}/contentType.ts +4 -4
- package/src/{http → unstable-core-do-not-import/http}/getHTTPStatusCode.ts +8 -8
- package/src/unstable-core-do-not-import/http/index.ts +29 -0
- package/src/{http → unstable-core-do-not-import/http}/resolveHTTPResponse.ts +69 -69
- package/src/unstable-core-do-not-import/http/toURL.ts +7 -0
- package/src/unstable-core-do-not-import/http/types.ts +126 -0
- package/src/unstable-core-do-not-import/initTRPC.ts +152 -0
- package/src/unstable-core-do-not-import/middleware.ts +238 -0
- package/src/unstable-core-do-not-import/parser.ts +94 -0
- package/src/{core → unstable-core-do-not-import}/procedure.ts +37 -35
- package/src/unstable-core-do-not-import/procedureBuilder.ts +623 -0
- package/src/{core/internals/config.ts → unstable-core-do-not-import/rootConfig.ts} +22 -33
- package/src/unstable-core-do-not-import/router.ts +363 -0
- package/src/{rpc → unstable-core-do-not-import/rpc}/codes.ts +30 -3
- package/src/{rpc → unstable-core-do-not-import/rpc}/envelopes.ts +6 -9
- package/src/unstable-core-do-not-import/rpc/index.ts +21 -0
- package/src/unstable-core-do-not-import/rpc/parseTRPCMessage.ts +85 -0
- package/src/unstable-core-do-not-import/transformer.ts +194 -0
- package/src/unstable-core-do-not-import/types.ts +157 -0
- package/src/unstable-core-do-not-import/utils.ts +55 -0
- package/src/unstable-core-do-not-import.ts +30 -0
- package/unstable-core-do-not-import/index.d.ts +1 -0
- package/unstable-core-do-not-import/index.js +1 -0
- package/dist/TRPCError-efecb077.js +0 -63
- package/dist/batchStreamFormatter-2c1405a1.js +0 -31
- package/dist/codes-e5bb4d58.js +0 -48
- package/dist/config-5de7eae5.js +0 -10
- package/dist/config-60fc2667.js +0 -7
- package/dist/config-ab4c1c6b.mjs +0 -5
- package/dist/contentType-24c44bba.js +0 -5
- package/dist/contentType-9940f5d7.js +0 -58
- package/dist/core/index.d.ts +0 -9
- package/dist/core/index.d.ts.map +0 -1
- package/dist/core/initTRPC.d.ts +0 -105
- package/dist/core/initTRPC.d.ts.map +0 -1
- package/dist/core/internals/builderTypes.d.ts +0 -11
- package/dist/core/internals/builderTypes.d.ts.map +0 -1
- package/dist/core/internals/config.d.ts.map +0 -1
- package/dist/core/internals/getParseFn.d.ts +0 -4
- package/dist/core/internals/getParseFn.d.ts.map +0 -1
- package/dist/core/internals/mergeRouters.d.ts +0 -15
- package/dist/core/internals/mergeRouters.d.ts.map +0 -1
- package/dist/core/internals/mergeWithoutOverrides.d.ts +0 -5
- package/dist/core/internals/mergeWithoutOverrides.d.ts.map +0 -1
- package/dist/core/internals/omitPrototype.d.ts +0 -6
- package/dist/core/internals/omitPrototype.d.ts.map +0 -1
- package/dist/core/internals/procedureBuilder.d.ts +0 -113
- package/dist/core/internals/procedureBuilder.d.ts.map +0 -1
- package/dist/core/internals/utils.d.ts +0 -51
- package/dist/core/internals/utils.d.ts.map +0 -1
- package/dist/core/middleware.d.ts +0 -158
- package/dist/core/middleware.d.ts.map +0 -1
- package/dist/core/parser.d.ts.map +0 -1
- package/dist/core/procedure.d.ts.map +0 -1
- package/dist/core/router.d.ts +0 -65
- package/dist/core/router.d.ts.map +0 -1
- package/dist/core/types.d.ts +0 -24
- package/dist/core/types.d.ts.map +0 -1
- package/dist/error/TRPCError.d.ts.map +0 -1
- package/dist/error/formatter.d.ts.map +0 -1
- package/dist/error/utils.d.ts +0 -9
- package/dist/error/utils.d.ts.map +0 -1
- package/dist/http/batchStreamFormatter.d.ts.map +0 -1
- package/dist/http/contentType.d.ts.map +0 -1
- package/dist/http/getHTTPStatusCode.d.ts +0 -24
- package/dist/http/getHTTPStatusCode.d.ts.map +0 -1
- package/dist/http/index.d.ts +0 -5
- package/dist/http/index.d.ts.map +0 -1
- package/dist/http/index.js +0 -21
- package/dist/http/index.mjs +0 -9
- package/dist/http/internals/types.d.ts +0 -32
- package/dist/http/internals/types.d.ts.map +0 -1
- package/dist/http/resolveHTTPResponse.d.ts.map +0 -1
- package/dist/http/types.d.ts +0 -46
- package/dist/http/types.d.ts.map +0 -1
- package/dist/index-46cb3130.js +0 -94
- package/dist/index-f91d720c.mjs +0 -97
- package/dist/internals/invert.d.ts +0 -12
- package/dist/internals/invert.d.ts.map +0 -1
- package/dist/internals/types.d.ts +0 -26
- package/dist/internals/types.d.ts.map +0 -1
- package/dist/nodeHTTPRequestHandler-388f5fce.js +0 -107
- package/dist/observable/internals/identity.d.ts +0 -2
- package/dist/observable/internals/identity.d.ts.map +0 -1
- package/dist/observable/internals/observableToPromise.d.ts +0 -10
- package/dist/observable/internals/observableToPromise.d.ts.map +0 -1
- package/dist/observable/internals/pipe.d.ts +0 -4
- package/dist/observable/internals/pipe.d.ts.map +0 -1
- package/dist/observable/operators/index.d.ts +0 -4
- package/dist/observable/operators/index.d.ts.map +0 -1
- package/dist/observable/operators/map.d.ts +0 -3
- package/dist/observable/operators/map.d.ts.map +0 -1
- package/dist/observable/operators/share.d.ts +0 -6
- package/dist/observable/operators/share.d.ts.map +0 -1
- package/dist/observable/operators/tap.d.ts +0 -3
- package/dist/observable/operators/tap.d.ts.map +0 -1
- package/dist/observable-15588f28.js +0 -83
- package/dist/resolveHTTPResponse-8d474952.js +0 -267
- package/dist/router-3c22fe56.js +0 -159
- package/dist/router-5274e533.mjs +0 -153
- package/dist/router-a1635eab.js +0 -147
- package/dist/rpc/codes.d.ts.map +0 -1
- package/dist/rpc/envelopes.d.ts.map +0 -1
- package/dist/rpc/index.d.ts +0 -3
- package/dist/rpc/index.d.ts.map +0 -1
- package/dist/rpc/index.js +0 -10
- package/dist/rpc/index.mjs +0 -1
- package/dist/shared/createProxy/index.d.ts.map +0 -1
- package/dist/shared/getErrorShape.d.ts +0 -15
- package/dist/shared/getErrorShape.d.ts.map +0 -1
- package/dist/shared/index.d.ts +0 -7
- package/dist/shared/index.d.ts.map +0 -1
- package/dist/shared/index.js +0 -14
- package/dist/shared/index.mjs +0 -3
- package/dist/shared/internal/serialize.d.ts +0 -30
- package/dist/shared/internal/serialize.d.ts.map +0 -1
- package/dist/shared/jsonify.d.ts +0 -11
- package/dist/shared/jsonify.d.ts.map +0 -1
- package/dist/shared/transformTRPCResponse.d.ts +0 -9
- package/dist/shared/transformTRPCResponse.d.ts.map +0 -1
- package/dist/shared/types.d.ts +0 -6
- package/dist/shared/types.d.ts.map +0 -1
- package/dist/transformTRPCResponse-1153b421.mjs +0 -53
- package/dist/transformTRPCResponse-20ce3b68.js +0 -54
- package/dist/transformTRPCResponse-e65f34e9.js +0 -56
- package/dist/transformer.d.ts +0 -74
- package/dist/transformer.d.ts.map +0 -1
- package/dist/types.d.ts +0 -83
- package/dist/types.d.ts.map +0 -1
- package/dist/unstableInternalsExport-10cc2bae.mjs +0 -353
- package/dist/unstableInternalsExport-a064a7dd.js +0 -349
- package/dist/unstableInternalsExport-bf8496ea.js +0 -363
- package/dist/unstableInternalsExport.d.ts +0 -11
- package/dist/unstableInternalsExport.d.ts.map +0 -1
- package/dist/unstableInternalsExport.js +0 -16
- package/dist/unstableInternalsExport.mjs +0 -5
- package/src/core/index.ts +0 -28
- package/src/core/initTRPC.ts +0 -169
- package/src/core/internals/builderTypes.ts +0 -11
- package/src/core/internals/getParseFn.ts +0 -43
- package/src/core/internals/mergeRouters.ts +0 -90
- package/src/core/internals/mergeWithoutOverrides.ts +0 -19
- package/src/core/internals/omitPrototype.ts +0 -9
- package/src/core/internals/procedureBuilder.ts +0 -394
- package/src/core/internals/utils.ts +0 -84
- package/src/core/middleware.ts +0 -295
- package/src/core/parser.ts +0 -57
- package/src/core/router.ts +0 -226
- package/src/core/types.ts +0 -67
- package/src/error/utils.ts +0 -23
- package/src/http/index.ts +0 -4
- package/src/http/internals/types.ts +0 -40
- package/src/http/types.ts +0 -51
- package/src/internals/invert.ts +0 -21
- package/src/internals/types.ts +0 -27
- package/src/observable/internals/identity.ts +0 -3
- package/src/observable/internals/observableToPromise.ts +0 -49
- package/src/observable/internals/pipe.ts +0 -23
- package/src/observable/operators/index.ts +0 -3
- package/src/observable/operators/map.ts +0 -25
- package/src/observable/operators/share.ts +0 -65
- package/src/observable/operators/tap.ts +0 -26
- package/src/rpc/index.ts +0 -2
- package/src/shared/index.ts +0 -10
- package/src/shared/internal/serialize.ts +0 -65
- package/src/shared/jsonify.ts +0 -22
- package/src/shared/transformTRPCResponse.ts +0 -40
- package/src/shared/types.ts +0 -9
- package/src/transformer.ts +0 -94
- package/src/types.ts +0 -125
- package/src/unstableInternalsExport.ts +0 -10
- package/subscription/index.d.ts +0 -1
- package/subscription/index.js +0 -1
- package/unstableInternalsExport/index.d.ts +0 -1
- package/unstableInternalsExport/index.js +0 -1
- /package/dist/{http → unstable-core-do-not-import/http}/batchStreamFormatter.d.ts +0 -0
- /package/dist/{batchStreamFormatter-93cdcdd4.js → unstable-core-do-not-import/http/batchStreamFormatter.js} +0 -0
- /package/src/{shared/createProxy/index.ts → unstable-core-do-not-import/createProxy.ts} +0 -0
- /package/src/{http → unstable-core-do-not-import/http}/batchStreamFormatter.ts +0 -0
|
@@ -1,125 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import { r as resolveHTTPResponse } from '../../resolveHTTPResponse-55c648bd.mjs';
|
|
4
|
-
import { g as getBatchStreamFormatter } from '../../batchStreamFormatter-fc1ffb26.mjs';
|
|
5
|
-
import { applyWSSHandler } from '../ws.mjs';
|
|
6
|
-
import '../../codes-c924c3db.mjs';
|
|
7
|
-
import '../../router-5274e533.mjs';
|
|
8
|
-
import '../../TRPCError-816ff32e.mjs';
|
|
9
|
-
import '../../config-ab4c1c6b.mjs';
|
|
10
|
-
import '../../transformTRPCResponse-1153b421.mjs';
|
|
11
|
-
import '../../contentType-93515a46.mjs';
|
|
12
|
-
import '../../observable-ade1bad8.mjs';
|
|
13
|
-
|
|
14
|
-
async function fastifyRequestHandler(opts) {
|
|
15
|
-
const createContext = async (innerOpts)=>{
|
|
16
|
-
return await opts.createContext?.({
|
|
17
|
-
...opts,
|
|
18
|
-
...innerOpts
|
|
19
|
-
});
|
|
20
|
-
};
|
|
21
|
-
const query = opts.req.query ? new URLSearchParams(opts.req.query) : new URLSearchParams(opts.req.url.split('?')[1]);
|
|
22
|
-
const req = {
|
|
23
|
-
query,
|
|
24
|
-
method: opts.req.method,
|
|
25
|
-
headers: opts.req.headers,
|
|
26
|
-
body: opts.req.body ?? 'null'
|
|
27
|
-
};
|
|
28
|
-
let resolve;
|
|
29
|
-
const promise = new Promise((r)=>resolve = r);
|
|
30
|
-
let isStream = false;
|
|
31
|
-
let stream;
|
|
32
|
-
let formatter;
|
|
33
|
-
const unstable_onHead = (head, isStreaming)=>{
|
|
34
|
-
if (!opts.res.statusCode || opts.res.statusCode === 200) {
|
|
35
|
-
opts.res.statusCode = head.status;
|
|
36
|
-
}
|
|
37
|
-
for (const [key, value] of Object.entries(head.headers ?? {})){
|
|
38
|
-
/* istanbul ignore if -- @preserve */ if (typeof value === 'undefined') {
|
|
39
|
-
continue;
|
|
40
|
-
}
|
|
41
|
-
void opts.res.header(key, value);
|
|
42
|
-
}
|
|
43
|
-
if (isStreaming) {
|
|
44
|
-
void opts.res.header('Transfer-Encoding', 'chunked');
|
|
45
|
-
void opts.res.header('Vary', opts.res.hasHeader('Vary') ? 'trpc-batch-mode, ' + opts.res.getHeader('Vary') : 'trpc-batch-mode');
|
|
46
|
-
stream = new Readable();
|
|
47
|
-
stream._read = ()=>{}; // eslint-disable-line @typescript-eslint/no-empty-function -- https://github.com/fastify/fastify/issues/805#issuecomment-369172154
|
|
48
|
-
resolve(opts.res.send(stream));
|
|
49
|
-
isStream = true;
|
|
50
|
-
formatter = getBatchStreamFormatter();
|
|
51
|
-
}
|
|
52
|
-
};
|
|
53
|
-
const unstable_onChunk = ([index, string])=>{
|
|
54
|
-
if (index === -1) {
|
|
55
|
-
// full response, no streaming
|
|
56
|
-
resolve(opts.res.send(string));
|
|
57
|
-
} else {
|
|
58
|
-
stream.push(formatter(index, string));
|
|
59
|
-
}
|
|
60
|
-
};
|
|
61
|
-
resolveHTTPResponse({
|
|
62
|
-
req,
|
|
63
|
-
createContext,
|
|
64
|
-
path: opts.path,
|
|
65
|
-
router: opts.router,
|
|
66
|
-
batching: opts.batching,
|
|
67
|
-
responseMeta: opts.responseMeta,
|
|
68
|
-
onError (o) {
|
|
69
|
-
opts?.onError?.({
|
|
70
|
-
...o,
|
|
71
|
-
req: opts.req
|
|
72
|
-
});
|
|
73
|
-
},
|
|
74
|
-
unstable_onHead,
|
|
75
|
-
unstable_onChunk
|
|
76
|
-
}).then(()=>{
|
|
77
|
-
if (isStream) {
|
|
78
|
-
stream.push(formatter.end());
|
|
79
|
-
stream.push(null); // https://github.com/fastify/fastify/issues/805#issuecomment-369172154
|
|
80
|
-
}
|
|
81
|
-
}).catch(()=>{
|
|
82
|
-
if (isStream) {
|
|
83
|
-
stream.push(null);
|
|
84
|
-
}
|
|
85
|
-
});
|
|
86
|
-
return promise;
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
/// <reference types="@fastify/websocket" />
|
|
90
|
-
function fastifyTRPCPlugin(fastify, opts, done) {
|
|
91
|
-
fastify.removeContentTypeParser('application/json');
|
|
92
|
-
fastify.addContentTypeParser('application/json', {
|
|
93
|
-
parseAs: 'string'
|
|
94
|
-
}, function(_, body, _done) {
|
|
95
|
-
_done(null, body);
|
|
96
|
-
});
|
|
97
|
-
let prefix = opts.prefix ?? '';
|
|
98
|
-
// https://github.com/fastify/fastify-plugin/blob/fe079bef6557a83794bf437e14b9b9edb8a74104/plugin.js#L11
|
|
99
|
-
// @ts-expect-error property 'default' does not exists on type ...
|
|
100
|
-
if (typeof fastifyTRPCPlugin.default !== 'function') {
|
|
101
|
-
prefix = ''; // handled by fastify internally
|
|
102
|
-
}
|
|
103
|
-
fastify.all(`${prefix}/:path`, async (req, res)=>{
|
|
104
|
-
const path = req.params.path;
|
|
105
|
-
await fastifyRequestHandler({
|
|
106
|
-
...opts.trpcOptions,
|
|
107
|
-
req,
|
|
108
|
-
res,
|
|
109
|
-
path
|
|
110
|
-
});
|
|
111
|
-
});
|
|
112
|
-
if (opts.useWSS) {
|
|
113
|
-
applyWSSHandler({
|
|
114
|
-
...opts.trpcOptions,
|
|
115
|
-
wss: fastify.websocketServer
|
|
116
|
-
});
|
|
117
|
-
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
118
|
-
fastify.get(prefix ?? '/', {
|
|
119
|
-
websocket: true
|
|
120
|
-
}, ()=>{});
|
|
121
|
-
}
|
|
122
|
-
done();
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
export { fastifyRequestHandler, fastifyTRPCPlugin };
|
|
1
|
+
export { fastifyRequestHandler } from './fastifyRequestHandler.mjs';
|
|
2
|
+
export { fastifyTRPCPlugin } from './fastifyTRPCPlugin.mjs';
|
|
@@ -1,5 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
import
|
|
1
|
+
/**
|
|
2
|
+
* If you're making an adapter for tRPC and looking at this file for reference, you should import types and functions from `@trpc/server` and `@trpc/server/http`
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* ```ts
|
|
6
|
+
* import type { AnyTRPCRouter } from '@trpc/server'
|
|
7
|
+
* import type { HTTPBaseHandlerOptions } from '@trpc/server/http'
|
|
8
|
+
* ```
|
|
9
|
+
*/
|
|
10
|
+
import type { AnyRouter } from '../../@trpc/server';
|
|
11
|
+
import type { FetchHandlerOptions } from './types';
|
|
3
12
|
export type FetchHandlerRequestOptions<TRouter extends AnyRouter> = FetchHandlerOptions<TRouter> & {
|
|
4
13
|
req: Request;
|
|
5
14
|
endpoint: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetchRequestHandler.d.ts","sourceRoot":"","sources":["../../../src/adapters/fetch/fetchRequestHandler.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"fetchRequestHandler.d.ts","sourceRoot":"","sources":["../../../src/adapters/fetch/fetchRequestHandler.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAGH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAYpD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAC;AAEnD,MAAM,MAAM,0BAA0B,CAAC,OAAO,SAAS,SAAS,IAC9D,mBAAmB,CAAC,OAAO,CAAC,GAAG;IAC7B,GAAG,EAAE,OAAO,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AASJ,wBAAsB,mBAAmB,CAAC,OAAO,SAAS,SAAS,EACjE,IAAI,EAAE,0BAA0B,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,QAAQ,CAAC,CAuGnB"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
require('../../unstable-core-do-not-import/utils.js');
|
|
4
|
+
var resolveHTTPResponse = require('../../unstable-core-do-not-import/http/resolveHTTPResponse.js');
|
|
5
|
+
var batchStreamFormatter = require('../../unstable-core-do-not-import/http/batchStreamFormatter.js');
|
|
6
|
+
var toURL = require('../../unstable-core-do-not-import/http/toURL.js');
|
|
7
|
+
require('../../unstable-core-do-not-import/rootConfig.js');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* If you're making an adapter for tRPC and looking at this file for reference, you should import types and functions from `@trpc/server` and `@trpc/server/http`
|
|
11
|
+
*
|
|
12
|
+
* @example
|
|
13
|
+
* ```ts
|
|
14
|
+
* import type { AnyTRPCRouter } from '@trpc/server'
|
|
15
|
+
* import type { HTTPBaseHandlerOptions } from '@trpc/server/http'
|
|
16
|
+
* ```
|
|
17
|
+
*/ // @trpc/server
|
|
18
|
+
const trimSlashes = (path)=>{
|
|
19
|
+
path = path.startsWith('/') ? path.slice(1) : path;
|
|
20
|
+
path = path.endsWith('/') ? path.slice(0, -1) : path;
|
|
21
|
+
return path;
|
|
22
|
+
};
|
|
23
|
+
async function fetchRequestHandler(opts) {
|
|
24
|
+
const resHeaders = new Headers();
|
|
25
|
+
const createContext = async (innerOpts)=>{
|
|
26
|
+
return opts.createContext?.({
|
|
27
|
+
req: opts.req,
|
|
28
|
+
resHeaders,
|
|
29
|
+
...innerOpts
|
|
30
|
+
});
|
|
31
|
+
};
|
|
32
|
+
const url = toURL.toURL(opts.req.url);
|
|
33
|
+
const pathname = trimSlashes(url.pathname);
|
|
34
|
+
const endpoint = trimSlashes(opts.endpoint);
|
|
35
|
+
const path = trimSlashes(pathname.slice(endpoint.length));
|
|
36
|
+
const req = {
|
|
37
|
+
query: url.searchParams,
|
|
38
|
+
method: opts.req.method,
|
|
39
|
+
headers: Object.fromEntries(opts.req.headers),
|
|
40
|
+
body: opts.req.headers.get('content-type')?.startsWith('application/json') ? await opts.req.text() : ''
|
|
41
|
+
};
|
|
42
|
+
let resolve;
|
|
43
|
+
const promise = new Promise((r)=>resolve = r);
|
|
44
|
+
let status = 200;
|
|
45
|
+
let isStream = false;
|
|
46
|
+
let controller;
|
|
47
|
+
let encoder;
|
|
48
|
+
let formatter;
|
|
49
|
+
const unstable_onHead = (head, isStreaming)=>{
|
|
50
|
+
for (const [key, value] of Object.entries(head.headers ?? {})){
|
|
51
|
+
/* istanbul ignore if -- @preserve */ if (typeof value === 'undefined') {
|
|
52
|
+
continue;
|
|
53
|
+
}
|
|
54
|
+
if (typeof value === 'string') {
|
|
55
|
+
resHeaders.set(key, value);
|
|
56
|
+
continue;
|
|
57
|
+
}
|
|
58
|
+
for (const v of value){
|
|
59
|
+
resHeaders.append(key, v);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
status = head.status;
|
|
63
|
+
if (isStreaming) {
|
|
64
|
+
resHeaders.set('Transfer-Encoding', 'chunked');
|
|
65
|
+
resHeaders.append('Vary', 'trpc-batch-mode');
|
|
66
|
+
const stream = new ReadableStream({
|
|
67
|
+
start (c) {
|
|
68
|
+
controller = c;
|
|
69
|
+
}
|
|
70
|
+
});
|
|
71
|
+
const response = new Response(stream, {
|
|
72
|
+
status,
|
|
73
|
+
headers: resHeaders
|
|
74
|
+
});
|
|
75
|
+
resolve(response);
|
|
76
|
+
encoder = new TextEncoder();
|
|
77
|
+
formatter = batchStreamFormatter.getBatchStreamFormatter();
|
|
78
|
+
isStream = true;
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
const unstable_onChunk = ([index, string])=>{
|
|
82
|
+
if (index === -1) {
|
|
83
|
+
// full response, no streaming
|
|
84
|
+
const response = new Response(string || null, {
|
|
85
|
+
status,
|
|
86
|
+
headers: resHeaders
|
|
87
|
+
});
|
|
88
|
+
resolve(response);
|
|
89
|
+
} else {
|
|
90
|
+
controller.enqueue(encoder.encode(formatter(index, string)));
|
|
91
|
+
}
|
|
92
|
+
};
|
|
93
|
+
resolveHTTPResponse.resolveHTTPResponse({
|
|
94
|
+
...opts,
|
|
95
|
+
req,
|
|
96
|
+
createContext,
|
|
97
|
+
path,
|
|
98
|
+
onError (o) {
|
|
99
|
+
opts?.onError?.({
|
|
100
|
+
...o,
|
|
101
|
+
req: opts.req
|
|
102
|
+
});
|
|
103
|
+
},
|
|
104
|
+
unstable_onHead,
|
|
105
|
+
unstable_onChunk
|
|
106
|
+
}).then(()=>{
|
|
107
|
+
if (isStream) {
|
|
108
|
+
controller.enqueue(encoder.encode(formatter.end()));
|
|
109
|
+
controller.close();
|
|
110
|
+
}
|
|
111
|
+
}).catch(()=>{
|
|
112
|
+
if (isStream) {
|
|
113
|
+
controller.close();
|
|
114
|
+
}
|
|
115
|
+
});
|
|
116
|
+
return promise;
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
exports.fetchRequestHandler = fetchRequestHandler;
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import '../../unstable-core-do-not-import/utils.mjs';
|
|
2
|
+
import { resolveHTTPResponse } from '../../unstable-core-do-not-import/http/resolveHTTPResponse.mjs';
|
|
3
|
+
import { getBatchStreamFormatter } from '../../unstable-core-do-not-import/http/batchStreamFormatter.mjs';
|
|
4
|
+
import { toURL } from '../../unstable-core-do-not-import/http/toURL.mjs';
|
|
5
|
+
import '../../unstable-core-do-not-import/rootConfig.mjs';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* If you're making an adapter for tRPC and looking at this file for reference, you should import types and functions from `@trpc/server` and `@trpc/server/http`
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* ```ts
|
|
12
|
+
* import type { AnyTRPCRouter } from '@trpc/server'
|
|
13
|
+
* import type { HTTPBaseHandlerOptions } from '@trpc/server/http'
|
|
14
|
+
* ```
|
|
15
|
+
*/ // @trpc/server
|
|
16
|
+
const trimSlashes = (path)=>{
|
|
17
|
+
path = path.startsWith('/') ? path.slice(1) : path;
|
|
18
|
+
path = path.endsWith('/') ? path.slice(0, -1) : path;
|
|
19
|
+
return path;
|
|
20
|
+
};
|
|
21
|
+
async function fetchRequestHandler(opts) {
|
|
22
|
+
const resHeaders = new Headers();
|
|
23
|
+
const createContext = async (innerOpts)=>{
|
|
24
|
+
return opts.createContext?.({
|
|
25
|
+
req: opts.req,
|
|
26
|
+
resHeaders,
|
|
27
|
+
...innerOpts
|
|
28
|
+
});
|
|
29
|
+
};
|
|
30
|
+
const url = toURL(opts.req.url);
|
|
31
|
+
const pathname = trimSlashes(url.pathname);
|
|
32
|
+
const endpoint = trimSlashes(opts.endpoint);
|
|
33
|
+
const path = trimSlashes(pathname.slice(endpoint.length));
|
|
34
|
+
const req = {
|
|
35
|
+
query: url.searchParams,
|
|
36
|
+
method: opts.req.method,
|
|
37
|
+
headers: Object.fromEntries(opts.req.headers),
|
|
38
|
+
body: opts.req.headers.get('content-type')?.startsWith('application/json') ? await opts.req.text() : ''
|
|
39
|
+
};
|
|
40
|
+
let resolve;
|
|
41
|
+
const promise = new Promise((r)=>resolve = r);
|
|
42
|
+
let status = 200;
|
|
43
|
+
let isStream = false;
|
|
44
|
+
let controller;
|
|
45
|
+
let encoder;
|
|
46
|
+
let formatter;
|
|
47
|
+
const unstable_onHead = (head, isStreaming)=>{
|
|
48
|
+
for (const [key, value] of Object.entries(head.headers ?? {})){
|
|
49
|
+
/* istanbul ignore if -- @preserve */ if (typeof value === 'undefined') {
|
|
50
|
+
continue;
|
|
51
|
+
}
|
|
52
|
+
if (typeof value === 'string') {
|
|
53
|
+
resHeaders.set(key, value);
|
|
54
|
+
continue;
|
|
55
|
+
}
|
|
56
|
+
for (const v of value){
|
|
57
|
+
resHeaders.append(key, v);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
status = head.status;
|
|
61
|
+
if (isStreaming) {
|
|
62
|
+
resHeaders.set('Transfer-Encoding', 'chunked');
|
|
63
|
+
resHeaders.append('Vary', 'trpc-batch-mode');
|
|
64
|
+
const stream = new ReadableStream({
|
|
65
|
+
start (c) {
|
|
66
|
+
controller = c;
|
|
67
|
+
}
|
|
68
|
+
});
|
|
69
|
+
const response = new Response(stream, {
|
|
70
|
+
status,
|
|
71
|
+
headers: resHeaders
|
|
72
|
+
});
|
|
73
|
+
resolve(response);
|
|
74
|
+
encoder = new TextEncoder();
|
|
75
|
+
formatter = getBatchStreamFormatter();
|
|
76
|
+
isStream = true;
|
|
77
|
+
}
|
|
78
|
+
};
|
|
79
|
+
const unstable_onChunk = ([index, string])=>{
|
|
80
|
+
if (index === -1) {
|
|
81
|
+
// full response, no streaming
|
|
82
|
+
const response = new Response(string || null, {
|
|
83
|
+
status,
|
|
84
|
+
headers: resHeaders
|
|
85
|
+
});
|
|
86
|
+
resolve(response);
|
|
87
|
+
} else {
|
|
88
|
+
controller.enqueue(encoder.encode(formatter(index, string)));
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
resolveHTTPResponse({
|
|
92
|
+
...opts,
|
|
93
|
+
req,
|
|
94
|
+
createContext,
|
|
95
|
+
path,
|
|
96
|
+
onError (o) {
|
|
97
|
+
opts?.onError?.({
|
|
98
|
+
...o,
|
|
99
|
+
req: opts.req
|
|
100
|
+
});
|
|
101
|
+
},
|
|
102
|
+
unstable_onHead,
|
|
103
|
+
unstable_onChunk
|
|
104
|
+
}).then(()=>{
|
|
105
|
+
if (isStream) {
|
|
106
|
+
controller.enqueue(encoder.encode(formatter.end()));
|
|
107
|
+
controller.close();
|
|
108
|
+
}
|
|
109
|
+
}).catch(()=>{
|
|
110
|
+
if (isStream) {
|
|
111
|
+
controller.close();
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
return promise;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
export { fetchRequestHandler };
|
|
@@ -1,111 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
var fetchRequestHandler = require('./fetchRequestHandler.js');
|
|
4
4
|
|
|
5
|
-
require('../../index-784ff647.js');
|
|
6
|
-
var resolveHTTPResponse = require('../../resolveHTTPResponse-5def1b0c.js');
|
|
7
|
-
var batchStreamFormatter = require('../../batchStreamFormatter-93cdcdd4.js');
|
|
8
|
-
require('../../codes-87f6824b.js');
|
|
9
|
-
require('../../router-3c22fe56.js');
|
|
10
|
-
require('../../TRPCError-ae7b67e8.js');
|
|
11
|
-
require('../../config-60fc2667.js');
|
|
12
|
-
require('../../transformTRPCResponse-e65f34e9.js');
|
|
13
|
-
require('../../contentType-90bad7bb.js');
|
|
14
5
|
|
|
15
|
-
async function fetchRequestHandler(opts) {
|
|
16
|
-
const resHeaders = new Headers();
|
|
17
|
-
const createContext = async (innerOpts)=>{
|
|
18
|
-
return opts.createContext?.({
|
|
19
|
-
req: opts.req,
|
|
20
|
-
resHeaders,
|
|
21
|
-
...innerOpts
|
|
22
|
-
});
|
|
23
|
-
};
|
|
24
|
-
const url = new URL(opts.req.url);
|
|
25
|
-
const path = url.pathname.slice(opts.endpoint.length + 1);
|
|
26
|
-
const req = {
|
|
27
|
-
query: url.searchParams,
|
|
28
|
-
method: opts.req.method,
|
|
29
|
-
headers: Object.fromEntries(opts.req.headers),
|
|
30
|
-
body: opts.req.headers.get('content-type')?.startsWith('application/json') ? await opts.req.text() : ''
|
|
31
|
-
};
|
|
32
|
-
let resolve;
|
|
33
|
-
const promise = new Promise((r)=>resolve = r);
|
|
34
|
-
let status = 200;
|
|
35
|
-
let isStream = false;
|
|
36
|
-
let controller;
|
|
37
|
-
let encoder;
|
|
38
|
-
let formatter;
|
|
39
|
-
const unstable_onHead = (head, isStreaming)=>{
|
|
40
|
-
for (const [key, value] of Object.entries(head.headers ?? {})){
|
|
41
|
-
/* istanbul ignore if -- @preserve */ if (typeof value === 'undefined') {
|
|
42
|
-
continue;
|
|
43
|
-
}
|
|
44
|
-
if (typeof value === 'string') {
|
|
45
|
-
resHeaders.set(key, value);
|
|
46
|
-
continue;
|
|
47
|
-
}
|
|
48
|
-
for (const v of value){
|
|
49
|
-
resHeaders.append(key, v);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
status = head.status;
|
|
53
|
-
if (isStreaming) {
|
|
54
|
-
resHeaders.set('Transfer-Encoding', 'chunked');
|
|
55
|
-
resHeaders.append('Vary', 'trpc-batch-mode');
|
|
56
|
-
const stream = new ReadableStream({
|
|
57
|
-
start (c) {
|
|
58
|
-
controller = c;
|
|
59
|
-
}
|
|
60
|
-
});
|
|
61
|
-
const response = new Response(stream, {
|
|
62
|
-
status,
|
|
63
|
-
headers: resHeaders
|
|
64
|
-
});
|
|
65
|
-
resolve(response);
|
|
66
|
-
encoder = new TextEncoder();
|
|
67
|
-
formatter = batchStreamFormatter.getBatchStreamFormatter();
|
|
68
|
-
isStream = true;
|
|
69
|
-
}
|
|
70
|
-
};
|
|
71
|
-
const unstable_onChunk = ([index, string])=>{
|
|
72
|
-
if (index === -1) {
|
|
73
|
-
// full response, no streaming
|
|
74
|
-
const response = new Response(string || null, {
|
|
75
|
-
status,
|
|
76
|
-
headers: resHeaders
|
|
77
|
-
});
|
|
78
|
-
resolve(response);
|
|
79
|
-
} else {
|
|
80
|
-
controller.enqueue(encoder.encode(formatter(index, string)));
|
|
81
|
-
}
|
|
82
|
-
};
|
|
83
|
-
resolveHTTPResponse.resolveHTTPResponse({
|
|
84
|
-
req,
|
|
85
|
-
createContext,
|
|
86
|
-
path,
|
|
87
|
-
router: opts.router,
|
|
88
|
-
batching: opts.batching,
|
|
89
|
-
responseMeta: opts.responseMeta,
|
|
90
|
-
onError (o) {
|
|
91
|
-
opts?.onError?.({
|
|
92
|
-
...o,
|
|
93
|
-
req: opts.req
|
|
94
|
-
});
|
|
95
|
-
},
|
|
96
|
-
unstable_onHead,
|
|
97
|
-
unstable_onChunk
|
|
98
|
-
}).then(()=>{
|
|
99
|
-
if (isStream) {
|
|
100
|
-
controller.enqueue(encoder.encode(formatter.end()));
|
|
101
|
-
controller.close();
|
|
102
|
-
}
|
|
103
|
-
}).catch(()=>{
|
|
104
|
-
if (isStream) {
|
|
105
|
-
controller.close();
|
|
106
|
-
}
|
|
107
|
-
});
|
|
108
|
-
return promise;
|
|
109
|
-
}
|
|
110
6
|
|
|
111
|
-
exports.fetchRequestHandler = fetchRequestHandler;
|
|
7
|
+
exports.fetchRequestHandler = fetchRequestHandler.fetchRequestHandler;
|
|
@@ -1,107 +1 @@
|
|
|
1
|
-
|
|
2
|
-
import { r as resolveHTTPResponse } from '../../resolveHTTPResponse-55c648bd.mjs';
|
|
3
|
-
import { g as getBatchStreamFormatter } from '../../batchStreamFormatter-fc1ffb26.mjs';
|
|
4
|
-
import '../../codes-c924c3db.mjs';
|
|
5
|
-
import '../../router-5274e533.mjs';
|
|
6
|
-
import '../../TRPCError-816ff32e.mjs';
|
|
7
|
-
import '../../config-ab4c1c6b.mjs';
|
|
8
|
-
import '../../transformTRPCResponse-1153b421.mjs';
|
|
9
|
-
import '../../contentType-93515a46.mjs';
|
|
10
|
-
|
|
11
|
-
async function fetchRequestHandler(opts) {
|
|
12
|
-
const resHeaders = new Headers();
|
|
13
|
-
const createContext = async (innerOpts)=>{
|
|
14
|
-
return opts.createContext?.({
|
|
15
|
-
req: opts.req,
|
|
16
|
-
resHeaders,
|
|
17
|
-
...innerOpts
|
|
18
|
-
});
|
|
19
|
-
};
|
|
20
|
-
const url = new URL(opts.req.url);
|
|
21
|
-
const path = url.pathname.slice(opts.endpoint.length + 1);
|
|
22
|
-
const req = {
|
|
23
|
-
query: url.searchParams,
|
|
24
|
-
method: opts.req.method,
|
|
25
|
-
headers: Object.fromEntries(opts.req.headers),
|
|
26
|
-
body: opts.req.headers.get('content-type')?.startsWith('application/json') ? await opts.req.text() : ''
|
|
27
|
-
};
|
|
28
|
-
let resolve;
|
|
29
|
-
const promise = new Promise((r)=>resolve = r);
|
|
30
|
-
let status = 200;
|
|
31
|
-
let isStream = false;
|
|
32
|
-
let controller;
|
|
33
|
-
let encoder;
|
|
34
|
-
let formatter;
|
|
35
|
-
const unstable_onHead = (head, isStreaming)=>{
|
|
36
|
-
for (const [key, value] of Object.entries(head.headers ?? {})){
|
|
37
|
-
/* istanbul ignore if -- @preserve */ if (typeof value === 'undefined') {
|
|
38
|
-
continue;
|
|
39
|
-
}
|
|
40
|
-
if (typeof value === 'string') {
|
|
41
|
-
resHeaders.set(key, value);
|
|
42
|
-
continue;
|
|
43
|
-
}
|
|
44
|
-
for (const v of value){
|
|
45
|
-
resHeaders.append(key, v);
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
status = head.status;
|
|
49
|
-
if (isStreaming) {
|
|
50
|
-
resHeaders.set('Transfer-Encoding', 'chunked');
|
|
51
|
-
resHeaders.append('Vary', 'trpc-batch-mode');
|
|
52
|
-
const stream = new ReadableStream({
|
|
53
|
-
start (c) {
|
|
54
|
-
controller = c;
|
|
55
|
-
}
|
|
56
|
-
});
|
|
57
|
-
const response = new Response(stream, {
|
|
58
|
-
status,
|
|
59
|
-
headers: resHeaders
|
|
60
|
-
});
|
|
61
|
-
resolve(response);
|
|
62
|
-
encoder = new TextEncoder();
|
|
63
|
-
formatter = getBatchStreamFormatter();
|
|
64
|
-
isStream = true;
|
|
65
|
-
}
|
|
66
|
-
};
|
|
67
|
-
const unstable_onChunk = ([index, string])=>{
|
|
68
|
-
if (index === -1) {
|
|
69
|
-
// full response, no streaming
|
|
70
|
-
const response = new Response(string || null, {
|
|
71
|
-
status,
|
|
72
|
-
headers: resHeaders
|
|
73
|
-
});
|
|
74
|
-
resolve(response);
|
|
75
|
-
} else {
|
|
76
|
-
controller.enqueue(encoder.encode(formatter(index, string)));
|
|
77
|
-
}
|
|
78
|
-
};
|
|
79
|
-
resolveHTTPResponse({
|
|
80
|
-
req,
|
|
81
|
-
createContext,
|
|
82
|
-
path,
|
|
83
|
-
router: opts.router,
|
|
84
|
-
batching: opts.batching,
|
|
85
|
-
responseMeta: opts.responseMeta,
|
|
86
|
-
onError (o) {
|
|
87
|
-
opts?.onError?.({
|
|
88
|
-
...o,
|
|
89
|
-
req: opts.req
|
|
90
|
-
});
|
|
91
|
-
},
|
|
92
|
-
unstable_onHead,
|
|
93
|
-
unstable_onChunk
|
|
94
|
-
}).then(()=>{
|
|
95
|
-
if (isStream) {
|
|
96
|
-
controller.enqueue(encoder.encode(formatter.end()));
|
|
97
|
-
controller.close();
|
|
98
|
-
}
|
|
99
|
-
}).catch(()=>{
|
|
100
|
-
if (isStream) {
|
|
101
|
-
controller.close();
|
|
102
|
-
}
|
|
103
|
-
});
|
|
104
|
-
return promise;
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
export { fetchRequestHandler };
|
|
1
|
+
export { fetchRequestHandler } from './fetchRequestHandler.mjs';
|
|
@@ -1,5 +1,14 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
/**
|
|
2
|
+
* If you're making an adapter for tRPC and looking at this file for reference, you should import types and functions from `@trpc/server` and `@trpc/server/http`
|
|
3
|
+
*
|
|
4
|
+
* @example
|
|
5
|
+
* ```ts
|
|
6
|
+
* import type { AnyTRPCRouter } from '@trpc/server'
|
|
7
|
+
* import type { HTTPBaseHandlerOptions } from '@trpc/server/http'
|
|
8
|
+
* ```
|
|
9
|
+
*/
|
|
10
|
+
import type { AnyRouter, inferRouterContext } from '../../@trpc/server';
|
|
11
|
+
import type { HTTPBaseHandlerOptions, TRPCRequestInfo } from '../../@trpc/server/http';
|
|
3
12
|
export type FetchCreateContextFnOptions = {
|
|
4
13
|
req: Request;
|
|
5
14
|
resHeaders: Headers;
|
|
@@ -8,12 +17,12 @@ export type FetchCreateContextFnOptions = {
|
|
|
8
17
|
export type FetchCreateContextFn<TRouter extends AnyRouter> = (opts: FetchCreateContextFnOptions) => inferRouterContext<TRouter> | Promise<inferRouterContext<TRouter>>;
|
|
9
18
|
export type FetchCreateContextOption<TRouter extends AnyRouter> = unknown extends inferRouterContext<TRouter> ? {
|
|
10
19
|
/**
|
|
11
|
-
* @link https://trpc.io/docs/context
|
|
20
|
+
* @link https://trpc.io/docs/v11/context
|
|
12
21
|
**/
|
|
13
22
|
createContext?: FetchCreateContextFn<TRouter>;
|
|
14
23
|
} : {
|
|
15
24
|
/**
|
|
16
|
-
* @link https://trpc.io/docs/context
|
|
25
|
+
* @link https://trpc.io/docs/v11/context
|
|
17
26
|
**/
|
|
18
27
|
createContext: FetchCreateContextFn<TRouter>;
|
|
19
28
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/adapters/fetch/types.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/adapters/fetch/types.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AAExE,OAAO,KAAK,EACV,sBAAsB,EACtB,eAAe,EAChB,MAAM,yBAAyB,CAAC;AAEjC,MAAM,MAAM,2BAA2B,GAAG;IACxC,GAAG,EAAE,OAAO,CAAC;IACb,UAAU,EAAE,OAAO,CAAC;IACpB,IAAI,EAAE,eAAe,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,oBAAoB,CAAC,OAAO,SAAS,SAAS,IAAI,CAC5D,IAAI,EAAE,2BAA2B,KAC9B,kBAAkB,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC;AAExE,MAAM,MAAM,wBAAwB,CAAC,OAAO,SAAS,SAAS,IAC5D,OAAO,SAAS,kBAAkB,CAAC,OAAO,CAAC,GACvC;IACE;;QAEI;IACJ,aAAa,CAAC,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;CAC/C,GACD;IACE;;QAEI;IACJ,aAAa,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;CAC9C,CAAC;AAER,MAAM,MAAM,mBAAmB,CAAC,OAAO,SAAS,SAAS,IACvD,wBAAwB,CAAC,OAAO,CAAC,GAAG,sBAAsB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formDataToObject.d.ts","sourceRoot":"","sources":["../../../src/adapters/next-app-dir/formDataToObject.ts"],"names":[],"mappings":"AA2BA,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,2BAQlD"}
|