@trpc/server 11.0.0-next.92 → 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 -126
- package/dist/adapters/fastify/index.mjs +2 -126
- 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 -17
- package/dist/adapters/ws.d.ts.map +1 -1
- package/dist/adapters/ws.js +35 -22
- package/dist/adapters/ws.mjs +28 -14
- package/dist/bundle-analysis.json +383 -493
- 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.map +1 -0
- package/dist/{parseTRPCMessage-1377f305.js → unstable-core-do-not-import/rpc/parseTRPCMessage.js} +5 -2
- package/dist/{parseTRPCMessage-a0f17853.mjs → unstable-core-do-not-import/rpc/parseTRPCMessage.mjs} +6 -3
- 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 +68 -39
- 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/{rpc → unstable-core-do-not-import/rpc}/parseTRPCMessage.ts +4 -3
- 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/parseTRPCMessage-95955211.js +0 -63
- 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 -4
- package/dist/rpc/index.d.ts.map +0 -1
- package/dist/rpc/index.js +0 -12
- package/dist/rpc/index.mjs +0 -2
- package/dist/rpc/parseTRPCMessage.d.ts.map +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 -3
- 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/dist/{rpc → unstable-core-do-not-import/rpc}/parseTRPCMessage.d.ts +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
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import type { Observable } from '../observable';
|
|
2
|
+
import { TRPCError } from './error/TRPCError';
|
|
3
|
+
import type { AnyProcedure, ErrorHandlerOptions, inferProcedureInput, inferProcedureOutput } from './procedure';
|
|
4
|
+
import type { ProcedureCallOptions } from './procedureBuilder';
|
|
5
|
+
import type { AnyRootTypes, RootConfig } from './rootConfig';
|
|
6
|
+
import type { MaybePromise } from './types';
|
|
7
|
+
export interface RouterRecord {
|
|
8
|
+
[key: string]: AnyProcedure | RouterRecord;
|
|
9
|
+
}
|
|
10
|
+
type DecorateProcedure<TProcedure extends AnyProcedure> = (input: inferProcedureInput<TProcedure>) => Promise<TProcedure['_def']['type'] extends 'subscription' ? Observable<inferProcedureOutput<TProcedure>, TRPCError> : inferProcedureOutput<TProcedure>>;
|
|
11
|
+
/**
|
|
12
|
+
* @internal
|
|
13
|
+
*/
|
|
14
|
+
export type DecorateRouterRecord<TRecord extends RouterRecord> = {
|
|
15
|
+
[TKey in keyof TRecord]: TRecord[TKey] extends AnyProcedure ? DecorateProcedure<TRecord[TKey]> : TRecord[TKey] extends RouterRecord ? DecorateRouterRecord<TRecord[TKey]> : never;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* @internal
|
|
19
|
+
*/
|
|
20
|
+
export type RouterCallerErrorHandler<TContext> = (opts: ErrorHandlerOptions<TContext>) => void;
|
|
21
|
+
/**
|
|
22
|
+
* @internal
|
|
23
|
+
*/
|
|
24
|
+
export type RouterCaller<TRoot extends AnyRootTypes, TRecord extends RouterRecord> = (
|
|
25
|
+
/**
|
|
26
|
+
* @note
|
|
27
|
+
* If passing a function, we recommend it's a cached function
|
|
28
|
+
* e.g. wrapped in `React.cache` to avoid unnecessary computations
|
|
29
|
+
*/
|
|
30
|
+
ctx: TRoot['ctx'] | (() => MaybePromise<TRoot['ctx']>), options?: {
|
|
31
|
+
onError?: RouterCallerErrorHandler<TRoot['ctx']>;
|
|
32
|
+
}) => DecorateRouterRecord<TRecord>;
|
|
33
|
+
export interface Router<TRoot extends AnyRootTypes, TRecord extends RouterRecord> {
|
|
34
|
+
_def: {
|
|
35
|
+
_config: RootConfig<TRoot>;
|
|
36
|
+
router: true;
|
|
37
|
+
procedure?: never;
|
|
38
|
+
procedures: TRecord;
|
|
39
|
+
record: TRecord;
|
|
40
|
+
};
|
|
41
|
+
/**
|
|
42
|
+
* @deprecated use `t.createCallerFactory(router)` instead
|
|
43
|
+
* @link https://trpc.io/docs/v11/server/server-side-calls
|
|
44
|
+
*/
|
|
45
|
+
createCaller: RouterCaller<TRoot, TRecord>;
|
|
46
|
+
}
|
|
47
|
+
export type BuiltRouter<TRoot extends AnyRootTypes, TDef extends RouterRecord> = Router<TRoot, TDef> & TDef;
|
|
48
|
+
export type AnyRouter = Router<any, any>;
|
|
49
|
+
export type inferRouterRootTypes<TRouter extends AnyRouter> = TRouter['_def']['_config']['$types'];
|
|
50
|
+
export type inferRouterContext<TRouter extends AnyRouter> = inferRouterRootTypes<TRouter>['ctx'];
|
|
51
|
+
export type inferRouterError<TRouter extends AnyRouter> = inferRouterRootTypes<TRouter>['errorShape'];
|
|
52
|
+
export type inferRouterMeta<TRouter extends AnyRouter> = inferRouterRootTypes<TRouter>['meta'];
|
|
53
|
+
export type CreateRouterOptions = {
|
|
54
|
+
[key: string]: AnyProcedure | AnyRouter | CreateRouterOptions;
|
|
55
|
+
};
|
|
56
|
+
export type DecorateCreateRouterOptions<TRouterOptions extends CreateRouterOptions> = {
|
|
57
|
+
[K in keyof TRouterOptions]: TRouterOptions[K] extends infer $Value ? $Value extends AnyProcedure ? $Value : $Value extends Router<any, infer TRecord> ? TRecord : $Value extends CreateRouterOptions ? DecorateCreateRouterOptions<$Value> : never : never;
|
|
58
|
+
};
|
|
59
|
+
/**
|
|
60
|
+
* @internal
|
|
61
|
+
*/
|
|
62
|
+
export declare function createRouterFactory<TRoot extends AnyRootTypes>(config: RootConfig<TRoot>): {
|
|
63
|
+
<TInput extends RouterRecord>(input: TInput): BuiltRouter<TRoot, TInput>;
|
|
64
|
+
<TInput_1 extends CreateRouterOptions>(input: TInput_1): BuiltRouter<TRoot, DecorateCreateRouterOptions<TInput_1>>;
|
|
65
|
+
};
|
|
66
|
+
/**
|
|
67
|
+
* @internal
|
|
68
|
+
*/
|
|
69
|
+
export declare function callProcedure(opts: ProcedureCallOptions<unknown> & {
|
|
70
|
+
procedures: RouterRecord;
|
|
71
|
+
allowMethodOverride?: boolean;
|
|
72
|
+
}): Promise<any>;
|
|
73
|
+
export declare function createCallerFactory<TRoot extends AnyRootTypes>(): <TRecord extends RouterRecord>(router: Pick<Router<TRoot, TRecord>, '_def'>) => RouterCaller<TRoot, TRecord>;
|
|
74
|
+
/** @internal */
|
|
75
|
+
type MergeRouters<TRouters extends AnyRouter[], TRoot extends AnyRootTypes = TRouters[0]['_def']['_config']['$types'], TRecord extends RouterRecord = {}> = TRouters extends [
|
|
76
|
+
infer Head extends AnyRouter,
|
|
77
|
+
...infer Tail extends AnyRouter[]
|
|
78
|
+
] ? MergeRouters<Tail, TRoot, Head['_def']['record'] & TRecord> : BuiltRouter<TRoot, TRecord>;
|
|
79
|
+
export declare function mergeRouters<TRouters extends AnyRouter[]>(...routerList: [...TRouters]): MergeRouters<TRouters>;
|
|
80
|
+
export {};
|
|
81
|
+
//# sourceMappingURL=router.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"router.d.ts","sourceRoot":"","sources":["../../src/unstable-core-do-not-import/router.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var createProxy = require('./createProxy.js');
|
|
4
|
+
var formatter = require('./error/formatter.js');
|
|
5
|
+
var TRPCError = require('./error/TRPCError.js');
|
|
6
|
+
var transformer = require('./transformer.js');
|
|
7
|
+
var utils = require('./utils.js');
|
|
8
|
+
|
|
9
|
+
function isRouter(procedureOrRouter) {
|
|
10
|
+
return procedureOrRouter._def && 'router' in procedureOrRouter._def;
|
|
11
|
+
}
|
|
12
|
+
const emptyRouter = {
|
|
13
|
+
_ctx: null,
|
|
14
|
+
_errorShape: null,
|
|
15
|
+
_meta: null,
|
|
16
|
+
queries: {},
|
|
17
|
+
mutations: {},
|
|
18
|
+
subscriptions: {},
|
|
19
|
+
errorFormatter: formatter.defaultFormatter,
|
|
20
|
+
transformer: transformer.defaultTransformer
|
|
21
|
+
};
|
|
22
|
+
/**
|
|
23
|
+
* Reserved words that can't be used as router or procedure names
|
|
24
|
+
*/ const reservedWords = [
|
|
25
|
+
/**
|
|
26
|
+
* Then is a reserved word because otherwise we can't return a promise that returns a Proxy
|
|
27
|
+
* since JS will think that `.then` is something that exists
|
|
28
|
+
*/ 'then'
|
|
29
|
+
];
|
|
30
|
+
/**
|
|
31
|
+
* @internal
|
|
32
|
+
*/ function createRouterFactory(config) {
|
|
33
|
+
function createRouterInner(input) {
|
|
34
|
+
const reservedWordsUsed = new Set(Object.keys(input).filter((v)=>reservedWords.includes(v)));
|
|
35
|
+
if (reservedWordsUsed.size > 0) {
|
|
36
|
+
throw new Error('Reserved words used in `router({})` call: ' + Array.from(reservedWordsUsed).join(', '));
|
|
37
|
+
}
|
|
38
|
+
const procedures = utils.omitPrototype({});
|
|
39
|
+
function step(from, path = []) {
|
|
40
|
+
const aggregate = utils.omitPrototype({});
|
|
41
|
+
for (const [key, item] of Object.entries(from ?? {})){
|
|
42
|
+
if (isRouter(item)) {
|
|
43
|
+
aggregate[key] = step(item._def.record, [
|
|
44
|
+
...path,
|
|
45
|
+
key
|
|
46
|
+
]);
|
|
47
|
+
continue;
|
|
48
|
+
}
|
|
49
|
+
if (!isProcedure(item)) {
|
|
50
|
+
// RouterRecord
|
|
51
|
+
aggregate[key] = step(item, [
|
|
52
|
+
...path,
|
|
53
|
+
key
|
|
54
|
+
]);
|
|
55
|
+
continue;
|
|
56
|
+
}
|
|
57
|
+
const newPath = [
|
|
58
|
+
...path,
|
|
59
|
+
key
|
|
60
|
+
].join('.');
|
|
61
|
+
if (procedures[newPath]) {
|
|
62
|
+
throw new Error(`Duplicate key: ${newPath}`);
|
|
63
|
+
}
|
|
64
|
+
procedures[newPath] = item;
|
|
65
|
+
aggregate[key] = item;
|
|
66
|
+
}
|
|
67
|
+
return aggregate;
|
|
68
|
+
}
|
|
69
|
+
const record = step(input);
|
|
70
|
+
const _def = {
|
|
71
|
+
_config: config,
|
|
72
|
+
router: true,
|
|
73
|
+
procedures,
|
|
74
|
+
...emptyRouter,
|
|
75
|
+
record
|
|
76
|
+
};
|
|
77
|
+
return {
|
|
78
|
+
...record,
|
|
79
|
+
_def,
|
|
80
|
+
createCaller: createCallerFactory()({
|
|
81
|
+
_def
|
|
82
|
+
})
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
return createRouterInner;
|
|
86
|
+
}
|
|
87
|
+
function isProcedure(procedureOrRouter) {
|
|
88
|
+
return typeof procedureOrRouter === 'function';
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* @internal
|
|
92
|
+
*/ function callProcedure(opts) {
|
|
93
|
+
const { type , path } = opts;
|
|
94
|
+
const proc = opts.procedures[path];
|
|
95
|
+
if (!proc || !isProcedure(proc) || proc._def.type !== type && !opts.allowMethodOverride) {
|
|
96
|
+
throw new TRPCError.TRPCError({
|
|
97
|
+
code: 'NOT_FOUND',
|
|
98
|
+
message: `No "${type}"-procedure on path "${path}"`
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
return proc(opts);
|
|
102
|
+
}
|
|
103
|
+
function createCallerFactory() {
|
|
104
|
+
return function createCallerInner(router) {
|
|
105
|
+
const _def = router._def;
|
|
106
|
+
return function createCaller(ctxOrCallback, options) {
|
|
107
|
+
const proxy = createProxy.createRecursiveProxy(async ({ path , args })=>{
|
|
108
|
+
const fullPath = path.join('.');
|
|
109
|
+
const procedure = _def.procedures[fullPath];
|
|
110
|
+
let ctx = undefined;
|
|
111
|
+
try {
|
|
112
|
+
ctx = utils.isFunction(ctxOrCallback) ? await Promise.resolve(ctxOrCallback()) : ctxOrCallback;
|
|
113
|
+
return await procedure({
|
|
114
|
+
path: fullPath,
|
|
115
|
+
getRawInput: async ()=>args[0],
|
|
116
|
+
ctx,
|
|
117
|
+
type: procedure._def.type
|
|
118
|
+
});
|
|
119
|
+
} catch (cause) {
|
|
120
|
+
options?.onError?.({
|
|
121
|
+
ctx,
|
|
122
|
+
error: TRPCError.getTRPCErrorFromUnknown(cause),
|
|
123
|
+
input: args[0],
|
|
124
|
+
path: fullPath,
|
|
125
|
+
type: procedure._def.type
|
|
126
|
+
});
|
|
127
|
+
throw cause;
|
|
128
|
+
}
|
|
129
|
+
});
|
|
130
|
+
return proxy;
|
|
131
|
+
};
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
function mergeRouters(...routerList) {
|
|
135
|
+
const record = utils.mergeWithoutOverrides({}, ...routerList.map((r)=>r._def.record));
|
|
136
|
+
const errorFormatter = routerList.reduce((currentErrorFormatter, nextRouter)=>{
|
|
137
|
+
if (nextRouter._def._config.errorFormatter && nextRouter._def._config.errorFormatter !== formatter.defaultFormatter) {
|
|
138
|
+
if (currentErrorFormatter !== formatter.defaultFormatter && currentErrorFormatter !== nextRouter._def._config.errorFormatter) {
|
|
139
|
+
throw new Error('You seem to have several error formatters');
|
|
140
|
+
}
|
|
141
|
+
return nextRouter._def._config.errorFormatter;
|
|
142
|
+
}
|
|
143
|
+
return currentErrorFormatter;
|
|
144
|
+
}, formatter.defaultFormatter);
|
|
145
|
+
const transformer$1 = routerList.reduce((prev, current)=>{
|
|
146
|
+
if (current._def._config.transformer && current._def._config.transformer !== transformer.defaultTransformer) {
|
|
147
|
+
if (prev !== transformer.defaultTransformer && prev !== current._def._config.transformer) {
|
|
148
|
+
throw new Error('You seem to have several transformers');
|
|
149
|
+
}
|
|
150
|
+
return current._def._config.transformer;
|
|
151
|
+
}
|
|
152
|
+
return prev;
|
|
153
|
+
}, transformer.defaultTransformer);
|
|
154
|
+
const router = createRouterFactory({
|
|
155
|
+
errorFormatter,
|
|
156
|
+
transformer: transformer$1,
|
|
157
|
+
isDev: routerList.every((r)=>r._def._config.isDev),
|
|
158
|
+
allowOutsideOfServer: routerList.every((r)=>r._def._config.allowOutsideOfServer),
|
|
159
|
+
isServer: routerList.every((r)=>r._def._config.isServer),
|
|
160
|
+
$types: routerList[0]?._def._config.$types
|
|
161
|
+
})(record);
|
|
162
|
+
return router;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
exports.callProcedure = callProcedure;
|
|
166
|
+
exports.createCallerFactory = createCallerFactory;
|
|
167
|
+
exports.createRouterFactory = createRouterFactory;
|
|
168
|
+
exports.mergeRouters = mergeRouters;
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { createRecursiveProxy } from './createProxy.mjs';
|
|
2
|
+
import { defaultFormatter } from './error/formatter.mjs';
|
|
3
|
+
import { TRPCError, getTRPCErrorFromUnknown } from './error/TRPCError.mjs';
|
|
4
|
+
import { defaultTransformer } from './transformer.mjs';
|
|
5
|
+
import { mergeWithoutOverrides, omitPrototype, isFunction } from './utils.mjs';
|
|
6
|
+
|
|
7
|
+
function isRouter(procedureOrRouter) {
|
|
8
|
+
return procedureOrRouter._def && 'router' in procedureOrRouter._def;
|
|
9
|
+
}
|
|
10
|
+
const emptyRouter = {
|
|
11
|
+
_ctx: null,
|
|
12
|
+
_errorShape: null,
|
|
13
|
+
_meta: null,
|
|
14
|
+
queries: {},
|
|
15
|
+
mutations: {},
|
|
16
|
+
subscriptions: {},
|
|
17
|
+
errorFormatter: defaultFormatter,
|
|
18
|
+
transformer: defaultTransformer
|
|
19
|
+
};
|
|
20
|
+
/**
|
|
21
|
+
* Reserved words that can't be used as router or procedure names
|
|
22
|
+
*/ const reservedWords = [
|
|
23
|
+
/**
|
|
24
|
+
* Then is a reserved word because otherwise we can't return a promise that returns a Proxy
|
|
25
|
+
* since JS will think that `.then` is something that exists
|
|
26
|
+
*/ 'then'
|
|
27
|
+
];
|
|
28
|
+
/**
|
|
29
|
+
* @internal
|
|
30
|
+
*/ function createRouterFactory(config) {
|
|
31
|
+
function createRouterInner(input) {
|
|
32
|
+
const reservedWordsUsed = new Set(Object.keys(input).filter((v)=>reservedWords.includes(v)));
|
|
33
|
+
if (reservedWordsUsed.size > 0) {
|
|
34
|
+
throw new Error('Reserved words used in `router({})` call: ' + Array.from(reservedWordsUsed).join(', '));
|
|
35
|
+
}
|
|
36
|
+
const procedures = omitPrototype({});
|
|
37
|
+
function step(from, path = []) {
|
|
38
|
+
const aggregate = omitPrototype({});
|
|
39
|
+
for (const [key, item] of Object.entries(from ?? {})){
|
|
40
|
+
if (isRouter(item)) {
|
|
41
|
+
aggregate[key] = step(item._def.record, [
|
|
42
|
+
...path,
|
|
43
|
+
key
|
|
44
|
+
]);
|
|
45
|
+
continue;
|
|
46
|
+
}
|
|
47
|
+
if (!isProcedure(item)) {
|
|
48
|
+
// RouterRecord
|
|
49
|
+
aggregate[key] = step(item, [
|
|
50
|
+
...path,
|
|
51
|
+
key
|
|
52
|
+
]);
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
const newPath = [
|
|
56
|
+
...path,
|
|
57
|
+
key
|
|
58
|
+
].join('.');
|
|
59
|
+
if (procedures[newPath]) {
|
|
60
|
+
throw new Error(`Duplicate key: ${newPath}`);
|
|
61
|
+
}
|
|
62
|
+
procedures[newPath] = item;
|
|
63
|
+
aggregate[key] = item;
|
|
64
|
+
}
|
|
65
|
+
return aggregate;
|
|
66
|
+
}
|
|
67
|
+
const record = step(input);
|
|
68
|
+
const _def = {
|
|
69
|
+
_config: config,
|
|
70
|
+
router: true,
|
|
71
|
+
procedures,
|
|
72
|
+
...emptyRouter,
|
|
73
|
+
record
|
|
74
|
+
};
|
|
75
|
+
return {
|
|
76
|
+
...record,
|
|
77
|
+
_def,
|
|
78
|
+
createCaller: createCallerFactory()({
|
|
79
|
+
_def
|
|
80
|
+
})
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
return createRouterInner;
|
|
84
|
+
}
|
|
85
|
+
function isProcedure(procedureOrRouter) {
|
|
86
|
+
return typeof procedureOrRouter === 'function';
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* @internal
|
|
90
|
+
*/ function callProcedure(opts) {
|
|
91
|
+
const { type , path } = opts;
|
|
92
|
+
const proc = opts.procedures[path];
|
|
93
|
+
if (!proc || !isProcedure(proc) || proc._def.type !== type && !opts.allowMethodOverride) {
|
|
94
|
+
throw new TRPCError({
|
|
95
|
+
code: 'NOT_FOUND',
|
|
96
|
+
message: `No "${type}"-procedure on path "${path}"`
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
return proc(opts);
|
|
100
|
+
}
|
|
101
|
+
function createCallerFactory() {
|
|
102
|
+
return function createCallerInner(router) {
|
|
103
|
+
const _def = router._def;
|
|
104
|
+
return function createCaller(ctxOrCallback, options) {
|
|
105
|
+
const proxy = createRecursiveProxy(async ({ path , args })=>{
|
|
106
|
+
const fullPath = path.join('.');
|
|
107
|
+
const procedure = _def.procedures[fullPath];
|
|
108
|
+
let ctx = undefined;
|
|
109
|
+
try {
|
|
110
|
+
ctx = isFunction(ctxOrCallback) ? await Promise.resolve(ctxOrCallback()) : ctxOrCallback;
|
|
111
|
+
return await procedure({
|
|
112
|
+
path: fullPath,
|
|
113
|
+
getRawInput: async ()=>args[0],
|
|
114
|
+
ctx,
|
|
115
|
+
type: procedure._def.type
|
|
116
|
+
});
|
|
117
|
+
} catch (cause) {
|
|
118
|
+
options?.onError?.({
|
|
119
|
+
ctx,
|
|
120
|
+
error: getTRPCErrorFromUnknown(cause),
|
|
121
|
+
input: args[0],
|
|
122
|
+
path: fullPath,
|
|
123
|
+
type: procedure._def.type
|
|
124
|
+
});
|
|
125
|
+
throw cause;
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
return proxy;
|
|
129
|
+
};
|
|
130
|
+
};
|
|
131
|
+
}
|
|
132
|
+
function mergeRouters(...routerList) {
|
|
133
|
+
const record = mergeWithoutOverrides({}, ...routerList.map((r)=>r._def.record));
|
|
134
|
+
const errorFormatter = routerList.reduce((currentErrorFormatter, nextRouter)=>{
|
|
135
|
+
if (nextRouter._def._config.errorFormatter && nextRouter._def._config.errorFormatter !== defaultFormatter) {
|
|
136
|
+
if (currentErrorFormatter !== defaultFormatter && currentErrorFormatter !== nextRouter._def._config.errorFormatter) {
|
|
137
|
+
throw new Error('You seem to have several error formatters');
|
|
138
|
+
}
|
|
139
|
+
return nextRouter._def._config.errorFormatter;
|
|
140
|
+
}
|
|
141
|
+
return currentErrorFormatter;
|
|
142
|
+
}, defaultFormatter);
|
|
143
|
+
const transformer = routerList.reduce((prev, current)=>{
|
|
144
|
+
if (current._def._config.transformer && current._def._config.transformer !== defaultTransformer) {
|
|
145
|
+
if (prev !== defaultTransformer && prev !== current._def._config.transformer) {
|
|
146
|
+
throw new Error('You seem to have several transformers');
|
|
147
|
+
}
|
|
148
|
+
return current._def._config.transformer;
|
|
149
|
+
}
|
|
150
|
+
return prev;
|
|
151
|
+
}, defaultTransformer);
|
|
152
|
+
const router = createRouterFactory({
|
|
153
|
+
errorFormatter,
|
|
154
|
+
transformer,
|
|
155
|
+
isDev: routerList.every((r)=>r._def._config.isDev),
|
|
156
|
+
allowOutsideOfServer: routerList.every((r)=>r._def._config.allowOutsideOfServer),
|
|
157
|
+
isServer: routerList.every((r)=>r._def._config.isServer),
|
|
158
|
+
$types: routerList[0]?._def._config.$types
|
|
159
|
+
})(record);
|
|
160
|
+
return router;
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
export { callProcedure, createCallerFactory, createRouterFactory, mergeRouters };
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { ValueOf } from '../types';
|
|
1
2
|
/**
|
|
2
3
|
* JSON-RPC 2.0 Error codes
|
|
3
4
|
*
|
|
@@ -23,28 +24,19 @@ export declare const TRPC_ERROR_CODES_BY_KEY: {
|
|
|
23
24
|
readonly TIMEOUT: -32008;
|
|
24
25
|
readonly CONFLICT: -32009;
|
|
25
26
|
readonly PRECONDITION_FAILED: -32012;
|
|
27
|
+
readonly UNSUPPORTED_MEDIA_TYPE: -32015;
|
|
26
28
|
readonly PAYLOAD_TOO_LARGE: -32013;
|
|
27
29
|
readonly UNPROCESSABLE_CONTENT: -32022;
|
|
28
30
|
readonly TOO_MANY_REQUESTS: -32029;
|
|
29
31
|
readonly CLIENT_CLOSED_REQUEST: -32099;
|
|
30
32
|
};
|
|
31
|
-
|
|
32
|
-
[
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
[
|
|
36
|
-
[-32003]: "FORBIDDEN";
|
|
37
|
-
[-32004]: "NOT_FOUND";
|
|
38
|
-
[-32005]: "METHOD_NOT_SUPPORTED";
|
|
39
|
-
[-32008]: "TIMEOUT";
|
|
40
|
-
[-32009]: "CONFLICT";
|
|
41
|
-
[-32012]: "PRECONDITION_FAILED";
|
|
42
|
-
[-32013]: "PAYLOAD_TOO_LARGE";
|
|
43
|
-
[-32022]: "UNPROCESSABLE_CONTENT";
|
|
44
|
-
[-32029]: "TOO_MANY_REQUESTS";
|
|
45
|
-
[-32099]: "CLIENT_CLOSED_REQUEST";
|
|
33
|
+
type KeyFromValue<TValue, TType extends Record<PropertyKey, PropertyKey>> = {
|
|
34
|
+
[K in keyof TType]: TValue extends TType[K] ? K : never;
|
|
35
|
+
}[keyof TType];
|
|
36
|
+
type Invert<TType extends Record<PropertyKey, PropertyKey>> = {
|
|
37
|
+
[TValue in TType[keyof TType]]: KeyFromValue<TValue, TType>;
|
|
46
38
|
};
|
|
47
|
-
|
|
39
|
+
export declare const TRPC_ERROR_CODES_BY_NUMBER: Invert<typeof TRPC_ERROR_CODES_BY_KEY>;
|
|
48
40
|
export type TRPC_ERROR_CODE_NUMBER = ValueOf<typeof TRPC_ERROR_CODES_BY_KEY>;
|
|
49
41
|
export type TRPC_ERROR_CODE_KEY = keyof typeof TRPC_ERROR_CODES_BY_KEY;
|
|
50
42
|
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"codes.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/rpc/codes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AAIxC;;;;;GAKG;AACH,eAAO,MAAM,uBAAuB;IAClC;;;OAGG;;IAEH;;OAEG;;;;;;;;;;;;;;;;CAoBK,CAAC;AAEX,KAAK,YAAY,CAAC,MAAM,EAAE,KAAK,SAAS,MAAM,CAAC,WAAW,EAAE,WAAW,CAAC,IAAI;KACzE,CAAC,IAAI,MAAM,KAAK,GAAG,MAAM,SAAS,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK;CACxD,CAAC,MAAM,KAAK,CAAC,CAAC;AAEf,KAAK,MAAM,CAAC,KAAK,SAAS,MAAM,CAAC,WAAW,EAAE,WAAW,CAAC,IAAI;KAC3D,MAAM,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,GAAG,YAAY,CAAC,MAAM,EAAE,KAAK,CAAC;CAC5D,CAAC;AAGF,eAAO,MAAM,0BAA0B,EAAE,MAAM,CAC7C,OAAO,uBAAuB,CAiB/B,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG,OAAO,CAAC,OAAO,uBAAuB,CAAC,CAAC;AAC7E,MAAM,MAAM,mBAAmB,GAAG,MAAM,OAAO,uBAAuB,CAAC"}
|
|
@@ -1,16 +1,5 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
/**
|
|
4
|
-
* @internal
|
|
5
|
-
*/ function invert(obj) {
|
|
6
|
-
const newObj = Object.create(null);
|
|
7
|
-
for(const key in obj){
|
|
8
|
-
const v = obj[key];
|
|
9
|
-
newObj[v] = key;
|
|
10
|
-
}
|
|
11
|
-
return newObj;
|
|
12
|
-
}
|
|
13
|
-
|
|
14
3
|
// reference: https://www.jsonrpc.org/specification
|
|
15
4
|
/**
|
|
16
5
|
* JSON-RPC 2.0 Error codes
|
|
@@ -36,13 +25,30 @@
|
|
|
36
25
|
TIMEOUT: -32008,
|
|
37
26
|
CONFLICT: -32009,
|
|
38
27
|
PRECONDITION_FAILED: -32012,
|
|
28
|
+
UNSUPPORTED_MEDIA_TYPE: -32015,
|
|
39
29
|
PAYLOAD_TOO_LARGE: -32013,
|
|
40
30
|
UNPROCESSABLE_CONTENT: -32022,
|
|
41
31
|
TOO_MANY_REQUESTS: -32029,
|
|
42
32
|
CLIENT_CLOSED_REQUEST: -32099
|
|
43
33
|
};
|
|
44
|
-
|
|
34
|
+
// pure
|
|
35
|
+
const TRPC_ERROR_CODES_BY_NUMBER = {
|
|
36
|
+
[-32700]: 'PARSE_ERROR',
|
|
37
|
+
[-32600]: 'BAD_REQUEST',
|
|
38
|
+
[-32603]: 'INTERNAL_SERVER_ERROR',
|
|
39
|
+
[-32001]: 'UNAUTHORIZED',
|
|
40
|
+
[-32003]: 'FORBIDDEN',
|
|
41
|
+
[-32004]: 'NOT_FOUND',
|
|
42
|
+
[-32005]: 'METHOD_NOT_SUPPORTED',
|
|
43
|
+
[-32008]: 'TIMEOUT',
|
|
44
|
+
[-32009]: 'CONFLICT',
|
|
45
|
+
[-32012]: 'PRECONDITION_FAILED',
|
|
46
|
+
[-32013]: 'PAYLOAD_TOO_LARGE',
|
|
47
|
+
[-32015]: 'UNSUPPORTED_MEDIA_TYPE',
|
|
48
|
+
[-32022]: 'UNPROCESSABLE_CONTENT',
|
|
49
|
+
[-32029]: 'TOO_MANY_REQUESTS',
|
|
50
|
+
[-32099]: 'CLIENT_CLOSED_REQUEST'
|
|
51
|
+
};
|
|
45
52
|
|
|
46
53
|
exports.TRPC_ERROR_CODES_BY_KEY = TRPC_ERROR_CODES_BY_KEY;
|
|
47
54
|
exports.TRPC_ERROR_CODES_BY_NUMBER = TRPC_ERROR_CODES_BY_NUMBER;
|
|
48
|
-
exports.invert = invert;
|
|
@@ -1,14 +1,3 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @internal
|
|
3
|
-
*/ function invert(obj) {
|
|
4
|
-
const newObj = Object.create(null);
|
|
5
|
-
for(const key in obj){
|
|
6
|
-
const v = obj[key];
|
|
7
|
-
newObj[v] = key;
|
|
8
|
-
}
|
|
9
|
-
return newObj;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
1
|
// reference: https://www.jsonrpc.org/specification
|
|
13
2
|
/**
|
|
14
3
|
* JSON-RPC 2.0 Error codes
|
|
@@ -34,11 +23,29 @@
|
|
|
34
23
|
TIMEOUT: -32008,
|
|
35
24
|
CONFLICT: -32009,
|
|
36
25
|
PRECONDITION_FAILED: -32012,
|
|
26
|
+
UNSUPPORTED_MEDIA_TYPE: -32015,
|
|
37
27
|
PAYLOAD_TOO_LARGE: -32013,
|
|
38
28
|
UNPROCESSABLE_CONTENT: -32022,
|
|
39
29
|
TOO_MANY_REQUESTS: -32029,
|
|
40
30
|
CLIENT_CLOSED_REQUEST: -32099
|
|
41
31
|
};
|
|
42
|
-
|
|
32
|
+
// pure
|
|
33
|
+
const TRPC_ERROR_CODES_BY_NUMBER = {
|
|
34
|
+
[-32700]: 'PARSE_ERROR',
|
|
35
|
+
[-32600]: 'BAD_REQUEST',
|
|
36
|
+
[-32603]: 'INTERNAL_SERVER_ERROR',
|
|
37
|
+
[-32001]: 'UNAUTHORIZED',
|
|
38
|
+
[-32003]: 'FORBIDDEN',
|
|
39
|
+
[-32004]: 'NOT_FOUND',
|
|
40
|
+
[-32005]: 'METHOD_NOT_SUPPORTED',
|
|
41
|
+
[-32008]: 'TIMEOUT',
|
|
42
|
+
[-32009]: 'CONFLICT',
|
|
43
|
+
[-32012]: 'PRECONDITION_FAILED',
|
|
44
|
+
[-32013]: 'PAYLOAD_TOO_LARGE',
|
|
45
|
+
[-32015]: 'UNSUPPORTED_MEDIA_TYPE',
|
|
46
|
+
[-32022]: 'UNPROCESSABLE_CONTENT',
|
|
47
|
+
[-32029]: 'TOO_MANY_REQUESTS',
|
|
48
|
+
[-32099]: 'CLIENT_CLOSED_REQUEST'
|
|
49
|
+
};
|
|
43
50
|
|
|
44
|
-
export { TRPC_ERROR_CODES_BY_KEY
|
|
51
|
+
export { TRPC_ERROR_CODES_BY_KEY, TRPC_ERROR_CODES_BY_NUMBER };
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { ProcedureType } from '../
|
|
2
|
-
import { TRPC_ERROR_CODE_NUMBER } from './codes';
|
|
1
|
+
import type { ProcedureType } from '../procedure';
|
|
2
|
+
import type { TRPC_ERROR_CODE_NUMBER } from './codes';
|
|
3
3
|
/**
|
|
4
4
|
* Error response
|
|
5
5
|
*/
|
|
6
|
-
export interface TRPCErrorShape<
|
|
7
|
-
code:
|
|
6
|
+
export interface TRPCErrorShape<TData extends object = object> {
|
|
7
|
+
code: TRPC_ERROR_CODE_NUMBER;
|
|
8
8
|
message: string;
|
|
9
9
|
data: TData;
|
|
10
10
|
}
|
|
@@ -69,8 +69,10 @@ export type TRPCClientOutgoingMessage = TRPCRequestMessage | (JSONRPC2.BaseReque
|
|
|
69
69
|
});
|
|
70
70
|
export interface TRPCResultMessage<TData> extends JSONRPC2.ResultResponse<{
|
|
71
71
|
type: 'started';
|
|
72
|
+
data?: never;
|
|
72
73
|
} | {
|
|
73
74
|
type: 'stopped';
|
|
75
|
+
data?: never;
|
|
74
76
|
} | (TRPCResult<TData> & {
|
|
75
77
|
type: 'data';
|
|
76
78
|
})> {
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"envelopes.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/rpc/envelopes.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export { TRPC_ERROR_CODES_BY_KEY, TRPC_ERROR_CODES_BY_NUMBER } from './codes';
|
|
2
|
+
export type { TRPC_ERROR_CODE_KEY, TRPC_ERROR_CODE_NUMBER } from './codes';
|
|
3
|
+
export type { JSONRPC2, TRPCClientIncomingMessage, TRPCClientIncomingRequest, TRPCClientOutgoingMessage, TRPCClientOutgoingRequest, TRPCErrorResponse, TRPCErrorShape, TRPCReconnectNotification, TRPCRequest, TRPCRequestMessage, TRPCResponse, TRPCResponseMessage, TRPCResult, TRPCResultMessage, TRPCSubscriptionStopNotification, TRPCSuccessResponse, } from './envelopes';
|
|
4
|
+
export { parseTRPCMessage } from './parseTRPCMessage';
|
|
5
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/rpc/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,SAAS,CAAC;AAC9E,YAAY,EAAE,mBAAmB,EAAE,sBAAsB,EAAE,MAAM,SAAS,CAAC;AAC3E,YAAY,EACV,QAAQ,EACR,yBAAyB,EACzB,yBAAyB,EACzB,yBAAyB,EACzB,yBAAyB,EACzB,iBAAiB,EACjB,cAAc,EACd,yBAAyB,EACzB,WAAW,EACX,kBAAkB,EAClB,YAAY,EACZ,mBAAmB,EACnB,UAAU,EACV,iBAAiB,EACjB,gCAAgC,EAChC,mBAAmB,GACpB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parseTRPCMessage.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/rpc/parseTRPCMessage.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AAE9D,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AA8C7D,cAAc;AACd,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,OAAO,EACZ,WAAW,EAAE,uBAAuB,GACnC,yBAAyB,CA+B3B"}
|
package/dist/{parseTRPCMessage-1377f305.js → unstable-core-do-not-import/rpc/parseTRPCMessage.js}
RENAMED
|
@@ -1,12 +1,15 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var procedure = require('../procedure.js');
|
|
4
|
+
var utils = require('../utils.js');
|
|
5
|
+
|
|
3
6
|
/* istanbul ignore next -- @preserve */ function assertIsObject(obj) {
|
|
4
|
-
if (
|
|
7
|
+
if (!utils.isObject(obj)) {
|
|
5
8
|
throw new Error('Not an object');
|
|
6
9
|
}
|
|
7
10
|
}
|
|
8
11
|
/* istanbul ignore next -- @preserve */ function assertIsProcedureType(obj) {
|
|
9
|
-
if (obj
|
|
12
|
+
if (!procedure.procedureTypes.includes(obj)) {
|
|
10
13
|
throw new Error('Invalid procedure type');
|
|
11
14
|
}
|
|
12
15
|
}
|
package/dist/{parseTRPCMessage-a0f17853.mjs → unstable-core-do-not-import/rpc/parseTRPCMessage.mjs}
RENAMED
|
@@ -1,10 +1,13 @@
|
|
|
1
|
+
import { procedureTypes } from '../procedure.mjs';
|
|
2
|
+
import { isObject } from '../utils.mjs';
|
|
3
|
+
|
|
1
4
|
/* istanbul ignore next -- @preserve */ function assertIsObject(obj) {
|
|
2
|
-
if (
|
|
5
|
+
if (!isObject(obj)) {
|
|
3
6
|
throw new Error('Not an object');
|
|
4
7
|
}
|
|
5
8
|
}
|
|
6
9
|
/* istanbul ignore next -- @preserve */ function assertIsProcedureType(obj) {
|
|
7
|
-
if (obj
|
|
10
|
+
if (!procedureTypes.includes(obj)) {
|
|
8
11
|
throw new Error('Invalid procedure type');
|
|
9
12
|
}
|
|
10
13
|
}
|
|
@@ -51,4 +54,4 @@
|
|
|
51
54
|
};
|
|
52
55
|
}
|
|
53
56
|
|
|
54
|
-
export { parseTRPCMessage
|
|
57
|
+
export { parseTRPCMessage };
|