crossws 0.2.3 → 0.3.0

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 (66) hide show
  1. package/README.md +8 -9
  2. package/adapters/cloudflare-durable.d.ts +2 -0
  3. package/adapters/sse.d.ts +2 -0
  4. package/dist/adapters/bun.d.mts +25 -6
  5. package/dist/adapters/bun.d.ts +25 -6
  6. package/dist/adapters/bun.mjs +54 -62
  7. package/dist/adapters/cloudflare-durable.d.mts +20 -0
  8. package/dist/adapters/cloudflare-durable.d.ts +20 -0
  9. package/dist/adapters/cloudflare-durable.mjs +132 -0
  10. package/dist/adapters/cloudflare.d.mts +5 -5
  11. package/dist/adapters/cloudflare.d.ts +5 -5
  12. package/dist/adapters/cloudflare.mjs +56 -49
  13. package/dist/adapters/deno.d.mts +10 -3
  14. package/dist/adapters/deno.d.ts +10 -3
  15. package/dist/adapters/deno.mjs +54 -45
  16. package/dist/adapters/node.d.mts +4 -2
  17. package/dist/adapters/node.d.ts +4 -2
  18. package/dist/adapters/node.mjs +108 -71
  19. package/dist/adapters/sse.d.mts +12 -0
  20. package/dist/adapters/sse.d.ts +12 -0
  21. package/dist/adapters/sse.mjs +120 -0
  22. package/dist/adapters/uws.d.mts +45 -9
  23. package/dist/adapters/uws.d.ts +45 -9
  24. package/dist/adapters/uws.mjs +148 -124
  25. package/dist/index.d.mts +136 -4
  26. package/dist/index.d.ts +136 -4
  27. package/dist/index.mjs +1 -10
  28. package/dist/shared/crossws.B4sHId41.mjs +42 -0
  29. package/dist/shared/crossws.By9qWDAI.mjs +8 -0
  30. package/dist/shared/crossws.ChIJSJVK.d.mts +297 -0
  31. package/dist/shared/crossws.ChIJSJVK.d.ts +297 -0
  32. package/dist/shared/crossws.DTY7a69w.mjs +315 -0
  33. package/dist/shared/{crossws.a5db571c.mjs → crossws.YgHWLi0G.mjs} +284 -115
  34. package/dist/websocket/{index.d.mts → native.d.mts} +1 -1
  35. package/dist/websocket/{node.d.cts → native.d.ts} +1 -1
  36. package/dist/websocket/native.mjs +3 -0
  37. package/dist/websocket/node.d.mts +1 -1
  38. package/dist/websocket/node.d.ts +1 -1
  39. package/dist/websocket/node.mjs +1 -1
  40. package/dist/websocket/sse.d.mts +41 -0
  41. package/dist/websocket/sse.d.ts +41 -0
  42. package/dist/websocket/sse.mjs +127 -0
  43. package/package.json +78 -75
  44. package/dist/adapters/bun.cjs +0 -95
  45. package/dist/adapters/bun.d.cts +0 -17
  46. package/dist/adapters/cloudflare.cjs +0 -65
  47. package/dist/adapters/cloudflare.d.cts +0 -12
  48. package/dist/adapters/deno.cjs +0 -63
  49. package/dist/adapters/deno.d.cts +0 -15
  50. package/dist/adapters/node.cjs +0 -726
  51. package/dist/adapters/node.d.cts +0 -298
  52. package/dist/adapters/uws.cjs +0 -153
  53. package/dist/adapters/uws.d.cts +0 -19
  54. package/dist/index.cjs +0 -17
  55. package/dist/index.d.cts +0 -6
  56. package/dist/shared/crossws.2ed26345.cjs +0 -3931
  57. package/dist/shared/crossws.34cfc8d0.mjs +0 -139
  58. package/dist/shared/crossws.a2e5c71e.d.cts +0 -112
  59. package/dist/shared/crossws.a2e5c71e.d.mts +0 -112
  60. package/dist/shared/crossws.a2e5c71e.d.ts +0 -112
  61. package/dist/shared/crossws.c13afbe7.cjs +0 -146
  62. package/dist/websocket/index.cjs +0 -5
  63. package/dist/websocket/index.d.cts +0 -10
  64. package/dist/websocket/index.d.ts +0 -10
  65. package/dist/websocket/index.mjs +0 -3
  66. package/dist/websocket/node.cjs +0 -17
