@trpc/server 11.0.0-rc.643 → 11.0.0-rc.648
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/dist/adapters/aws-lambda/index.js +1 -1
- package/dist/adapters/aws-lambda/index.mjs +1 -1
- package/dist/adapters/express.js +1 -1
- package/dist/adapters/express.mjs +1 -1
- package/dist/adapters/fastify/fastifyRequestHandler.js +1 -1
- package/dist/adapters/fastify/fastifyRequestHandler.mjs +1 -1
- package/dist/adapters/fetch/fetchRequestHandler.js +1 -1
- package/dist/adapters/fetch/fetchRequestHandler.mjs +1 -1
- package/dist/adapters/next-app-dir/nextAppDirCaller.js +1 -1
- package/dist/adapters/next-app-dir/nextAppDirCaller.mjs +1 -1
- package/dist/adapters/next-app-dir/notFound.js +1 -1
- package/dist/adapters/next-app-dir/notFound.mjs +1 -1
- package/dist/adapters/next-app-dir/redirect.js +15 -3
- package/dist/adapters/next-app-dir/redirect.mjs +14 -2
- package/dist/adapters/next.js +1 -1
- package/dist/adapters/next.mjs +1 -1
- package/dist/adapters/node-http/incomingMessageToRequest.js +1 -1
- package/dist/adapters/node-http/incomingMessageToRequest.mjs +1 -1
- package/dist/adapters/node-http/nodeHTTPRequestHandler.js +1 -1
- package/dist/adapters/node-http/nodeHTTPRequestHandler.mjs +1 -1
- package/dist/adapters/node-http/writeResponse.d.ts.map +1 -1
- package/dist/adapters/node-http/writeResponse.js +3 -1
- package/dist/adapters/node-http/writeResponse.mjs +3 -1
- package/dist/adapters/standalone.js +1 -1
- package/dist/adapters/standalone.mjs +1 -1
- package/dist/adapters/ws.d.ts.map +1 -1
- package/dist/adapters/ws.js +145 -66
- package/dist/adapters/ws.mjs +145 -66
- package/dist/bundle-analysis.json +194 -201
- package/dist/http.js +1 -1
- package/dist/http.mjs +1 -1
- package/dist/index.js +1 -1
- package/dist/index.mjs +1 -1
- package/dist/node_modules/.pnpm/@rollup_plugin-typescript@12.1.1_rollup@4.27.4_tslib@2.8.1_typescript@5.6.2/node_modules/tslib/tslib.es6.js +73 -0
- package/dist/observable/observable.d.ts +1 -1
- package/dist/observable/observable.d.ts.map +1 -1
- package/dist/observable/observable.js +16 -4
- package/dist/observable/observable.mjs +16 -4
- package/dist/rpc.js +1 -1
- package/dist/rpc.mjs +1 -1
- package/dist/shared.js +1 -1
- package/dist/shared.mjs +1 -1
- package/dist/unstable-core-do-not-import/error/TRPCError.d.ts +1 -1
- package/dist/unstable-core-do-not-import/error/TRPCError.js +14 -2
- package/dist/unstable-core-do-not-import/error/TRPCError.mjs +13 -1
- package/dist/unstable-core-do-not-import/http/resolveResponse.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/http/resolveResponse.js +7 -18
- package/dist/unstable-core-do-not-import/http/resolveResponse.mjs +8 -19
- package/dist/unstable-core-do-not-import/stream/jsonl.d.ts +15 -4
- package/dist/unstable-core-do-not-import/stream/jsonl.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/stream/jsonl.js +430 -291
- package/dist/unstable-core-do-not-import/stream/jsonl.mjs +428 -289
- package/dist/unstable-core-do-not-import/stream/sse.d.ts +1 -1
- package/dist/unstable-core-do-not-import/stream/sse.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/stream/sse.js +183 -122
- package/dist/unstable-core-do-not-import/stream/sse.mjs +183 -122
- package/dist/unstable-core-do-not-import/stream/utils/asyncIterable.d.ts +1 -0
- package/dist/unstable-core-do-not-import/stream/utils/asyncIterable.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/stream/utils/asyncIterable.js +103 -10
- package/dist/unstable-core-do-not-import/stream/utils/asyncIterable.mjs +104 -12
- package/dist/unstable-core-do-not-import/stream/utils/disposable.d.ts +17 -0
- package/dist/unstable-core-do-not-import/stream/utils/disposable.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/stream/utils/disposable.js +44 -0
- package/dist/unstable-core-do-not-import/stream/utils/disposable.mjs +41 -0
- package/dist/unstable-core-do-not-import/stream/utils/readableStreamFrom.d.ts +8 -0
- package/dist/unstable-core-do-not-import/stream/utils/readableStreamFrom.d.ts.map +1 -0
- package/dist/unstable-core-do-not-import/stream/utils/readableStreamFrom.js +25 -0
- package/dist/unstable-core-do-not-import/stream/utils/readableStreamFrom.mjs +23 -0
- package/dist/unstable-core-do-not-import/stream/utils/timerResource.d.ts +1 -2
- package/dist/unstable-core-do-not-import/stream/utils/timerResource.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/stream/utils/timerResource.js +8 -10
- package/dist/unstable-core-do-not-import/stream/utils/timerResource.mjs +8 -10
- package/dist/unstable-core-do-not-import/stream/utils/withPing.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import/stream/utils/withPing.js +113 -24
- package/dist/unstable-core-do-not-import/stream/utils/withPing.mjs +114 -25
- package/dist/unstable-core-do-not-import/transformer.d.ts +1 -1
- package/dist/unstable-core-do-not-import.d.ts +1 -0
- package/dist/unstable-core-do-not-import.d.ts.map +1 -1
- package/dist/unstable-core-do-not-import.js +3 -0
- package/dist/unstable-core-do-not-import.mjs +1 -0
- package/dist/vendor/unpromise/unpromise.js +17 -6
- package/dist/vendor/unpromise/unpromise.mjs +13 -2
- package/package.json +2 -3
- package/src/adapters/node-http/writeResponse.ts +3 -0
- package/src/adapters/ws.ts +8 -9
- package/src/observable/observable.ts +17 -2
- package/src/unstable-core-do-not-import/http/resolveResponse.ts +8 -21
- package/src/unstable-core-do-not-import/stream/jsonl.ts +236 -216
- package/src/unstable-core-do-not-import/stream/sse.ts +112 -132
- package/src/unstable-core-do-not-import/stream/utils/asyncIterable.ts +50 -48
- package/src/unstable-core-do-not-import/stream/utils/disposable.ts +52 -0
- package/src/unstable-core-do-not-import/stream/utils/readableStreamFrom.ts +28 -0
- package/src/unstable-core-do-not-import/stream/utils/timerResource.ts +17 -15
- package/src/unstable-core-do-not-import/stream/utils/withPing.ts +18 -19
- package/src/unstable-core-do-not-import.ts +1 -0
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.13/node_modules/@swc/helpers/esm/_define_property.js +0 -11
- package/dist/node_modules/.pnpm/@swc_helpers@0.5.13/node_modules/@swc/helpers/esm/_define_property.mjs +0 -9
- package/dist/unstable-core-do-not-import/stream/utils/createReadableStream.d.ts +0 -9
- package/dist/unstable-core-do-not-import/stream/utils/createReadableStream.d.ts.map +0 -1
- package/dist/unstable-core-do-not-import/stream/utils/createReadableStream.js +0 -25
- package/dist/unstable-core-do-not-import/stream/utils/createReadableStream.mjs +0 -23
- package/dist/unstable-core-do-not-import/stream/utils/withRefCount.d.ts +0 -17
- package/dist/unstable-core-do-not-import/stream/utils/withRefCount.d.ts.map +0 -1
- package/dist/unstable-core-do-not-import/stream/utils/withRefCount.js +0 -59
- package/dist/unstable-core-do-not-import/stream/utils/withRefCount.mjs +0 -57
- package/src/unstable-core-do-not-import/stream/utils/createReadableStream.ts +0 -25
- package/src/unstable-core-do-not-import/stream/utils/withRefCount.ts +0 -93
package/dist/http.js
CHANGED
|
@@ -6,7 +6,7 @@ var contentTypeParsers = require('./unstable-core-do-not-import/http/contentType
|
|
|
6
6
|
var resolveResponse = require('./unstable-core-do-not-import/http/resolveResponse.js');
|
|
7
7
|
require('./unstable-core-do-not-import/rootConfig.js');
|
|
8
8
|
require('./vendor/unpromise/unpromise.js');
|
|
9
|
-
require('./unstable-core-do-not-import/stream/utils/
|
|
9
|
+
require('./unstable-core-do-not-import/stream/utils/disposable.js');
|
|
10
10
|
|
|
11
11
|
|
|
12
12
|
|
package/dist/http.mjs
CHANGED
|
@@ -4,4 +4,4 @@ export { octetInputParser } from './unstable-core-do-not-import/http/contentType
|
|
|
4
4
|
export { resolveResponse } from './unstable-core-do-not-import/http/resolveResponse.mjs';
|
|
5
5
|
import './unstable-core-do-not-import/rootConfig.mjs';
|
|
6
6
|
import './vendor/unpromise/unpromise.mjs';
|
|
7
|
-
import './unstable-core-do-not-import/stream/utils/
|
|
7
|
+
import './unstable-core-do-not-import/stream/utils/disposable.mjs';
|
package/dist/index.js
CHANGED
|
@@ -4,8 +4,8 @@ var createProxy = require('./unstable-core-do-not-import/createProxy.js');
|
|
|
4
4
|
var getErrorShape = require('./unstable-core-do-not-import/error/getErrorShape.js');
|
|
5
5
|
var TRPCError = require('./unstable-core-do-not-import/error/TRPCError.js');
|
|
6
6
|
require('./vendor/unpromise/unpromise.js');
|
|
7
|
+
require('./unstable-core-do-not-import/stream/utils/disposable.js');
|
|
7
8
|
var tracked = require('./unstable-core-do-not-import/stream/tracked.js');
|
|
8
|
-
require('./unstable-core-do-not-import/stream/utils/timerResource.js');
|
|
9
9
|
var transformer = require('./unstable-core-do-not-import/transformer.js');
|
|
10
10
|
var initTRPC = require('./unstable-core-do-not-import/initTRPC.js');
|
|
11
11
|
var middleware = require('./unstable-core-do-not-import/middleware.js');
|
package/dist/index.mjs
CHANGED
|
@@ -2,8 +2,8 @@ export { createFlatProxy as createTRPCFlatProxy } from './unstable-core-do-not-i
|
|
|
2
2
|
export { getErrorShape } from './unstable-core-do-not-import/error/getErrorShape.mjs';
|
|
3
3
|
export { TRPCError, getTRPCErrorFromUnknown } from './unstable-core-do-not-import/error/TRPCError.mjs';
|
|
4
4
|
import './vendor/unpromise/unpromise.mjs';
|
|
5
|
+
import './unstable-core-do-not-import/stream/utils/disposable.mjs';
|
|
5
6
|
export { isTrackedEnvelope, sse, tracked } from './unstable-core-do-not-import/stream/tracked.mjs';
|
|
6
|
-
import './unstable-core-do-not-import/stream/utils/timerResource.mjs';
|
|
7
7
|
export { transformTRPCResponse } from './unstable-core-do-not-import/transformer.mjs';
|
|
8
8
|
export { initTRPC } from './unstable-core-do-not-import/initTRPC.mjs';
|
|
9
9
|
export { experimental_standaloneMiddleware, experimental_standaloneMiddleware as experimental_trpcMiddleware } from './unstable-core-do-not-import/middleware.mjs';
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
/******************************************************************************
|
|
2
|
+
Copyright (c) Microsoft Corporation.
|
|
3
|
+
|
|
4
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
5
|
+
purpose with or without fee is hereby granted.
|
|
6
|
+
|
|
7
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
8
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
9
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
10
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
11
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
12
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
13
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
14
|
+
***************************************************************************** */
|
|
15
|
+
/* global Reflect, Promise, SuppressedError, Symbol, Iterator */
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
function __addDisposableResource(env, value, async) {
|
|
19
|
+
if (value !== null && value !== void 0) {
|
|
20
|
+
if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
|
|
21
|
+
var dispose, inner;
|
|
22
|
+
if (async) {
|
|
23
|
+
if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
|
|
24
|
+
dispose = value[Symbol.asyncDispose];
|
|
25
|
+
}
|
|
26
|
+
if (dispose === void 0) {
|
|
27
|
+
if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
|
|
28
|
+
dispose = value[Symbol.dispose];
|
|
29
|
+
if (async) inner = dispose;
|
|
30
|
+
}
|
|
31
|
+
if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
|
|
32
|
+
if (inner) dispose = function() { try { inner.call(this); } catch (e) { return Promise.reject(e); } };
|
|
33
|
+
env.stack.push({ value: value, dispose: dispose, async: async });
|
|
34
|
+
}
|
|
35
|
+
else if (async) {
|
|
36
|
+
env.stack.push({ async: true });
|
|
37
|
+
}
|
|
38
|
+
return value;
|
|
39
|
+
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
var _SuppressedError = typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
|
|
43
|
+
var e = new Error(message);
|
|
44
|
+
return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
function __disposeResources(env) {
|
|
48
|
+
function fail(e) {
|
|
49
|
+
env.error = env.hasError ? new _SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
|
|
50
|
+
env.hasError = true;
|
|
51
|
+
}
|
|
52
|
+
var r, s = 0;
|
|
53
|
+
function next() {
|
|
54
|
+
while (r = env.stack.pop()) {
|
|
55
|
+
try {
|
|
56
|
+
if (!r.async && s === 1) return s = 0, env.stack.push(r), Promise.resolve().then(next);
|
|
57
|
+
if (r.dispose) {
|
|
58
|
+
var result = r.dispose.call(r.value);
|
|
59
|
+
if (r.async) return s |= 2, Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
|
|
60
|
+
}
|
|
61
|
+
else s |= 1;
|
|
62
|
+
}
|
|
63
|
+
catch (e) {
|
|
64
|
+
fail(e);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
if (s === 1) return env.hasError ? Promise.reject(env.error) : Promise.resolve();
|
|
68
|
+
if (env.hasError) throw env.error;
|
|
69
|
+
}
|
|
70
|
+
return next();
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
export { __addDisposableResource, __disposeResources };
|
|
@@ -8,5 +8,5 @@ export declare function observable<TValue, TError = unknown>(subscribe: (observe
|
|
|
8
8
|
/** @internal */
|
|
9
9
|
export declare function observableToPromise<TValue>(observable: Observable<TValue, unknown>): Promise<TValue>;
|
|
10
10
|
/** @internal */
|
|
11
|
-
export declare function observableToAsyncIterable<TValue>(observable: Observable<TValue, unknown
|
|
11
|
+
export declare function observableToAsyncIterable<TValue>(observable: Observable<TValue, unknown>, signal: AbortSignal): AsyncIterable<TValue>;
|
|
12
12
|
//# sourceMappingURL=observable.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"observable.d.ts","sourceRoot":"","sources":["../../src/observable/observable.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,UAAU,EACV,QAAQ,EAER,aAAa,EAGd,MAAM,SAAS,CAAC;AAEjB,cAAc;AACd,MAAM,MAAM,oBAAoB,CAAC,WAAW,IAC1C,WAAW,SAAS,UAAU,CAAC,MAAM,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,GAAG,KAAK,CAAC;AAEzE,cAAc;AACd,wBAAgB,YAAY,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,IAAI,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAE1E;AAED,cAAc;AACd,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,EACjD,SAAS,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,aAAa,GAC/D,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CA6D5B;AAMD,gBAAgB;AAChB,wBAAgB,mBAAmB,CAAC,MAAM,EACxC,UAAU,EAAE,UAAU,CAAC,MAAM,EAAE,OAAO,CAAC,mBA+BxC;
|
|
1
|
+
{"version":3,"file":"observable.d.ts","sourceRoot":"","sources":["../../src/observable/observable.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,UAAU,EACV,QAAQ,EAER,aAAa,EAGd,MAAM,SAAS,CAAC;AAEjB,cAAc;AACd,MAAM,MAAM,oBAAoB,CAAC,WAAW,IAC1C,WAAW,SAAS,UAAU,CAAC,MAAM,MAAM,EAAE,OAAO,CAAC,GAAG,MAAM,GAAG,KAAK,CAAC;AAEzE,cAAc;AACd,wBAAgB,YAAY,CAAC,CAAC,EAAE,OAAO,GAAG,CAAC,IAAI,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,CAE1E;AAED,cAAc;AACd,wBAAgB,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,EACjD,SAAS,EAAE,CAAC,QAAQ,EAAE,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,aAAa,GAC/D,UAAU,CAAC,MAAM,EAAE,MAAM,CAAC,CA6D5B;AAMD,gBAAgB;AAChB,wBAAgB,mBAAmB,CAAC,MAAM,EACxC,UAAU,EAAE,UAAU,CAAC,MAAM,EAAE,OAAO,CAAC,mBA+BxC;AA4CD,gBAAgB;AAChB,wBAAgB,yBAAyB,CAAC,MAAM,EAC9C,UAAU,EAAE,UAAU,CAAC,MAAM,EAAE,OAAO,CAAC,EACvC,MAAM,EAAE,WAAW,GAClB,aAAa,CAAC,MAAM,CAAC,CAmCvB"}
|
|
@@ -98,8 +98,13 @@ function pipeReducer(prev, fn) {
|
|
|
98
98
|
}
|
|
99
99
|
/**
|
|
100
100
|
* @internal
|
|
101
|
-
*/ function observableToReadableStream(observable) {
|
|
101
|
+
*/ function observableToReadableStream(observable, signal) {
|
|
102
102
|
let unsub = null;
|
|
103
|
+
const onAbort = ()=>{
|
|
104
|
+
unsub?.unsubscribe();
|
|
105
|
+
unsub = null;
|
|
106
|
+
signal.removeEventListener('abort', onAbort);
|
|
107
|
+
};
|
|
103
108
|
return new ReadableStream({
|
|
104
109
|
start (controller) {
|
|
105
110
|
unsub = observable.subscribe({
|
|
@@ -120,14 +125,21 @@ function pipeReducer(prev, fn) {
|
|
|
120
125
|
controller.close();
|
|
121
126
|
}
|
|
122
127
|
});
|
|
128
|
+
if (signal.aborted) {
|
|
129
|
+
onAbort();
|
|
130
|
+
} else {
|
|
131
|
+
signal.addEventListener('abort', onAbort, {
|
|
132
|
+
once: true
|
|
133
|
+
});
|
|
134
|
+
}
|
|
123
135
|
},
|
|
124
136
|
cancel () {
|
|
125
|
-
|
|
137
|
+
onAbort();
|
|
126
138
|
}
|
|
127
139
|
});
|
|
128
140
|
}
|
|
129
|
-
/** @internal */ function observableToAsyncIterable(observable) {
|
|
130
|
-
const stream = observableToReadableStream(observable);
|
|
141
|
+
/** @internal */ function observableToAsyncIterable(observable, signal) {
|
|
142
|
+
const stream = observableToReadableStream(observable, signal);
|
|
131
143
|
const reader = stream.getReader();
|
|
132
144
|
const iterator = {
|
|
133
145
|
async next () {
|
|
@@ -96,8 +96,13 @@ function pipeReducer(prev, fn) {
|
|
|
96
96
|
}
|
|
97
97
|
/**
|
|
98
98
|
* @internal
|
|
99
|
-
*/ function observableToReadableStream(observable) {
|
|
99
|
+
*/ function observableToReadableStream(observable, signal) {
|
|
100
100
|
let unsub = null;
|
|
101
|
+
const onAbort = ()=>{
|
|
102
|
+
unsub?.unsubscribe();
|
|
103
|
+
unsub = null;
|
|
104
|
+
signal.removeEventListener('abort', onAbort);
|
|
105
|
+
};
|
|
101
106
|
return new ReadableStream({
|
|
102
107
|
start (controller) {
|
|
103
108
|
unsub = observable.subscribe({
|
|
@@ -118,14 +123,21 @@ function pipeReducer(prev, fn) {
|
|
|
118
123
|
controller.close();
|
|
119
124
|
}
|
|
120
125
|
});
|
|
126
|
+
if (signal.aborted) {
|
|
127
|
+
onAbort();
|
|
128
|
+
} else {
|
|
129
|
+
signal.addEventListener('abort', onAbort, {
|
|
130
|
+
once: true
|
|
131
|
+
});
|
|
132
|
+
}
|
|
121
133
|
},
|
|
122
134
|
cancel () {
|
|
123
|
-
|
|
135
|
+
onAbort();
|
|
124
136
|
}
|
|
125
137
|
});
|
|
126
138
|
}
|
|
127
|
-
/** @internal */ function observableToAsyncIterable(observable) {
|
|
128
|
-
const stream = observableToReadableStream(observable);
|
|
139
|
+
/** @internal */ function observableToAsyncIterable(observable, signal) {
|
|
140
|
+
const stream = observableToReadableStream(observable, signal);
|
|
129
141
|
const reader = stream.getReader();
|
|
130
142
|
const iterator = {
|
|
131
143
|
async next () {
|
package/dist/rpc.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
var codes = require('./unstable-core-do-not-import/rpc/codes.js');
|
|
4
4
|
var parseTRPCMessage = require('./unstable-core-do-not-import/rpc/parseTRPCMessage.js');
|
|
5
5
|
require('./vendor/unpromise/unpromise.js');
|
|
6
|
-
require('./unstable-core-do-not-import/stream/utils/
|
|
6
|
+
require('./unstable-core-do-not-import/stream/utils/disposable.js');
|
|
7
7
|
require('./unstable-core-do-not-import/rootConfig.js');
|
|
8
8
|
|
|
9
9
|
|
package/dist/rpc.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { TRPC_ERROR_CODES_BY_KEY, TRPC_ERROR_CODES_BY_NUMBER } from './unstable-core-do-not-import/rpc/codes.mjs';
|
|
2
2
|
export { parseTRPCMessage } from './unstable-core-do-not-import/rpc/parseTRPCMessage.mjs';
|
|
3
3
|
import './vendor/unpromise/unpromise.mjs';
|
|
4
|
-
import './unstable-core-do-not-import/stream/utils/
|
|
4
|
+
import './unstable-core-do-not-import/stream/utils/disposable.mjs';
|
|
5
5
|
import './unstable-core-do-not-import/rootConfig.mjs';
|
package/dist/shared.js
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
var createProxy = require('./unstable-core-do-not-import/createProxy.js');
|
|
4
4
|
var getErrorShape = require('./unstable-core-do-not-import/error/getErrorShape.js');
|
|
5
5
|
require('./vendor/unpromise/unpromise.js');
|
|
6
|
-
require('./unstable-core-do-not-import/stream/utils/
|
|
6
|
+
require('./unstable-core-do-not-import/stream/utils/disposable.js');
|
|
7
7
|
require('./unstable-core-do-not-import/rootConfig.js');
|
|
8
8
|
|
|
9
9
|
|
package/dist/shared.mjs
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
export { createFlatProxy } from './unstable-core-do-not-import/createProxy.mjs';
|
|
2
2
|
export { getErrorShape } from './unstable-core-do-not-import/error/getErrorShape.mjs';
|
|
3
3
|
import './vendor/unpromise/unpromise.mjs';
|
|
4
|
-
import './unstable-core-do-not-import/stream/utils/
|
|
4
|
+
import './unstable-core-do-not-import/stream/utils/disposable.mjs';
|
|
5
5
|
import './unstable-core-do-not-import/rootConfig.mjs';
|
|
@@ -3,7 +3,7 @@ export declare function getCauseFromUnknown(cause: unknown): Error | undefined;
|
|
|
3
3
|
export declare function getTRPCErrorFromUnknown(cause: unknown): TRPCError;
|
|
4
4
|
export declare class TRPCError extends Error {
|
|
5
5
|
readonly cause?: Error;
|
|
6
|
-
readonly code: "
|
|
6
|
+
readonly code: "PARSE_ERROR" | "BAD_REQUEST" | "INTERNAL_SERVER_ERROR" | "NOT_IMPLEMENTED" | "BAD_GATEWAY" | "SERVICE_UNAVAILABLE" | "GATEWAY_TIMEOUT" | "UNAUTHORIZED" | "FORBIDDEN" | "NOT_FOUND" | "METHOD_NOT_SUPPORTED" | "TIMEOUT" | "CONFLICT" | "PRECONDITION_FAILED" | "PAYLOAD_TOO_LARGE" | "UNSUPPORTED_MEDIA_TYPE" | "UNPROCESSABLE_CONTENT" | "TOO_MANY_REQUESTS" | "CLIENT_CLOSED_REQUEST";
|
|
7
7
|
constructor(opts: {
|
|
8
8
|
message?: string;
|
|
9
9
|
code: TRPC_ERROR_CODE_KEY;
|
|
@@ -1,8 +1,20 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var _define_property = require('../../node_modules/.pnpm/@swc_helpers@0.5.13/node_modules/@swc/helpers/esm/_define_property.js');
|
|
4
3
|
var utils = require('../utils.js');
|
|
5
4
|
|
|
5
|
+
function _define_property(obj, key, value) {
|
|
6
|
+
if (key in obj) {
|
|
7
|
+
Object.defineProperty(obj, key, {
|
|
8
|
+
value: value,
|
|
9
|
+
enumerable: true,
|
|
10
|
+
configurable: true,
|
|
11
|
+
writable: true
|
|
12
|
+
});
|
|
13
|
+
} else {
|
|
14
|
+
obj[key] = value;
|
|
15
|
+
}
|
|
16
|
+
return obj;
|
|
17
|
+
}
|
|
6
18
|
class UnknownCauseError extends Error {
|
|
7
19
|
}
|
|
8
20
|
function getCauseFromUnknown(cause) {
|
|
@@ -55,7 +67,7 @@ class TRPCError extends Error {
|
|
|
55
67
|
cause
|
|
56
68
|
}), // eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
57
69
|
// @ts-ignore override doesn't work in all environments due to "This member cannot have an 'override' modifier because it is not declared in the base class 'Error'"
|
|
58
|
-
_define_property
|
|
70
|
+
_define_property(this, "cause", void 0), _define_property(this, "code", void 0);
|
|
59
71
|
this.code = opts.code;
|
|
60
72
|
this.name = 'TRPCError';
|
|
61
73
|
if (!this.cause) {
|
|
@@ -1,6 +1,18 @@
|
|
|
1
|
-
import { _ as _define_property } from '../../node_modules/.pnpm/@swc_helpers@0.5.13/node_modules/@swc/helpers/esm/_define_property.mjs';
|
|
2
1
|
import { isObject } from '../utils.mjs';
|
|
3
2
|
|
|
3
|
+
function _define_property(obj, key, value) {
|
|
4
|
+
if (key in obj) {
|
|
5
|
+
Object.defineProperty(obj, key, {
|
|
6
|
+
value: value,
|
|
7
|
+
enumerable: true,
|
|
8
|
+
configurable: true,
|
|
9
|
+
writable: true
|
|
10
|
+
});
|
|
11
|
+
} else {
|
|
12
|
+
obj[key] = value;
|
|
13
|
+
}
|
|
14
|
+
return obj;
|
|
15
|
+
}
|
|
4
16
|
class UnknownCauseError extends Error {
|
|
5
17
|
}
|
|
6
18
|
function getCauseFromUnknown(cause) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"resolveResponse.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/http/resolveResponse.ts"],"names":[],"mappings":"AAMA,OAAO,EAA2B,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAExE,OAAO,EACL,KAAK,SAAS,EAGf,MAAM,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"resolveResponse.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/http/resolveResponse.ts"],"names":[],"mappings":"AAMA,OAAO,EAA2B,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAExE,OAAO,EACL,KAAK,SAAS,EAGf,MAAM,WAAW,CAAC;AAQnB,OAAO,KAAK,EACV,sBAAsB,EACtB,kCAAkC,EAEnC,MAAM,SAAS,CAAC;AA+BjB,UAAU,yBAAyB,CAAC,OAAO,SAAS,SAAS,CAC3D,SAAQ,sBAAsB,CAAC,OAAO,EAAE,OAAO,CAAC;IAChD,aAAa,EAAE,kCAAkC,CAAC,OAAO,CAAC,CAAC;IAC3D,GAAG,EAAE,OAAO,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb;;OAEG;IACH,KAAK,EAAE,SAAS,GAAG,IAAI,CAAC;CACzB;AA2ID,wBAAsB,eAAe,CAAC,OAAO,SAAS,SAAS,EAC7D,IAAI,EAAE,yBAAyB,CAAC,OAAO,CAAC,GACvC,OAAO,CAAC,QAAQ,CAAC,CAqfnB"}
|
|
@@ -11,15 +11,9 @@ var contentType = require('./contentType.js');
|
|
|
11
11
|
var getHTTPStatusCode = require('./getHTTPStatusCode.js');
|
|
12
12
|
|
|
13
13
|
function errorToAsyncIterable(err) {
|
|
14
|
-
return {
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
next () {
|
|
18
|
-
throw err;
|
|
19
|
-
}
|
|
20
|
-
};
|
|
21
|
-
}
|
|
22
|
-
};
|
|
14
|
+
return utils.run(async function*() {
|
|
15
|
+
throw err;
|
|
16
|
+
});
|
|
23
17
|
}
|
|
24
18
|
const TYPE_ACCEPTED_METHOD_MAP = {
|
|
25
19
|
mutation: [
|
|
@@ -254,22 +248,17 @@ async function resolveResponse(opts) {
|
|
|
254
248
|
});
|
|
255
249
|
}
|
|
256
250
|
}
|
|
257
|
-
const abortCtrl = new AbortController();
|
|
258
251
|
const data = await proc({
|
|
259
252
|
path: call.path,
|
|
260
253
|
getRawInput: call.getRawInput,
|
|
261
254
|
ctx: ctxManager.value(),
|
|
262
255
|
type: proc._def.type,
|
|
263
|
-
signal:
|
|
264
|
-
opts.req.signal,
|
|
265
|
-
abortCtrl.signal
|
|
266
|
-
])
|
|
256
|
+
signal: opts.req.signal
|
|
267
257
|
});
|
|
268
258
|
return [
|
|
269
259
|
undefined,
|
|
270
260
|
{
|
|
271
|
-
data
|
|
272
|
-
abortCtrl
|
|
261
|
+
data
|
|
273
262
|
}
|
|
274
263
|
];
|
|
275
264
|
} catch (cause) {
|
|
@@ -356,7 +345,7 @@ async function resolveResponse(opts) {
|
|
|
356
345
|
code: 'INTERNAL_SERVER_ERROR'
|
|
357
346
|
}));
|
|
358
347
|
}
|
|
359
|
-
const dataAsIterable = observable.isObservable(result.data) ? observable.observableToAsyncIterable(result.data) : result.data;
|
|
348
|
+
const dataAsIterable = observable.isObservable(result.data) ? observable.observableToAsyncIterable(result.data, opts.req.signal) : result.data;
|
|
360
349
|
return dataAsIterable;
|
|
361
350
|
});
|
|
362
351
|
const stream = sse.sseStreamProducer({
|
|
@@ -450,7 +439,7 @@ async function resolveResponse(opts) {
|
|
|
450
439
|
/**
|
|
451
440
|
* Not very pretty, but we need to wrap nested data in promises
|
|
452
441
|
* Our stream producer will only resolve top-level async values or async values that are directly nested in another async value
|
|
453
|
-
*/ const iterable = observable.isObservable(result.data) ? observable.observableToAsyncIterable(result.data) : Promise.resolve(result.data);
|
|
442
|
+
*/ const iterable = observable.isObservable(result.data) ? observable.observableToAsyncIterable(result.data, opts.req.signal) : Promise.resolve(result.data);
|
|
454
443
|
return {
|
|
455
444
|
result: Promise.resolve({
|
|
456
445
|
data: iterable
|
|
@@ -4,20 +4,14 @@ import { getTRPCErrorFromUnknown, TRPCError } from '../error/TRPCError.mjs';
|
|
|
4
4
|
import { jsonlStreamProducer, isPromise } from '../stream/jsonl.mjs';
|
|
5
5
|
import { sseStreamProducer, sseHeaders } from '../stream/sse.mjs';
|
|
6
6
|
import { transformTRPCResponse } from '../transformer.mjs';
|
|
7
|
-
import { run,
|
|
7
|
+
import { run, isAsyncIterable, isObject } from '../utils.mjs';
|
|
8
8
|
import { getRequestInfo } from './contentType.mjs';
|
|
9
9
|
import { getHTTPStatusCode } from './getHTTPStatusCode.mjs';
|
|
10
10
|
|
|
11
11
|
function errorToAsyncIterable(err) {
|
|
12
|
-
return {
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
next () {
|
|
16
|
-
throw err;
|
|
17
|
-
}
|
|
18
|
-
};
|
|
19
|
-
}
|
|
20
|
-
};
|
|
12
|
+
return run(async function*() {
|
|
13
|
+
throw err;
|
|
14
|
+
});
|
|
21
15
|
}
|
|
22
16
|
const TYPE_ACCEPTED_METHOD_MAP = {
|
|
23
17
|
mutation: [
|
|
@@ -252,22 +246,17 @@ async function resolveResponse(opts) {
|
|
|
252
246
|
});
|
|
253
247
|
}
|
|
254
248
|
}
|
|
255
|
-
const abortCtrl = new AbortController();
|
|
256
249
|
const data = await proc({
|
|
257
250
|
path: call.path,
|
|
258
251
|
getRawInput: call.getRawInput,
|
|
259
252
|
ctx: ctxManager.value(),
|
|
260
253
|
type: proc._def.type,
|
|
261
|
-
signal:
|
|
262
|
-
opts.req.signal,
|
|
263
|
-
abortCtrl.signal
|
|
264
|
-
])
|
|
254
|
+
signal: opts.req.signal
|
|
265
255
|
});
|
|
266
256
|
return [
|
|
267
257
|
undefined,
|
|
268
258
|
{
|
|
269
|
-
data
|
|
270
|
-
abortCtrl
|
|
259
|
+
data
|
|
271
260
|
}
|
|
272
261
|
];
|
|
273
262
|
} catch (cause) {
|
|
@@ -354,7 +343,7 @@ async function resolveResponse(opts) {
|
|
|
354
343
|
code: 'INTERNAL_SERVER_ERROR'
|
|
355
344
|
}));
|
|
356
345
|
}
|
|
357
|
-
const dataAsIterable = isObservable(result.data) ? observableToAsyncIterable(result.data) : result.data;
|
|
346
|
+
const dataAsIterable = isObservable(result.data) ? observableToAsyncIterable(result.data, opts.req.signal) : result.data;
|
|
358
347
|
return dataAsIterable;
|
|
359
348
|
});
|
|
360
349
|
const stream = sseStreamProducer({
|
|
@@ -448,7 +437,7 @@ async function resolveResponse(opts) {
|
|
|
448
437
|
/**
|
|
449
438
|
* Not very pretty, but we need to wrap nested data in promises
|
|
450
439
|
* Our stream producer will only resolve top-level async values or async values that are directly nested in another async value
|
|
451
|
-
*/ const iterable = isObservable(result.data) ? observableToAsyncIterable(result.data) : Promise.resolve(result.data);
|
|
440
|
+
*/ const iterable = isObservable(result.data) ? observableToAsyncIterable(result.data, opts.req.signal) : Promise.resolve(result.data);
|
|
452
441
|
return {
|
|
453
442
|
result: Promise.resolve({
|
|
454
443
|
data: iterable
|
|
@@ -18,8 +18,8 @@ declare const PROMISE_STATUS_REJECTED = 1;
|
|
|
18
18
|
type PROMISE_STATUS_REJECTED = typeof PROMISE_STATUS_REJECTED;
|
|
19
19
|
declare const ASYNC_ITERABLE_STATUS_RETURN = 0;
|
|
20
20
|
type ASYNC_ITERABLE_STATUS_RETURN = typeof ASYNC_ITERABLE_STATUS_RETURN;
|
|
21
|
-
declare const
|
|
22
|
-
type
|
|
21
|
+
declare const ASYNC_ITERABLE_STATUS_YIELD = 1;
|
|
22
|
+
type ASYNC_ITERABLE_STATUS_YIELD = typeof ASYNC_ITERABLE_STATUS_YIELD;
|
|
23
23
|
declare const ASYNC_ITERABLE_STATUS_ERROR = 2;
|
|
24
24
|
type ASYNC_ITERABLE_STATUS_ERROR = typeof ASYNC_ITERABLE_STATUS_ERROR;
|
|
25
25
|
type ChunkDefinitionKey = null | number | string;
|
|
@@ -49,7 +49,7 @@ type IterableChunk = [
|
|
|
49
49
|
value: EncodedValue
|
|
50
50
|
] | [
|
|
51
51
|
chunkIndex: ChunkIndex,
|
|
52
|
-
status:
|
|
52
|
+
status: ASYNC_ITERABLE_STATUS_YIELD,
|
|
53
53
|
value: EncodedValue
|
|
54
54
|
] | [
|
|
55
55
|
chunkIndex: ChunkIndex,
|
|
@@ -86,6 +86,10 @@ declare class StreamInterruptedError extends Error {
|
|
|
86
86
|
export type ConsumerOnError = (opts: {
|
|
87
87
|
error: unknown;
|
|
88
88
|
}) => void;
|
|
89
|
+
/**
|
|
90
|
+
* Represents a chunk of data or stream interruption error that can be enqueued to a controller
|
|
91
|
+
*/
|
|
92
|
+
type ControllerChunk = ChunkData | StreamInterruptedError;
|
|
89
93
|
/**
|
|
90
94
|
* JSON Lines stream consumer
|
|
91
95
|
* @see https://jsonlines.org/
|
|
@@ -102,7 +106,14 @@ export declare function jsonlStreamConsumer<THead>(opts: {
|
|
|
102
106
|
*/
|
|
103
107
|
abortController: AbortController;
|
|
104
108
|
}): Promise<readonly [Awaited<THead>, {
|
|
105
|
-
|
|
109
|
+
getOrCreate: (chunkId: ChunkIndex) => {
|
|
110
|
+
enqueue: (v: ControllerChunk) => void;
|
|
111
|
+
close: () => void;
|
|
112
|
+
closed: boolean;
|
|
113
|
+
getReaderResource: () => ReadableStreamDefaultReader<ControllerChunk> & Disposable;
|
|
114
|
+
};
|
|
115
|
+
isEmpty: () => boolean;
|
|
116
|
+
cancelAll: (reason: unknown) => void;
|
|
106
117
|
}]>;
|
|
107
118
|
export {};
|
|
108
119
|
//# sourceMappingURL=jsonl.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"jsonl.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/stream/jsonl.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"jsonl.d.ts","sourceRoot":"","sources":["../../../src/unstable-core-do-not-import/stream/jsonl.ts"],"names":[],"mappings":"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"}
|