@orpc/shared 0.0.0-next.f4d410a → 0.0.0-next.f538070

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 CHANGED
@@ -58,6 +58,7 @@ You can find the full documentation [here](https://orpc.unnoq.com).
58
58
  - [@orpc/contract](https://www.npmjs.com/package/@orpc/contract): Build your API contract.
59
59
  - [@orpc/server](https://www.npmjs.com/package/@orpc/server): Build your API or implement API contract.
60
60
  - [@orpc/client](https://www.npmjs.com/package/@orpc/client): Consume your API on the client with type-safety.
61
+ - [@orpc/react](https://www.npmjs.com/package/@orpc/react): Utilities for integrating oRPC with React and React Server Actions.
61
62
  - [@orpc/react-query](https://www.npmjs.com/package/@orpc/react-query): Integration with [React Query](https://tanstack.com/query/latest/docs/framework/react/overview).
62
63
  - [@orpc/vue-query](https://www.npmjs.com/package/@orpc/vue-query): Integration with [Vue Query](https://tanstack.com/query/latest/docs/framework/vue/overview).
63
64
  - [@orpc/solid-query](https://www.npmjs.com/package/@orpc/solid-query): Integration with [Solid Query](https://tanstack.com/query/latest/docs/framework/solid/overview).
@@ -65,11 +66,21 @@ You can find the full documentation [here](https://orpc.unnoq.com).
65
66
  - [@orpc/vue-colada](https://www.npmjs.com/package/@orpc/vue-colada): Integration with [Pinia Colada](https://pinia-colada.esm.dev/).
66
67
  - [@orpc/openapi](https://www.npmjs.com/package/@orpc/openapi): Generate OpenAPI specs and handle OpenAPI requests.
67
68
  - [@orpc/zod](https://www.npmjs.com/package/@orpc/zod): More schemas that [Zod](https://zod.dev/) doesn't support yet.
69
+ - [@orpc/valibot](https://www.npmjs.com/package/@orpc/valibot): OpenAPI spec generation from [Valibot](https://valibot.dev/).
70
+ - [@orpc/arktype](https://www.npmjs.com/package/@orpc/arktype): OpenAPI spec generation from [ArkType](https://arktype.io/).
68
71
 
69
72
  ## `@orpc/shared`
70
73
 
71
74
  Provides shared utilities for oRPC packages.
72
75
 
76
+ ## Sponsors
77
+
78
+ <p align="center">
79
+ <a href="https://cdn.jsdelivr.net/gh/unnoq/unnoq/sponsors.svg">
80
+ <img src='https://cdn.jsdelivr.net/gh/unnoq/unnoq/sponsors.svg'/>
81
+ </a>
82
+ </p>
83
+
73
84
  ## License
74
85
 
75
86
  Distributed under the MIT License. See [LICENSE](https://github.com/unnoq/orpc/blob/main/LICENSE) for more information.
package/dist/index.d.mts CHANGED
@@ -1,6 +1,12 @@
1
1
  import { Promisable } from 'type-fest';
2
2
  export { IsEqual, IsNever, PartialDeep, Promisable } from 'type-fest';
3
- export { group, guard, mapEntries, mapValues, omit, retry, trim } from 'radash';
3
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
4
+
5
+ type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
6
+ declare function resolveMaybeOptionalOptions<T>(rest: MaybeOptionalOptions<T>): T;
7
+
8
+ declare function toArray<T>(value: T): T extends readonly any[] ? T : Exclude<T, undefined | null>[];
9
+ declare function splitInHalf<T>(arr: readonly T[]): [T[], T[]];
4
10
 
5
11
  type AnyFunction = (...args: any[]) => any;
6
12
  declare function once<T extends () => any>(fn: T): () => ReturnType<T>;
@@ -9,50 +15,54 @@ type OmitChainMethodDeep<T extends object, K extends keyof any> = {
9
15
  [P in keyof Omit<T, K>]: T[P] extends AnyFunction ? ((...args: Parameters<T[P]>) => OmitChainMethodDeep<ReturnType<T[P]>, K>) : T[P];
10
16
  };
11
17
 
12
- declare function toError(error: unknown): Error;
13
-
14
- type InterceptableOptions = Record<string, any>;
15
- type InterceptorOptions<TOptions extends InterceptableOptions, TResult> = Omit<TOptions, 'next'> & {
16
- next(options?: TOptions): Promise<TResult>;
17
- };
18
- type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult>) => Promise<TResult> & {
18
+ type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
19
+ type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
20
+ type PromiseWithError<T, TError> = Promise<T> & {
19
21
  __error?: {
20
22
  type: TError;
21
23
  };
22
24
  };
25
+ /**
26
+ * The place where you can config the orpc types.
27
+ *
28
+ * - `throwableError` the error type that represent throwable errors should be `Error` or `null | undefined | {}` if you want more strict.
29
+ */
30
+ interface Registry {
31
+ }
32
+ type ThrowableError = Registry extends {
33
+ throwableError: infer T;
34
+ } ? T : Error;
35
+
36
+ type InterceptableOptions = Record<string, any>;
37
+ type InterceptorOptions<TOptions extends InterceptableOptions, TResult, TError> = Omit<TOptions, 'next'> & {
38
+ next(options?: TOptions): PromiseWithError<TResult, TError>;
39
+ };
40
+ type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult, TError>) => Promisable<TResult>;
23
41
  /**
24
42
  * Can used for interceptors or middlewares
25
43
  */
26
- declare function onStart<TOptions extends {
44
+ declare function onStart<T, TOptions extends {
27
45
  next(): any;
28
- }, TRest extends any[]>(callback: NoInfer<(options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
46
+ }, TRest extends any[]>(callback: NoInfer<(options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
29
47
  /**
30
48
  * Can used for interceptors or middlewares
31
49
  */
32
- declare function onSuccess<TOptions extends {
50
+ declare function onSuccess<T, TOptions extends {
33
51
  next(): any;
34
- }, TRest extends any[]>(callback: NoInfer<(result: Awaited<ReturnType<TOptions['next']>>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
52
+ }, TRest extends any[]>(callback: NoInfer<(result: Awaited<ReturnType<TOptions['next']>>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
35
53
  /**
36
54
  * Can used for interceptors or middlewares
37
55
  */
38
- declare function onError<TError, TOptions extends {
56
+ declare function onError<T, TOptions extends {
39
57
  next(): any;
40
- }, TRest extends any[]>(callback: NoInfer<(error: TError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
41
- __error?: {
42
- type: TError;
43
- };
44
- };
45
- type OnFinishState<TResult, TError> = [TResult, null, 'success'] | [undefined, TError, 'error'];
58
+ }, TRest extends any[]>(callback: NoInfer<(error: ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
59
+ type OnFinishState<TResult, TError> = [error: TError, data: undefined, isSuccess: false] | [error: null, data: TResult, isSuccess: true];
46
60
  /**
47
61
  * Can used for interceptors or middlewares
48
62
  */
49
- declare function onFinish<TError, TOptions extends {
63
+ declare function onFinish<T, TOptions extends {
50
64
  next(): any;
51
- }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, TError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
52
- __error?: {
53
- type: TError;
54
- };
55
- };
65
+ }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
56
66
  declare function intercept<TOptions extends InterceptableOptions, TResult, TError>(interceptors: Interceptor<TOptions, TResult, TError>[], options: NoInfer<TOptions>, main: NoInfer<(options: TOptions) => Promisable<TResult>>): Promise<TResult>;
57
67
 
58
68
  declare function isAsyncIteratorObject(maybe: unknown): maybe is AsyncIteratorObject<any, any, any>;
@@ -74,11 +84,9 @@ declare function isObject(value: unknown): value is Record<PropertyKey, unknown>
74
84
  */
75
85
  declare function isTypescriptObject(value: unknown): value is object & Record<PropertyKey, unknown>;
76
86
  declare function clone<T>(value: T): T;
77
-
78
- type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
79
- type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
87
+ declare function get(object: object, path: readonly string[]): unknown;
80
88
 
81
89
  type Value<T, TArgs extends any[] = []> = T | ((...args: TArgs) => Promisable<T>);
82
90
  declare function value<T, TArgs extends any[]>(value: Value<T, TArgs>, ...args: NoInfer<TArgs>): Promise<T extends Value<infer U, any> ? U : never>;
83
91
 
84
- export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type Segment, type SetOptional, type Value, clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
92
+ export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type PromiseWithError, type Registry, type Segment, type SetOptional, type ThrowableError, type Value, clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, splitInHalf, stringifyJSON, toArray, value };
package/dist/index.d.ts CHANGED
@@ -1,6 +1,12 @@
1
1
  import { Promisable } from 'type-fest';
2
2
  export { IsEqual, IsNever, PartialDeep, Promisable } from 'type-fest';
3
- export { group, guard, mapEntries, mapValues, omit, retry, trim } from 'radash';
3
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
4
+
5
+ type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
6
+ declare function resolveMaybeOptionalOptions<T>(rest: MaybeOptionalOptions<T>): T;
7
+
8
+ declare function toArray<T>(value: T): T extends readonly any[] ? T : Exclude<T, undefined | null>[];
9
+ declare function splitInHalf<T>(arr: readonly T[]): [T[], T[]];
4
10
 
5
11
  type AnyFunction = (...args: any[]) => any;
6
12
  declare function once<T extends () => any>(fn: T): () => ReturnType<T>;
@@ -9,50 +15,54 @@ type OmitChainMethodDeep<T extends object, K extends keyof any> = {
9
15
  [P in keyof Omit<T, K>]: T[P] extends AnyFunction ? ((...args: Parameters<T[P]>) => OmitChainMethodDeep<ReturnType<T[P]>, K>) : T[P];
10
16
  };
11
17
 
12
- declare function toError(error: unknown): Error;
13
-
14
- type InterceptableOptions = Record<string, any>;
15
- type InterceptorOptions<TOptions extends InterceptableOptions, TResult> = Omit<TOptions, 'next'> & {
16
- next(options?: TOptions): Promise<TResult>;
17
- };
18
- type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult>) => Promise<TResult> & {
18
+ type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
19
+ type IntersectPick<T, U> = Pick<T, keyof T & keyof U>;
20
+ type PromiseWithError<T, TError> = Promise<T> & {
19
21
  __error?: {
20
22
  type: TError;
21
23
  };
22
24
  };
25
+ /**
26
+ * The place where you can config the orpc types.
27
+ *
28
+ * - `throwableError` the error type that represent throwable errors should be `Error` or `null | undefined | {}` if you want more strict.
29
+ */
30
+ interface Registry {
31
+ }
32
+ type ThrowableError = Registry extends {
33
+ throwableError: infer T;
34
+ } ? T : Error;
35
+
36
+ type InterceptableOptions = Record<string, any>;
37
+ type InterceptorOptions<TOptions extends InterceptableOptions, TResult, TError> = Omit<TOptions, 'next'> & {
38
+ next(options?: TOptions): PromiseWithError<TResult, TError>;
39
+ };
40
+ type Interceptor<TOptions extends InterceptableOptions, TResult, TError> = (options: InterceptorOptions<TOptions, TResult, TError>) => Promisable<TResult>;
23
41
  /**
24
42
  * Can used for interceptors or middlewares
25
43
  */
26
- declare function onStart<TOptions extends {
44
+ declare function onStart<T, TOptions extends {
27
45
  next(): any;
28
- }, TRest extends any[]>(callback: NoInfer<(options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
46
+ }, TRest extends any[]>(callback: NoInfer<(options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
29
47
  /**
30
48
  * Can used for interceptors or middlewares
31
49
  */
32
- declare function onSuccess<TOptions extends {
50
+ declare function onSuccess<T, TOptions extends {
33
51
  next(): any;
34
- }, TRest extends any[]>(callback: NoInfer<(result: Awaited<ReturnType<TOptions['next']>>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>>;
52
+ }, TRest extends any[]>(callback: NoInfer<(result: Awaited<ReturnType<TOptions['next']>>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
35
53
  /**
36
54
  * Can used for interceptors or middlewares
37
55
  */
38
- declare function onError<TError, TOptions extends {
56
+ declare function onError<T, TOptions extends {
39
57
  next(): any;
40
- }, TRest extends any[]>(callback: NoInfer<(error: TError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
41
- __error?: {
42
- type: TError;
43
- };
44
- };
45
- type OnFinishState<TResult, TError> = [TResult, null, 'success'] | [undefined, TError, 'error'];
58
+ }, TRest extends any[]>(callback: NoInfer<(error: ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
59
+ type OnFinishState<TResult, TError> = [error: TError, data: undefined, isSuccess: false] | [error: null, data: TResult, isSuccess: true];
46
60
  /**
47
61
  * Can used for interceptors or middlewares
48
62
  */
49
- declare function onFinish<TError, TOptions extends {
63
+ declare function onFinish<T, TOptions extends {
50
64
  next(): any;
51
- }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, TError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => Promise<Awaited<ReturnType<TOptions['next']>>> & {
52
- __error?: {
53
- type: TError;
54
- };
55
- };
65
+ }, TRest extends any[]>(callback: NoInfer<(state: OnFinishState<Awaited<ReturnType<TOptions['next']>>, ReturnType<TOptions['next']> extends PromiseWithError<any, infer E> ? E : ThrowableError>, options: TOptions, ...rest: TRest) => Promisable<void>>): (options: TOptions, ...rest: TRest) => T | Promise<Awaited<ReturnType<TOptions['next']>>>;
56
66
  declare function intercept<TOptions extends InterceptableOptions, TResult, TError>(interceptors: Interceptor<TOptions, TResult, TError>[], options: NoInfer<TOptions>, main: NoInfer<(options: TOptions) => Promisable<TResult>>): Promise<TResult>;
57
67
 
58
68
  declare function isAsyncIteratorObject(maybe: unknown): maybe is AsyncIteratorObject<any, any, any>;
@@ -74,11 +84,9 @@ declare function isObject(value: unknown): value is Record<PropertyKey, unknown>
74
84
  */
75
85
  declare function isTypescriptObject(value: unknown): value is object & Record<PropertyKey, unknown>;
76
86
  declare function clone<T>(value: T): T;
77
-
78
- type MaybeOptionalOptions<TOptions> = Record<never, never> extends TOptions ? [options?: TOptions] : [options: TOptions];
79
- type SetOptional<T, K extends keyof T> = Omit<T, K> & Partial<Pick<T, K>>;
87
+ declare function get(object: object, path: readonly string[]): unknown;
80
88
 
81
89
  type Value<T, TArgs extends any[] = []> = T | ((...args: TArgs) => Promisable<T>);
82
90
  declare function value<T, TArgs extends any[]>(value: Value<T, TArgs>, ...args: NoInfer<TArgs>): Promise<T extends Value<infer U, any> ? U : never>;
83
91
 
84
- export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type Segment, type SetOptional, type Value, clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
92
+ export { type AnyFunction, type InterceptableOptions, type Interceptor, type InterceptorOptions, type IntersectPick, type MaybeOptionalOptions, type OmitChainMethodDeep, type OnFinishState, type PromiseWithError, type Registry, type Segment, type SetOptional, type ThrowableError, type Value, clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, splitInHalf, stringifyJSON, toArray, value };
package/dist/index.mjs CHANGED
@@ -1,10 +1,15 @@
1
- export { group, guard, mapEntries, mapValues, omit, retry, trim } from 'radash';
1
+ export { group, guard, mapEntries, mapValues, omit } from 'radash';
2
2
 
3
- function toError(error) {
4
- if (error instanceof Error) {
5
- return error;
6
- }
7
- return new Error("Unknown error", { cause: error });
3
+ function resolveMaybeOptionalOptions(rest) {
4
+ return rest[0] ?? {};
5
+ }
6
+
7
+ function toArray(value) {
8
+ return Array.isArray(value) ? value : value === void 0 || value === null ? [] : [value];
9
+ }
10
+ function splitInHalf(arr) {
11
+ const half = Math.ceil(arr.length / 2);
12
+ return [arr.slice(0, half), arr.slice(half)];
8
13
  }
9
14
 
10
15
  function once(fn) {
@@ -47,10 +52,10 @@ function onFinish(callback) {
47
52
  return async (options, ...rest) => {
48
53
  try {
49
54
  const result = await options.next();
50
- state = [result, null, "success"];
55
+ state = [null, result, true];
51
56
  return result;
52
57
  } catch (error) {
53
- state = [void 0, error, "error"];
58
+ state = [error, void 0, false];
54
59
  throw error;
55
60
  } finally {
56
61
  await callback(state, options, ...rest);
@@ -58,18 +63,17 @@ function onFinish(callback) {
58
63
  };
59
64
  }
60
65
  async function intercept(interceptors, options, main) {
61
- let index = 0;
62
- const next = async (options2) => {
63
- const interceptor = interceptors[index++];
66
+ const next = async (options2, index) => {
67
+ const interceptor = interceptors[index];
64
68
  if (!interceptor) {
65
69
  return await main(options2);
66
70
  }
67
71
  return await interceptor({
68
72
  ...options2,
69
- next: (newOptions = options2) => next(newOptions)
73
+ next: (newOptions = options2) => next(newOptions, index + 1)
70
74
  });
71
75
  };
72
- return await next(options);
76
+ return next(options, 0);
73
77
  }
74
78
 
75
79
  function isAsyncIteratorObject(maybe) {
@@ -127,6 +131,16 @@ function clone(value) {
127
131
  }
128
132
  return value;
129
133
  }
134
+ function get(object, path) {
135
+ let current = object;
136
+ for (const key of path) {
137
+ if (!isTypescriptObject(current)) {
138
+ return void 0;
139
+ }
140
+ current = current[key];
141
+ }
142
+ return current;
143
+ }
130
144
 
131
145
  function value(value2, ...args) {
132
146
  if (typeof value2 === "function") {
@@ -135,4 +149,4 @@ function value(value2, ...args) {
135
149
  return value2;
136
150
  }
137
151
 
138
- export { clone, findDeepMatches, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, stringifyJSON, toError, value };
152
+ export { clone, findDeepMatches, get, intercept, isAsyncIteratorObject, isObject, isTypescriptObject, onError, onFinish, onStart, onSuccess, once, parseEmptyableJSON, resolveMaybeOptionalOptions, splitInHalf, stringifyJSON, toArray, value };
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@orpc/shared",
3
3
  "type": "module",
4
- "version": "0.0.0-next.f4d410a",
4
+ "version": "0.0.0-next.f538070",
5
5
  "license": "MIT",
6
6
  "homepage": "https://orpc.unnoq.com",
7
7
  "repository": {