@@ -1,139 +0,0 @@
1
- function createCrossWS(opts = {}) {
2
- const resolveHook = async (req, name) => {
3
- const hooks = await opts.resolve?.(req);
4
- return hooks?.[name];
5
- };
6
- return {
7
- // WS Hooks
8
- async callHook(name, ...args) {
9
- await opts.hooks?.[name]?.apply(void 0, args);
10
- const hook = await resolveHook(args[0], name);
11
- await hook?.apply(void 0, args);
12
- },
13
- // Upgrade
14
- async upgrade(req) {
15
- const [res1, res2] = await Promise.all([
16
- opts.hooks?.upgrade?.(req),
17
- await resolveHook(req, "upgrade").then((h) => h?.(req))
18
- ]);
19
- const headers = new Headers(res1?.headers);
20
- if (res2?.headers) {
21
- for (const [key, value] of new Headers(res2?.headers)) {
22
- headers.append(key, value);
23
- }
24
- }
25
- return { headers };
26
- },
27
- // Adapter hook
28
- $callHook(name, ...args) {
29
- return opts.adapterHooks?.[name]?.apply(void 0, args);
30
- }
31
- };
32
- }
33
-
34
- function toBufferLike(val) {
35
- if (val === void 0 || val === null) {
36
- return "";
37
- }
38
- if (typeof val === "string") {
39
- return val;
40
- }
41
- if (isPlainObject(val)) {
42
- return JSON.stringify(val);
43
- }
44
- return val;
45
- }
46
- function isPlainObject(value) {
47
- if (value === null || typeof value !== "object") {
48
- return false;
49
- }
50
- const prototype = Object.getPrototypeOf(value);
51
- if (prototype !== null && prototype !== Object.prototype && Object.getPrototypeOf(prototype) !== null) {
52
- return false;
53
- }
54
- if (Symbol.iterator in value) {
55
- return false;
56
- }
57
- if (Symbol.toStringTag in value) {
58
- return Object.prototype.toString.call(value) === "[object Module]";
59
- }
60
- return true;
61
- }
62
-
63
- class Message {
64
- constructor(rawData, isBinary) {
65
- this.rawData = rawData;
66
- this.isBinary = isBinary;
67
- }
68
- text() {
69
- if (typeof this.rawData === "string") {
70
- return this.rawData;
71
- }
72
- const buff = toBufferLike(this.rawData);
73
- if (typeof buff === "string") {
74
- return buff;
75
- }
76
- return new TextDecoder().decode(buff);
77
- }
78
- toString() {
79
- return this.text();
80
- }
81
- [Symbol.for("nodejs.util.inspect.custom")]() {
82
- return this.text();
83
- }
84
- }
85
-
86
- var __defProp = Object.defineProperty;
87
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
88
- var __publicField = (obj, key, value) => {
89
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
90
- return value;
91
- };
92
- const ReadyStateMap = {
93
- "-1": "unknown",
94
- 0: "connecting",
95
- 1: "open",
96
- 2: "closing",
97
- 3: "closed"
98
- };
99
- class Peer {
100
- constructor(ctx) {
101
- this.ctx = ctx;
102
- __publicField(this, "_subscriptions", /* @__PURE__ */ new Set());
103
- }
104
- get id() {
105
- return "??";
106
- }
107
- get url() {
108
- return "/";
109
- }
110
- get headers() {
111
- return {};
112
- }
113
- get readyState() {
114
- return -1;
115
- }
116
- publish(topic, message, options) {
117
- }
118
- subscribe(topic) {
119
- this._subscriptions.add(topic);
120
- }
121
- unsubscribe(topic) {
122
- this._subscriptions.delete(topic);
123
- }
124
- toString() {
125
- return `${this.id || ""}${this.readyState === 1 || this.readyState === -1 ? "" : ` [${ReadyStateMap[this.readyState]}]`}`;
126
- }
127
- [Symbol.for("nodejs.util.inspect.custom")]() {
128
- return this.toString();
129
- }
130
- }
131
-
132
- function defineWebSocketAdapter(factory) {
133
- return factory;
134
- }
135
- function defineHooks(hooks) {
136
- return hooks;
137
- }
138
-
139
- export { Message as M, Peer as P, defineHooks as a, createCrossWS as c, defineWebSocketAdapter as d, toBufferLike as t };
@@ -1,112 +0,0 @@
1
- declare class WSError extends Error {
2
- constructor(...args: any[]);
3
- }
4
-
5
- declare class Message {
6
- readonly rawData: any;
7
- readonly isBinary?: boolean | undefined;
8
- constructor(rawData: any, isBinary?: boolean | undefined);
9
- text(): string;
10
- toString(): string;
11
- }
12
-
13
- type ReadyState = 0 | 1 | 2 | 3;
14
- declare abstract class Peer<AdapterContext = any> implements WSRequest {
15
- ctx: AdapterContext;
16
- _subscriptions: Set<string>;
17
- constructor(ctx: AdapterContext);
18
- get id(): string | undefined;
19
- get url(): string;
20
- get headers(): HeadersInit;
21
- get readyState(): ReadyState | -1;
22
- abstract send(message: any, options?: {
23
- compress?: boolean;
24
- }): number;
25
- publish(topic: string, message: any, options?: {
26
- compress?: boolean;
27
- }): void;
28
- subscribe(topic: string): void;
29
- unsubscribe(topic: string): void;
30
- toString(): string;
31
- }
32
-
33
- type MaybePromise<T> = T | Promise<T>;
34
- type Caller<T extends Record<string, (...args: any[]) => Promise<any>>, RT = null> = <K extends keyof T>(key: K, ...args: Parameters<T[K]>) => RT extends null ? Promise<ReturnType<T[K]>> : RT;
35
- interface AdapterOptions {
36
- resolve?: ResolveHooks;
37
- hooks?: Hooks;
38
- adapterHooks?: AdapterHooks;
39
- }
40
- type Adapter<AdapterT, Options extends AdapterOptions> = (options?: Options) => AdapterT;
41
- declare function defineWebSocketAdapter<AdapterT, Options extends AdapterOptions = AdapterOptions>(factory: Adapter<AdapterT, Options>): Adapter<AdapterT, Options>;
42
- interface CrossWS {
43
- $callHook: Caller<AdapterHooks>;
44
- callHook: Caller<Exclude<Hooks, "upgrade">, void>;
45
- upgrade: (req: WSRequest) => Promise<{
46
- headers?: HeadersInit;
47
- }>;
48
- }
49
- interface WSRequest {
50
- readonly url: string;
51
- readonly headers: HeadersInit;
52
- }
53
- declare function defineHooks<T extends Partial<Hooks> = Partial<Hooks>>(hooks: T): T;
54
- type ResolveHooks = (info: WSRequest | Peer) => Partial<Hooks> | Promise<Partial<Hooks>>;
55
- type HookFn<ArgsT extends any[] = any, RT = void> = (info: Peer, ...args: ArgsT) => MaybePromise<RT>;
56
- interface Hooks extends Record<string, HookFn<any[], any>> {
57
- /** Upgrading */
58
- upgrade: (req: WSRequest) => MaybePromise<void | {
59
- headers?: HeadersInit;
60
- }>;
61
- /** A message is received */
62
- message: (peer: Peer, message: Message) => MaybePromise<void>;
63
- /** A socket is opened */
64
- open: (peer: Peer) => MaybePromise<void>;
65
- /** A socket is closed */
66
- close: (peer: Peer, details: {
67
- code?: number;
68
- reason?: string;
69
- }) => MaybePromise<void>;
70
- /** An error occurs */
71
- error: (peer: Peer, error: WSError) => MaybePromise<void>;
72
- }
73
- interface AdapterHooks extends Record<string, HookFn<any[], any>> {
74
- "bun:message": HookFn<[ws: any, message: any]>;
75
- "bun:open": HookFn<[ws: any]>;
76
- "bun:close": HookFn<[ws: any]>;
77
- "bun:drain": HookFn<[]>;
78
- "bun:error": HookFn<[ws: any, error: any]>;
79
- "bun:ping": HookFn<[ws: any, data: any]>;
80
- "bun:pong": HookFn<[ws: any, data: any]>;
81
- "cloudflare:accept": HookFn<[]>;
82
- "cloudflare:message": HookFn<[event: any]>;
83
- "cloudflare:error": HookFn<[event: any]>;
84
- "cloudflare:close": HookFn<[event: any]>;
85
- "deno:open": HookFn<[]>;
86
- "deno:message": HookFn<[event: any]>;
87
- "deno:close": HookFn<[]>;
88
- "deno:error": HookFn<[error: any]>;
89
- "node:open": HookFn<[]>;
90
- "node:message": HookFn<[data: any, isBinary: boolean]>;
91
- "node:close": HookFn<[code: number, reason: Buffer]>;
92
- "node:error": HookFn<[error: any]>;
93
- "node:ping": HookFn<[data: Buffer]>;
94
- "node:pong": HookFn<[data: Buffer]>;
95
- "node:unexpected-response": HookFn<[req: any, res: any]>;
96
- "node:upgrade": HookFn<[req: any]>;
97
- "uws:open": HookFn<[ws: any]>;
98
- "uws:message": HookFn<[ws: any, message: any, isBinary: boolean]>;
99
- "uws:close": HookFn<[ws: any, code: number, message: any]>;
100
- "uws:ping": HookFn<[ws: any, message: any]>;
101
- "uws:pong": HookFn<[ws: any, message: any]>;
102
- "uws:drain": HookFn<[ws: any]>;
103
- "uws:upgrade": HookFn<[res: any, req: any, context: any]>;
104
- "uws:subscription": HookFn<[
105
- ws: any,
106
- topic: any,
107
- newCount: number,
108
- oldCount: number
109
- ]>;
110
- }
111
-
112
- export { type AdapterOptions as A, type CrossWS as C, type Hooks as H, Message as M, Peer as P, type ResolveHooks as R, WSError as W, type Caller as a, type Adapter as b, type WSRequest as c, defineWebSocketAdapter as d, defineHooks as e, type AdapterHooks as f };
@@ -1,112 +0,0 @@
1
- declare class WSError extends Error {
2
- constructor(...args: any[]);
3
- }
4
-
5
- declare class Message {
6
- readonly rawData: any;
7
- readonly isBinary?: boolean | undefined;
8
- constructor(rawData: any, isBinary?: boolean | undefined);
9
- text(): string;
10
- toString(): string;
11
- }
12
-
13
- type ReadyState = 0 | 1 | 2 | 3;
14
- declare abstract class Peer<AdapterContext = any> implements WSRequest {
15
- ctx: AdapterContext;
16
- _subscriptions: Set<string>;
17
- constructor(ctx: AdapterContext);
18
- get id(): string | undefined;
19
- get url(): string;
20
- get headers(): HeadersInit;
21
- get readyState(): ReadyState | -1;
22
- abstract send(message: any, options?: {
23
- compress?: boolean;
24
- }): number;
25
- publish(topic: string, message: any, options?: {
26
- compress?: boolean;
27
- }): void;
28
- subscribe(topic: string): void;
29
- unsubscribe(topic: string): void;
30
- toString(): string;
31
- }
32
-
33
- type MaybePromise<T> = T | Promise<T>;
34
- type Caller<T extends Record<string, (...args: any[]) => Promise<any>>, RT = null> = <K extends keyof T>(key: K, ...args: Parameters<T[K]>) => RT extends null ? Promise<ReturnType<T[K]>> : RT;
35
- interface AdapterOptions {
36
- resolve?: ResolveHooks;
37
- hooks?: Hooks;
38
- adapterHooks?: AdapterHooks;
39
- }
40
- type Adapter<AdapterT, Options extends AdapterOptions> = (options?: Options) => AdapterT;
41
- declare function defineWebSocketAdapter<AdapterT, Options extends AdapterOptions = AdapterOptions>(factory: Adapter<AdapterT, Options>): Adapter<AdapterT, Options>;
42
- interface CrossWS {
43
- $callHook: Caller<AdapterHooks>;
44
- callHook: Caller<Exclude<Hooks, "upgrade">, void>;
45
- upgrade: (req: WSRequest) => Promise<{
46
- headers?: HeadersInit;
47
- }>;
48
- }
49
- interface WSRequest {
50
- readonly url: string;
51
- readonly headers: HeadersInit;
52
- }
53
- declare function defineHooks<T extends Partial<Hooks> = Partial<Hooks>>(hooks: T): T;
54
- type ResolveHooks = (info: WSRequest | Peer) => Partial<Hooks> | Promise<Partial<Hooks>>;
55
- type HookFn<ArgsT extends any[] = any, RT = void> = (info: Peer, ...args: ArgsT) => MaybePromise<RT>;
56
- interface Hooks extends Record<string, HookFn<any[], any>> {
57
- /** Upgrading */
58
- upgrade: (req: WSRequest) => MaybePromise<void | {
59
- headers?: HeadersInit;
60
- }>;
61
- /** A message is received */
62
- message: (peer: Peer, message: Message) => MaybePromise<void>;
63
- /** A socket is opened */
64
- open: (peer: Peer) => MaybePromise<void>;
65
- /** A socket is closed */
66
- close: (peer: Peer, details: {
67
- code?: number;
68
- reason?: string;
69
- }) => MaybePromise<void>;
70
- /** An error occurs */
71
- error: (peer: Peer, error: WSError) => MaybePromise<void>;
72
- }
73
- interface AdapterHooks extends Record<string, HookFn<any[], any>> {
74
- "bun:message": HookFn<[ws: any, message: any]>;
75
- "bun:open": HookFn<[ws: any]>;
76
- "bun:close": HookFn<[ws: any]>;
77
- "bun:drain": HookFn<[]>;
78
- "bun:error": HookFn<[ws: any, error: any]>;
79
- "bun:ping": HookFn<[ws: any, data: any]>;
80
- "bun:pong": HookFn<[ws: any, data: any]>;
81
- "cloudflare:accept": HookFn<[]>;
82
- "cloudflare:message": HookFn<[event: any]>;
83
- "cloudflare:error": HookFn<[event: any]>;
84
- "cloudflare:close": HookFn<[event: any]>;
85
- "deno:open": HookFn<[]>;
86
- "deno:message": HookFn<[event: any]>;
87
- "deno:close": HookFn<[]>;
88
- "deno:error": HookFn<[error: any]>;
89
- "node:open": HookFn<[]>;
90
- "node:message": HookFn<[data: any, isBinary: boolean]>;
91
- "node:close": HookFn<[code: number, reason: Buffer]>;
92
- "node:error": HookFn<[error: any]>;
93
- "node:ping": HookFn<[data: Buffer]>;
94
- "node:pong": HookFn<[data: Buffer]>;
95
- "node:unexpected-response": HookFn<[req: any, res: any]>;
96
- "node:upgrade": HookFn<[req: any]>;
97
- "uws:open": HookFn<[ws: any]>;
98
- "uws:message": HookFn<[ws: any, message: any, isBinary: boolean]>;
99
- "uws:close": HookFn<[ws: any, code: number, message: any]>;
100
- "uws:ping": HookFn<[ws: any, message: any]>;
101
- "uws:pong": HookFn<[ws: any, message: any]>;
102
- "uws:drain": HookFn<[ws: any]>;
103
- "uws:upgrade": HookFn<[res: any, req: any, context: any]>;
104
- "uws:subscription": HookFn<[
105
- ws: any,
106
- topic: any,
107
- newCount: number,
108
- oldCount: number
109
- ]>;
110
- }
111
-
112
- export { type AdapterOptions as A, type CrossWS as C, type Hooks as H, Message as M, Peer as P, type ResolveHooks as R, WSError as W, type Caller as a, type Adapter as b, type WSRequest as c, defineWebSocketAdapter as d, defineHooks as e, type AdapterHooks as f };
@@ -1,112 +0,0 @@
1
- declare class WSError extends Error {
2
- constructor(...args: any[]);
3
- }
4
-
5
- declare class Message {
6
- readonly rawData: any;
7
- readonly isBinary?: boolean | undefined;
8
- constructor(rawData: any, isBinary?: boolean | undefined);
9
- text(): string;
10
- toString(): string;
11
- }
12
-
13
- type ReadyState = 0 | 1 | 2 | 3;
14
- declare abstract class Peer<AdapterContext = any> implements WSRequest {
15
- ctx: AdapterContext;
16
- _subscriptions: Set<string>;
17
- constructor(ctx: AdapterContext);
18
- get id(): string | undefined;
19
- get url(): string;
20
- get headers(): HeadersInit;
21
- get readyState(): ReadyState | -1;
22
- abstract send(message: any, options?: {
23
- compress?: boolean;
24
- }): number;
25
- publish(topic: string, message: any, options?: {
26
- compress?: boolean;
27
- }): void;
28
- subscribe(topic: string): void;
29
- unsubscribe(topic: string): void;
30
- toString(): string;
31
- }
32
-
33
- type MaybePromise<T> = T | Promise<T>;
34
- type Caller<T extends Record<string, (...args: any[]) => Promise<any>>, RT = null> = <K extends keyof T>(key: K, ...args: Parameters<T[K]>) => RT extends null ? Promise<ReturnType<T[K]>> : RT;
35
- interface AdapterOptions {
36
- resolve?: ResolveHooks;
37
- hooks?: Hooks;
38
- adapterHooks?: AdapterHooks;
39
- }
40
- type Adapter<AdapterT, Options extends AdapterOptions> = (options?: Options) => AdapterT;
41
- declare function defineWebSocketAdapter<AdapterT, Options extends AdapterOptions = AdapterOptions>(factory: Adapter<AdapterT, Options>): Adapter<AdapterT, Options>;
42
- interface CrossWS {
43
- $callHook: Caller<AdapterHooks>;
44
- callHook: Caller<Exclude<Hooks, "upgrade">, void>;
45
- upgrade: (req: WSRequest) => Promise<{
46
- headers?: HeadersInit;
47
- }>;
48
- }
49
- interface WSRequest {
50
- readonly url: string;
51
- readonly headers: HeadersInit;
52
- }
53
- declare function defineHooks<T extends Partial<Hooks> = Partial<Hooks>>(hooks: T): T;
54
- type ResolveHooks = (info: WSRequest | Peer) => Partial<Hooks> | Promise<Partial<Hooks>>;
55
- type HookFn<ArgsT extends any[] = any, RT = void> = (info: Peer, ...args: ArgsT) => MaybePromise<RT>;
56
- interface Hooks extends Record<string, HookFn<any[], any>> {
57
- /** Upgrading */
58
- upgrade: (req: WSRequest) => MaybePromise<void | {
59
- headers?: HeadersInit;
60
- }>;
61
- /** A message is received */
62
- message: (peer: Peer, message: Message) => MaybePromise<void>;
63
- /** A socket is opened */
64
- open: (peer: Peer) => MaybePromise<void>;
65
- /** A socket is closed */
66
- close: (peer: Peer, details: {
67
- code?: number;
68
- reason?: string;
69
- }) => MaybePromise<void>;
70
- /** An error occurs */
71
- error: (peer: Peer, error: WSError) => MaybePromise<void>;
72
- }
73
- interface AdapterHooks extends Record<string, HookFn<any[], any>> {
74
- "bun:message": HookFn<[ws: any, message: any]>;
75
- "bun:open": HookFn<[ws: any]>;
76
- "bun:close": HookFn<[ws: any]>;
77
- "bun:drain": HookFn<[]>;
78
- "bun:error": HookFn<[ws: any, error: any]>;
79
- "bun:ping": HookFn<[ws: any, data: any]>;
80
- "bun:pong": HookFn<[ws: any, data: any]>;
81
- "cloudflare:accept": HookFn<[]>;
82
- "cloudflare:message": HookFn<[event: any]>;
83
- "cloudflare:error": HookFn<[event: any]>;
84
- "cloudflare:close": HookFn<[event: any]>;
85
- "deno:open": HookFn<[]>;
86
- "deno:message": HookFn<[event: any]>;
87
- "deno:close": HookFn<[]>;
88
- "deno:error": HookFn<[error: any]>;
89
- "node:open": HookFn<[]>;
90
- "node:message": HookFn<[data: any, isBinary: boolean]>;
91
- "node:close": HookFn<[code: number, reason: Buffer]>;
92
- "node:error": HookFn<[error: any]>;
93
- "node:ping": HookFn<[data: Buffer]>;
94
- "node:pong": HookFn<[data: Buffer]>;
95
- "node:unexpected-response": HookFn<[req: any, res: any]>;
96
- "node:upgrade": HookFn<[req: any]>;
97
- "uws:open": HookFn<[ws: any]>;
98
- "uws:message": HookFn<[ws: any, message: any, isBinary: boolean]>;
99
- "uws:close": HookFn<[ws: any, code: number, message: any]>;
100
- "uws:ping": HookFn<[ws: any, message: any]>;
101
- "uws:pong": HookFn<[ws: any, message: any]>;
102
- "uws:drain": HookFn<[ws: any]>;
103
- "uws:upgrade": HookFn<[res: any, req: any, context: any]>;
104
- "uws:subscription": HookFn<[
105
- ws: any,
106
- topic: any,
107
- newCount: number,
108
- oldCount: number
109
- ]>;
110
- }
111
-
112
- export { type AdapterOptions as A, type CrossWS as C, type Hooks as H, Message as M, Peer as P, type ResolveHooks as R, WSError as W, type Caller as a, type Adapter as b, type WSRequest as c, defineWebSocketAdapter as d, defineHooks as e, type AdapterHooks as f };
@@ -1,146 +0,0 @@
1
- 'use strict';
2
-
3
- function createCrossWS(opts = {}) {
4
- const resolveHook = async (req, name) => {
5
- const hooks = await opts.resolve?.(req);
6
- return hooks?.[name];
7
- };
8
- return {
9
- // WS Hooks
10
- async callHook(name, ...args) {
11
- await opts.hooks?.[name]?.apply(void 0, args);
12
- const hook = await resolveHook(args[0], name);
13
- await hook?.apply(void 0, args);
14
- },
15
- // Upgrade
16
- async upgrade(req) {
17
- const [res1, res2] = await Promise.all([
18
- opts.hooks?.upgrade?.(req),
19
- await resolveHook(req, "upgrade").then((h) => h?.(req))
20
- ]);
21
- const headers = new Headers(res1?.headers);
22
- if (res2?.headers) {
23
- for (const [key, value] of new Headers(res2?.headers)) {
24
- headers.append(key, value);
25
- }
26
- }
27
- return { headers };
28
- },
29
- // Adapter hook
30
- $callHook(name, ...args) {
31
- return opts.adapterHooks?.[name]?.apply(void 0, args);
32
- }
33
- };
34
- }
35
-
36
- function toBufferLike(val) {
37
- if (val === void 0 || val === null) {
38
- return "";
39
- }
40
- if (typeof val === "string") {
41
- return val;
42
- }
43
- if (isPlainObject(val)) {
44
- return JSON.stringify(val);
45
- }
46
- return val;
47
- }
48
- function isPlainObject(value) {
49
- if (value === null || typeof value !== "object") {
50
- return false;
51
- }
52
- const prototype = Object.getPrototypeOf(value);
53
- if (prototype !== null && prototype !== Object.prototype && Object.getPrototypeOf(prototype) !== null) {
54
- return false;
55
- }
56
- if (Symbol.iterator in value) {
57
- return false;
58
- }
59
- if (Symbol.toStringTag in value) {
60
- return Object.prototype.toString.call(value) === "[object Module]";
61
- }
62
- return true;
63
- }
64
-
65
- class Message {
66
- constructor(rawData, isBinary) {
67
- this.rawData = rawData;
68
- this.isBinary = isBinary;
69
- }
70
- text() {
71
- if (typeof this.rawData === "string") {
72
- return this.rawData;
73
- }
74
- const buff = toBufferLike(this.rawData);
75
- if (typeof buff === "string") {
76
- return buff;
77
- }
78
- return new TextDecoder().decode(buff);
79
- }
80
- toString() {
81
- return this.text();
82
- }
83
- [Symbol.for("nodejs.util.inspect.custom")]() {
84
- return this.text();
85
- }
86
- }
87
-
88
- var __defProp = Object.defineProperty;
89
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
90
- var __publicField = (obj, key, value) => {
91
- __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
92
- return value;
93
- };
94
- const ReadyStateMap = {
95
- "-1": "unknown",
96
- 0: "connecting",
97
- 1: "open",
98
- 2: "closing",
99
- 3: "closed"
100
- };
101
- class Peer {
102
- constructor(ctx) {
103
- this.ctx = ctx;
104
- __publicField(this, "_subscriptions", /* @__PURE__ */ new Set());
105
- }
106
- get id() {
107
- return "??";
108
- }
109
- get url() {
110
- return "/";
111
- }
112
- get headers() {
113
- return {};
114
- }
115
- get readyState() {
116
- return -1;
117
- }
118
- publish(topic, message, options) {
119
- }
120
- subscribe(topic) {
121
- this._subscriptions.add(topic);
122
- }
123
- unsubscribe(topic) {
124
- this._subscriptions.delete(topic);
125
- }
126
- toString() {
127
- return `${this.id || ""}${this.readyState === 1 || this.readyState === -1 ? "" : ` [${ReadyStateMap[this.readyState]}]`}`;
128
- }
129
- [Symbol.for("nodejs.util.inspect.custom")]() {
130
- return this.toString();
131
- }
132
- }
133
-
134
- function defineWebSocketAdapter(factory) {
135
- return factory;
136
- }
137
- function defineHooks(hooks) {
138
- return hooks;
139
- }
140
-
141
- exports.Message = Message;
142
- exports.Peer = Peer;
143
- exports.createCrossWS = createCrossWS;
144
- exports.defineHooks = defineHooks;
145
- exports.defineWebSocketAdapter = defineWebSocketAdapter;
146
- exports.toBufferLike = toBufferLike;
@@ -1,5 +0,0 @@
1
- 'use strict';
2
-
3
- const index = globalThis.WebSocket;
4
-
5
- module.exports = index;
@@ -1,10 +0,0 @@
1
- declare const _default: {
2
- new (url: string | URL, protocols?: string | string[] | undefined): WebSocket;
3
- prototype: WebSocket;
4
- readonly CONNECTING: 0;
5
- readonly OPEN: 1;
6
- readonly CLOSING: 2;
7
- readonly CLOSED: 3;
8
- };
9
-
10
- export { _default as default };
@@ -1,10 +0,0 @@
1
- declare const _default: {
2
- new (url: string | URL, protocols?: string | string[] | undefined): WebSocket;
3
- prototype: WebSocket;
4
- readonly CONNECTING: 0;
5
- readonly OPEN: 1;
6
- readonly CLOSING: 2;
7
- readonly CLOSED: 3;
8
- };
9
-
10
- export { _default as default };
@@ -1,3 +0,0 @@
1
- const index = globalThis.WebSocket;
2
-
3
- export { index as default };
@@ -1,17 +0,0 @@
1
- 'use strict';
2
-
3
- require('stream');
4
- const websocket = require('../shared/crossws.2ed26345.cjs');
5
- require('events');
6
- require('http');
7
- require('crypto');
8
- require('https');
9
- require('net');
10
- require('tls');
11
- require('url');
12
- require('zlib');
13
- require('buffer');
14
-
15
- const node = globalThis.WebSocket || websocket._WebSocket;
16
-
17
- module.exports = node;