@temporary-name/server 1.9.3-alpha.16e8a4f82a5b0af6e22263774a4af4e6f9afd8bc → 1.9.3-alpha.205fb2d0874fa3b8bbf83112a63016937380442e

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/dist/adapters/aws-lambda/index.d.mts +5 -7
  2. package/dist/adapters/aws-lambda/index.d.ts +5 -7
  3. package/dist/adapters/aws-lambda/index.mjs +6 -9
  4. package/dist/adapters/fetch/index.d.mts +8 -86
  5. package/dist/adapters/fetch/index.d.ts +8 -86
  6. package/dist/adapters/fetch/index.mjs +18 -160
  7. package/dist/adapters/node/index.d.mts +9 -64
  8. package/dist/adapters/node/index.d.ts +9 -64
  9. package/dist/adapters/node/index.mjs +16 -125
  10. package/dist/handler/index.d.mts +28 -0
  11. package/dist/handler/index.d.ts +28 -0
  12. package/dist/handler/index.mjs +8 -0
  13. package/dist/helpers/index.mjs +3 -29
  14. package/dist/index.d.mts +373 -493
  15. package/dist/index.d.ts +373 -493
  16. package/dist/index.mjs +547 -469
  17. package/dist/openapi/index.d.mts +18 -53
  18. package/dist/openapi/index.d.ts +18 -53
  19. package/dist/openapi/index.mjs +384 -378
  20. package/dist/shared/server.B5ntjz_x.d.mts +800 -0
  21. package/dist/shared/server.B5ntjz_x.d.ts +800 -0
  22. package/dist/shared/server.BGG3eatg.mjs +315 -0
  23. package/dist/shared/server.BM9lK_Yv.mjs +523 -0
  24. package/dist/shared/server.BxyeakF-.d.mts +39 -0
  25. package/dist/shared/server.C1RJffw4.mjs +30 -0
  26. package/dist/shared/server.CjPiuQYH.d.mts +51 -0
  27. package/dist/shared/server.CjPiuQYH.d.ts +51 -0
  28. package/dist/shared/server.CmNVzZVe.mjs +156 -0
  29. package/dist/shared/server.Coz0LFSE.d.ts +39 -0
  30. package/dist/shared/server.X8F6e8eV.mjs +499 -0
  31. package/package.json +13 -30
  32. package/dist/adapters/standard/index.d.mts +0 -42
  33. package/dist/adapters/standard/index.d.ts +0 -42
  34. package/dist/adapters/standard/index.mjs +0 -11
  35. package/dist/plugins/index.d.mts +0 -160
  36. package/dist/plugins/index.d.ts +0 -160
  37. package/dist/plugins/index.mjs +0 -288
  38. package/dist/shared/server.BEHw7Eyx.mjs +0 -247
  39. package/dist/shared/server.BKSOrA6h.d.mts +0 -192
  40. package/dist/shared/server.BKSOrA6h.d.ts +0 -192
  41. package/dist/shared/server.BKh8I1Ny.mjs +0 -239
  42. package/dist/shared/server.BeuTpcmO.d.mts +0 -23
  43. package/dist/shared/server.C1fnTLq0.d.mts +0 -57
  44. package/dist/shared/server.CQyYNJ1H.d.ts +0 -57
  45. package/dist/shared/server.DLsti1Pv.mjs +0 -293
  46. package/dist/shared/server.SLLuK6_v.d.ts +0 -23
@@ -1,288 +0,0 @@
1
- import { runWithSpan, value, setSpanError, isAsyncIteratorObject, AsyncIteratorClass, clone, ORPCError } from '@temporary-name/shared';
2
- import { flattenHeader } from '@temporary-name/standard-server';
3
- import { parseBatchRequest, toBatchResponse } from '@temporary-name/standard-server/batch';
4
- import { toFetchHeaders } from '@temporary-name/standard-server-fetch';
5
-
6
- class BatchHandlerPlugin {
7
- maxSize;
8
- mapRequestItem;
9
- successStatus;
10
- headers;
11
- order = 5e6;
12
- constructor(options = {}) {
13
- this.maxSize = options.maxSize ?? 10;
14
- this.mapRequestItem = options.mapRequestItem ?? ((request, { request: batchRequest }) => ({
15
- ...request,
16
- headers: {
17
- ...batchRequest.headers,
18
- ...request.headers
19
- }
20
- }));
21
- this.successStatus = options.successStatus ?? 207;
22
- this.headers = options.headers ?? {};
23
- }
24
- init(options) {
25
- options.rootInterceptors ??= [];
26
- options.rootInterceptors.unshift(async (options2) => {
27
- const xHeader = flattenHeader(options2.request.headers["x-orpc-batch"]);
28
- if (xHeader === void 0) {
29
- return options2.next();
30
- }
31
- let isParsing = false;
32
- try {
33
- return await runWithSpan({ name: "handle_batch_request" }, async (span) => {
34
- const mode = xHeader === "buffered" ? "buffered" : "streaming";
35
- isParsing = true;
36
- const parsed = parseBatchRequest({ ...options2.request, body: await options2.request.body() });
37
- isParsing = false;
38
- span?.setAttribute("batch.mode", mode);
39
- span?.setAttribute("batch.size", parsed.length);
40
- const maxSize = await value(this.maxSize, options2);
41
- if (parsed.length > maxSize) {
42
- const message = "Batch request size exceeds the maximum allowed size";
43
- setSpanError(span, message);
44
- return {
45
- matched: true,
46
- response: {
47
- status: 413,
48
- headers: {},
49
- body: message
50
- }
51
- };
52
- }
53
- const responses = parsed.map((request, index) => {
54
- const mapped = this.mapRequestItem(request, options2);
55
- return options2.next({ ...options2, request: { ...mapped, body: () => Promise.resolve(mapped.body) } }).then(({ response: response2, matched }) => {
56
- span?.addEvent(`response.${index}.${matched ? "success" : "not_matched"}`);
57
- if (matched) {
58
- if (response2.body instanceof Blob || response2.body instanceof FormData || isAsyncIteratorObject(response2.body)) {
59
- return {
60
- index,
61
- status: 500,
62
- headers: {},
63
- body: "Batch responses do not support file/blob, or event-iterator. Please call this procedure separately outside of the batch request."
64
- };
65
- }
66
- return { ...response2, index };
67
- }
68
- return { index, status: 404, headers: {}, body: "No procedure matched" };
69
- }).catch((err) => {
70
- Promise.reject(err);
71
- return { index, status: 500, headers: {}, body: "Internal server error" };
72
- });
73
- });
74
- await Promise.race(responses);
75
- const status = await value(this.successStatus, responses, options2);
76
- const headers = await value(this.headers, responses, options2);
77
- const promises = [...responses];
78
- const response = await toBatchResponse({
79
- status,
80
- headers,
81
- mode,
82
- body: new AsyncIteratorClass(
83
- async () => {
84
- const handling = promises.filter((p) => p !== void 0);
85
- if (handling.length <= 0) {
86
- return { done: true, value: void 0 };
87
- }
88
- const value2 = await Promise.race(handling);
89
- promises[value2.index] = void 0;
90
- return { done: false, value: value2 };
91
- },
92
- async () => {
93
- }
94
- )
95
- });
96
- return {
97
- matched: true,
98
- response
99
- };
100
- });
101
- } catch (cause) {
102
- if (isParsing) {
103
- return {
104
- matched: true,
105
- response: {
106
- status: 400,
107
- headers: {},
108
- body: "Invalid batch request, this could be caused by a malformed request body or a missing header"
109
- }
110
- };
111
- }
112
- throw cause;
113
- }
114
- });
115
- }
116
- }
117
-
118
- class CORSPlugin {
119
- options;
120
- order = 9e6;
121
- constructor(options = {}) {
122
- const defaults = {
123
- origin: (origin) => origin,
124
- allowMethods: ["GET", "HEAD", "PUT", "POST", "DELETE", "PATCH"]
125
- };
126
- this.options = {
127
- ...defaults,
128
- ...options
129
- };
130
- }
131
- init(options) {
132
- options.rootInterceptors ??= [];
133
- options.rootInterceptors.unshift(async (interceptorOptions) => {
134
- if (interceptorOptions.request.method === "OPTIONS") {
135
- const resHeaders = {};
136
- if (this.options.maxAge !== void 0) {
137
- resHeaders["access-control-max-age"] = this.options.maxAge.toString();
138
- }
139
- if (this.options.allowMethods?.length) {
140
- resHeaders["access-control-allow-methods"] = flattenHeader(this.options.allowMethods);
141
- }
142
- const allowHeaders = this.options.allowHeaders ?? interceptorOptions.request.headers["access-control-request-headers"];
143
- if (typeof allowHeaders === "string" || allowHeaders?.length) {
144
- resHeaders["access-control-allow-headers"] = flattenHeader(allowHeaders);
145
- }
146
- return {
147
- matched: true,
148
- response: {
149
- status: 204,
150
- headers: resHeaders,
151
- body: void 0
152
- }
153
- };
154
- }
155
- return interceptorOptions.next();
156
- });
157
- options.rootInterceptors.unshift(async (interceptorOptions) => {
158
- const result = await interceptorOptions.next();
159
- if (!result.matched) {
160
- return result;
161
- }
162
- const origin = flattenHeader(interceptorOptions.request.headers.origin) ?? "";
163
- const allowedOrigin = await value(this.options.origin, origin, interceptorOptions);
164
- const allowedOriginArr = Array.isArray(allowedOrigin) ? allowedOrigin : [allowedOrigin];
165
- if (allowedOriginArr.includes("*")) {
166
- result.response.headers["access-control-allow-origin"] = "*";
167
- } else {
168
- if (allowedOriginArr.includes(origin)) {
169
- result.response.headers["access-control-allow-origin"] = origin;
170
- }
171
- result.response.headers.vary = interceptorOptions.request.headers.vary ?? "origin";
172
- }
173
- const allowedTimingOrigin = await value(this.options.timingOrigin, origin, interceptorOptions);
174
- const allowedTimingOriginArr = Array.isArray(allowedTimingOrigin) ? allowedTimingOrigin : [allowedTimingOrigin];
175
- if (allowedTimingOriginArr.includes("*")) {
176
- result.response.headers["timing-allow-origin"] = "*";
177
- } else if (allowedTimingOriginArr.includes(origin)) {
178
- result.response.headers["timing-allow-origin"] = origin;
179
- }
180
- if (this.options.credentials) {
181
- result.response.headers["access-control-allow-credentials"] = "true";
182
- }
183
- if (this.options.exposeHeaders?.length) {
184
- result.response.headers["access-control-expose-headers"] = flattenHeader(this.options.exposeHeaders);
185
- }
186
- return result;
187
- });
188
- }
189
- }
190
-
191
- class RequestHeadersPlugin {
192
- init(options) {
193
- options.rootInterceptors ??= [];
194
- options.rootInterceptors.push((interceptorOptions) => {
195
- const reqHeaders = interceptorOptions.context.reqHeaders ?? toFetchHeaders(interceptorOptions.request.headers);
196
- return interceptorOptions.next({
197
- ...interceptorOptions,
198
- context: {
199
- ...interceptorOptions.context,
200
- reqHeaders
201
- }
202
- });
203
- });
204
- }
205
- }
206
-
207
- class ResponseHeadersPlugin {
208
- init(options) {
209
- options.rootInterceptors ??= [];
210
- options.rootInterceptors.push(async (interceptorOptions) => {
211
- const resHeaders = interceptorOptions.context.resHeaders ?? new Headers();
212
- const result = await interceptorOptions.next({
213
- ...interceptorOptions,
214
- context: {
215
- ...interceptorOptions.context,
216
- resHeaders
217
- }
218
- });
219
- if (!result.matched) {
220
- return result;
221
- }
222
- const responseHeaders = clone(result.response.headers);
223
- for (const [key, value] of resHeaders) {
224
- if (Array.isArray(responseHeaders[key])) {
225
- responseHeaders[key].push(value);
226
- } else if (responseHeaders[key] !== void 0) {
227
- responseHeaders[key] = [responseHeaders[key], value];
228
- } else {
229
- responseHeaders[key] = value;
230
- }
231
- }
232
- return {
233
- ...result,
234
- response: {
235
- ...result.response,
236
- headers: responseHeaders
237
- }
238
- };
239
- });
240
- }
241
- }
242
-
243
- const SIMPLE_CSRF_PROTECTION_CONTEXT_SYMBOL = Symbol("SIMPLE_CSRF_PROTECTION_CONTEXT");
244
- class SimpleCsrfProtectionHandlerPlugin {
245
- headerName;
246
- headerValue;
247
- exclude;
248
- error;
249
- constructor(options = {}) {
250
- this.headerName = options.headerName ?? "x-csrf-token";
251
- this.headerValue = options.headerValue ?? "orpc";
252
- this.exclude = options.exclude ?? false;
253
- this.error = options.error ?? new ORPCError("CSRF_TOKEN_MISMATCH", {
254
- status: 403,
255
- message: "Invalid CSRF token"
256
- });
257
- }
258
- order = 8e6;
259
- init(options) {
260
- options.rootInterceptors ??= [];
261
- options.clientInterceptors ??= [];
262
- options.rootInterceptors.unshift(async (options2) => {
263
- const headerName = await value(this.headerName, options2);
264
- const headerValue = await value(this.headerValue, options2);
265
- return options2.next({
266
- ...options2,
267
- context: {
268
- ...options2.context,
269
- [SIMPLE_CSRF_PROTECTION_CONTEXT_SYMBOL]: options2.request.headers[headerName] === headerValue
270
- }
271
- });
272
- });
273
- options.clientInterceptors.unshift(async (options2) => {
274
- if (typeof options2.context[SIMPLE_CSRF_PROTECTION_CONTEXT_SYMBOL] !== "boolean") {
275
- throw new TypeError(
276
- "[SimpleCsrfProtectionHandlerPlugin] CSRF protection context has been corrupted or modified by another plugin or interceptor"
277
- );
278
- }
279
- const excluded = await value(this.exclude, options2);
280
- if (!excluded && !options2.context[SIMPLE_CSRF_PROTECTION_CONTEXT_SYMBOL]) {
281
- throw this.error;
282
- }
283
- return options2.next();
284
- });
285
- }
286
- }
287
-
288
- export { BatchHandlerPlugin, CORSPlugin, RequestHeadersPlugin, ResponseHeadersPlugin, SimpleCsrfProtectionHandlerPlugin };
@@ -1,247 +0,0 @@
1
- import { isObject, NullProtoObj, isAsyncIteratorObject, isORPCErrorJson, createORPCErrorFromJson, toORPCError } from '@temporary-name/shared';
2
- import { mapEventIterator, ErrorEvent } from '@temporary-name/standard-server';
3
-
4
- function bracketNotationSerialize(data, segments = [], result = []) {
5
- if (Array.isArray(data)) {
6
- data.forEach((item, i) => {
7
- bracketNotationSerialize(item, [...segments, i], result);
8
- });
9
- } else if (isObject(data)) {
10
- for (const key in data) {
11
- bracketNotationSerialize(data[key], [...segments, key], result);
12
- }
13
- } else {
14
- result.push([stringifyPath(segments), data]);
15
- }
16
- return result;
17
- }
18
- function bracketNotationDeserialize(serialized, { maxArrayIndex = 9999 } = {}) {
19
- if (serialized.length === 0) {
20
- return {};
21
- }
22
- const arrayPushStyles = /* @__PURE__ */ new WeakSet();
23
- const ref = { value: [] };
24
- for (const [path, value] of serialized) {
25
- const segments = parsePath(path);
26
- let currentRef = ref;
27
- let nextSegment = "value";
28
- segments.forEach((segment, i) => {
29
- if (!Array.isArray(currentRef[nextSegment]) && !isObject(currentRef[nextSegment])) {
30
- currentRef[nextSegment] = [];
31
- }
32
- if (i !== segments.length - 1) {
33
- if (Array.isArray(currentRef[nextSegment]) && !isValidArrayIndex(segment, maxArrayIndex)) {
34
- if (arrayPushStyles.has(currentRef[nextSegment])) {
35
- arrayPushStyles.delete(currentRef[nextSegment]);
36
- currentRef[nextSegment] = pushStyleArrayToObject(currentRef[nextSegment]);
37
- } else {
38
- currentRef[nextSegment] = arrayToObject(currentRef[nextSegment]);
39
- }
40
- }
41
- } else {
42
- if (Array.isArray(currentRef[nextSegment])) {
43
- if (segment === "") {
44
- if (currentRef[nextSegment].length && !arrayPushStyles.has(currentRef[nextSegment])) {
45
- currentRef[nextSegment] = arrayToObject(currentRef[nextSegment]);
46
- }
47
- } else {
48
- if (arrayPushStyles.has(currentRef[nextSegment])) {
49
- arrayPushStyles.delete(currentRef[nextSegment]);
50
- currentRef[nextSegment] = pushStyleArrayToObject(currentRef[nextSegment]);
51
- } else if (!isValidArrayIndex(segment, maxArrayIndex)) {
52
- currentRef[nextSegment] = arrayToObject(currentRef[nextSegment]);
53
- }
54
- }
55
- }
56
- }
57
- currentRef = currentRef[nextSegment];
58
- nextSegment = segment;
59
- });
60
- if (Array.isArray(currentRef) && nextSegment === "") {
61
- arrayPushStyles.add(currentRef);
62
- currentRef.push(value);
63
- } else if (nextSegment in currentRef) {
64
- if (Array.isArray(currentRef[nextSegment])) {
65
- currentRef[nextSegment].push(value);
66
- } else {
67
- currentRef[nextSegment] = [currentRef[nextSegment], value];
68
- }
69
- } else {
70
- currentRef[nextSegment] = value;
71
- }
72
- }
73
- return ref.value;
74
- }
75
- function stringifyPath(segments) {
76
- return segments.map((segment) => {
77
- return segment.toString().replace(/[\\[\]]/g, (match) => {
78
- switch (match) {
79
- case "\\":
80
- return "\\\\";
81
- case "[":
82
- return "\\[";
83
- case "]":
84
- return "\\]";
85
- /* v8 ignore next 2 */
86
- default:
87
- return match;
88
- }
89
- });
90
- }).reduce((result, segment, i) => {
91
- if (i === 0) {
92
- return segment;
93
- }
94
- return `${result}[${segment}]`;
95
- }, "");
96
- }
97
- function parsePath(path) {
98
- const segments = [];
99
- let inBrackets = false;
100
- let currentSegment = "";
101
- let backslashCount = 0;
102
- for (let i = 0; i < path.length; i++) {
103
- const char = path[i];
104
- const nextChar = path[i + 1];
105
- if (inBrackets && char === "]" && (nextChar === void 0 || nextChar === "[") && backslashCount % 2 === 0) {
106
- if (nextChar === void 0) {
107
- inBrackets = false;
108
- }
109
- segments.push(currentSegment);
110
- currentSegment = "";
111
- i++;
112
- } else if (segments.length === 0 && char === "[" && backslashCount % 2 === 0) {
113
- inBrackets = true;
114
- segments.push(currentSegment);
115
- currentSegment = "";
116
- } else if (char === "\\") {
117
- backslashCount++;
118
- } else {
119
- currentSegment += "\\".repeat(backslashCount / 2) + char;
120
- backslashCount = 0;
121
- }
122
- }
123
- return inBrackets || segments.length === 0 ? [path] : segments;
124
- }
125
- function isValidArrayIndex(value, maxIndex) {
126
- return /^0$|^[1-9]\d*$/.test(value) && Number(value) <= maxIndex;
127
- }
128
- function arrayToObject(array) {
129
- const obj = new NullProtoObj();
130
- array.forEach((item, i) => {
131
- obj[i] = item;
132
- });
133
- return obj;
134
- }
135
- function pushStyleArrayToObject(array) {
136
- const obj = new NullProtoObj();
137
- obj[""] = array.length === 1 ? array[0] : array;
138
- return obj;
139
- }
140
-
141
- function jsonSerialize(data, hasBlobRef = { value: false }) {
142
- if (data instanceof Blob) {
143
- hasBlobRef.value = true;
144
- return [data, hasBlobRef.value];
145
- }
146
- if (data instanceof Set) {
147
- return jsonSerialize(Array.from(data), hasBlobRef);
148
- }
149
- if (data instanceof Map) {
150
- return jsonSerialize(Array.from(data.entries()), hasBlobRef);
151
- }
152
- if (Array.isArray(data)) {
153
- const json = data.map((v) => v === void 0 ? null : jsonSerialize(v, hasBlobRef)[0]);
154
- return [json, hasBlobRef.value];
155
- }
156
- if (isObject(data)) {
157
- const json = {};
158
- for (const k in data) {
159
- if (k === "toJSON" && typeof data[k] === "function") {
160
- continue;
161
- }
162
- json[k] = jsonSerialize(data[k], hasBlobRef)[0];
163
- }
164
- return [json, hasBlobRef.value];
165
- }
166
- if (typeof data === "bigint" || data instanceof RegExp || data instanceof URL) {
167
- return [data.toString(), hasBlobRef.value];
168
- }
169
- if (data instanceof Date) {
170
- return [Number.isNaN(data.getTime()) ? null : data.toISOString(), hasBlobRef.value];
171
- }
172
- if (Number.isNaN(data)) {
173
- return [null, hasBlobRef.value];
174
- }
175
- return [data, hasBlobRef.value];
176
- }
177
-
178
- function serialize(data, options = {}) {
179
- if (isAsyncIteratorObject(data) && !options.outputFormat) {
180
- return mapEventIterator(data, {
181
- value: async (value) => _serialize(value, { outputFormat: "plain" }),
182
- error: async (e) => {
183
- return new ErrorEvent({
184
- data: _serialize(toORPCError(e).toJSON(), { outputFormat: "plain" }),
185
- cause: e
186
- });
187
- }
188
- });
189
- }
190
- return _serialize(data, options);
191
- }
192
- function _serialize(data, options) {
193
- const [json, hasBlob] = jsonSerialize(data);
194
- if (options.outputFormat === "plain") {
195
- return json;
196
- }
197
- if (options.outputFormat === "URLSearchParams") {
198
- const params = new URLSearchParams();
199
- for (const [path, value] of bracketNotationSerialize(json)) {
200
- if (typeof value === "string" || typeof value === "number" || typeof value === "boolean") {
201
- params.append(path, value.toString());
202
- }
203
- }
204
- return params;
205
- }
206
- if (json instanceof Blob || json === void 0 || !hasBlob) {
207
- return json;
208
- }
209
- const form = new FormData();
210
- for (const [path, value] of bracketNotationSerialize(json)) {
211
- if (typeof value === "string" || typeof value === "number" || typeof value === "boolean") {
212
- form.append(path, value.toString());
213
- } else if (value instanceof Blob) {
214
- form.append(path, value);
215
- }
216
- }
217
- return form;
218
- }
219
- function deserialize(data) {
220
- if (data instanceof URLSearchParams || data instanceof FormData) {
221
- return bracketNotationDeserialize(Array.from(data.entries()));
222
- }
223
- if (isAsyncIteratorObject(data)) {
224
- return mapEventIterator(data, {
225
- value: async (value) => value,
226
- error: async (e) => {
227
- if (e instanceof ErrorEvent && isORPCErrorJson(e.data)) {
228
- return createORPCErrorFromJson(e.data, { cause: e });
229
- }
230
- return e;
231
- }
232
- });
233
- }
234
- return data;
235
- }
236
-
237
- function standardizeHTTPPath(path) {
238
- return `/${path.replace(/\/{2,}/g, "/").replace(/^\/|\/$/g, "")}`;
239
- }
240
- function getDynamicParams(path) {
241
- return path ? standardizeHTTPPath(path).match(/\/\{[^}]+\}/g)?.map((v) => ({
242
- raw: v,
243
- name: v.match(/\{\+?([^}]+)\}/)[1]
244
- })) : void 0;
245
- }
246
-
247
- export { standardizeHTTPPath as a, deserialize as d, getDynamicParams as g, jsonSerialize as j, serialize as s };