monorise 1.0.0 → 1.1.0-dev.1
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/base/index.d.ts +110 -3
- package/dist/base/index.js +3 -1
- package/dist/base/index.js.map +1 -1
- package/dist/cli/cli.js +6 -0
- package/dist/cli/cli.js.map +1 -1
- package/dist/core/chunk-QV4Q5377.js +76 -0
- package/dist/core/chunk-QV4Q5377.js.map +1 -0
- package/dist/core/index.d.ts +191 -38
- package/dist/core/index.js +1539 -122
- package/dist/core/index.js.map +1 -1
- package/dist/core/service.config-ZJEZ6EKA.js +13 -0
- package/dist/core/service.config-ZJEZ6EKA.js.map +1 -0
- package/dist/proxy/index.d.ts +35 -0
- package/dist/proxy/index.js +75 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/react/actions/websocket.action.d.ts +71 -0
- package/dist/react/actions/websocket.action.d.ts.map +1 -0
- package/dist/react/chunk-2QOYO3GF.js +182 -0
- package/dist/react/chunk-2QOYO3GF.js.map +1 -0
- package/dist/react/chunk-4WSYM746.js +383 -0
- package/dist/react/chunk-4WSYM746.js.map +1 -0
- package/dist/react/chunk-5XIRNUBL.js +43 -0
- package/dist/react/chunk-5XIRNUBL.js.map +1 -0
- package/dist/react/chunk-7JDOKZGQ.js +172 -0
- package/dist/react/chunk-7JDOKZGQ.js.map +1 -0
- package/dist/react/chunk-A5TI2FW3.js +13 -0
- package/dist/react/chunk-A5TI2FW3.js.map +1 -0
- package/dist/react/chunk-BJXCFDMF.js +15 -0
- package/dist/react/chunk-BJXCFDMF.js.map +1 -0
- package/dist/react/chunk-BUTF5RJU.js +29 -0
- package/dist/react/chunk-BUTF5RJU.js.map +1 -0
- package/dist/react/chunk-DTRWUIDH.js +402 -0
- package/dist/react/chunk-DTRWUIDH.js.map +1 -0
- package/dist/react/chunk-GFVCNWVT.js +54 -0
- package/dist/react/chunk-GFVCNWVT.js.map +1 -0
- package/dist/react/chunk-JT5EZZSL.js +489 -0
- package/dist/react/chunk-JT5EZZSL.js.map +1 -0
- package/dist/react/chunk-KJX5LOMN.js +43 -0
- package/dist/react/chunk-KJX5LOMN.js.map +1 -0
- package/dist/react/chunk-KLXK4V6G.js +65 -0
- package/dist/react/chunk-KLXK4V6G.js.map +1 -0
- package/dist/react/chunk-LJLMKEKI.js +245 -0
- package/dist/react/chunk-LJLMKEKI.js.map +1 -0
- package/dist/react/chunk-MIXAYX55.js +147 -0
- package/dist/react/chunk-MIXAYX55.js.map +1 -0
- package/dist/react/chunk-RPNCWADG.js +248 -0
- package/dist/react/chunk-RPNCWADG.js.map +1 -0
- package/dist/react/chunk-S6RDMHHH.js +47 -0
- package/dist/react/chunk-S6RDMHHH.js.map +1 -0
- package/dist/react/chunk-U6RIOMF4.js +893 -0
- package/dist/react/chunk-U6RIOMF4.js.map +1 -0
- package/dist/react/chunk-WCRLJFBW.js +5568 -0
- package/dist/react/chunk-WCRLJFBW.js.map +1 -0
- package/dist/react/chunk-YF6S7S36.js +588 -0
- package/dist/react/chunk-YF6S7S36.js.map +1 -0
- package/dist/react/dist-es-5WYA7CWK.js +379 -0
- package/dist/react/dist-es-5WYA7CWK.js.map +1 -0
- package/dist/react/dist-es-CR5AOOCO.js +333 -0
- package/dist/react/dist-es-CR5AOOCO.js.map +1 -0
- package/dist/react/dist-es-KZ3GLAJI.js +494 -0
- package/dist/react/dist-es-KZ3GLAJI.js.map +1 -0
- package/dist/react/dist-es-R4TRTT45.js +22 -0
- package/dist/react/dist-es-R4TRTT45.js.map +1 -0
- package/dist/react/dist-es-SKDPAJEW.js +169 -0
- package/dist/react/dist-es-SKDPAJEW.js.map +1 -0
- package/dist/react/dist-es-TOHBZNTZ.js +71 -0
- package/dist/react/dist-es-TOHBZNTZ.js.map +1 -0
- package/dist/react/dist-es-XNAC47MK.js +90 -0
- package/dist/react/dist-es-XNAC47MK.js.map +1 -0
- package/dist/react/event-streams-WAZW4P3K.js +277 -0
- package/dist/react/event-streams-WAZW4P3K.js.map +1 -0
- package/dist/react/index.d.ts +53 -4
- package/dist/react/index.d.ts.map +1 -1
- package/dist/react/index.js +10991 -190
- package/dist/react/index.js.map +1 -1
- package/dist/react/loadSso-KXVD6CBM.js +556 -0
- package/dist/react/loadSso-KXVD6CBM.js.map +1 -0
- package/dist/react/service.config-I7RKP6FE.js +14 -0
- package/dist/react/service.config-I7RKP6FE.js.map +1 -0
- package/dist/react/services/core.service.d.ts +11 -1
- package/dist/react/services/core.service.d.ts.map +1 -1
- package/dist/react/signin-SEY3FDQ5.js +653 -0
- package/dist/react/signin-SEY3FDQ5.js.map +1 -0
- package/dist/react/sso-oidc-REODVHH5.js +786 -0
- package/dist/react/sso-oidc-REODVHH5.js.map +1 -0
- package/dist/react/sts-I3M4QP37.js +3948 -0
- package/dist/react/sts-I3M4QP37.js.map +1 -0
- package/dist/react/websocket/WebSocketManager.d.ts +68 -0
- package/dist/react/websocket/WebSocketManager.d.ts.map +1 -0
- package/dist/react/websocket/index.d.ts +3 -0
- package/dist/react/websocket/index.d.ts.map +1 -0
- package/dist/react/websocket/optimistic.d.ts +51 -0
- package/dist/react/websocket/optimistic.d.ts.map +1 -0
- package/dist/react/websocket-OSLLJSNO.js +10 -0
- package/dist/react/websocket-OSLLJSNO.js.map +1 -0
- package/dist/sst/components/monorise-core.d.ts +10 -0
- package/dist/sst/components/monorise-core.d.ts.map +1 -1
- package/dist/sst/index.js +75 -12
- package/dist/sst/index.js.map +1 -1
- package/package.json +9 -1
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CORE_EVENT_BUS,
|
|
3
|
+
CORE_TABLE,
|
|
4
|
+
ENTITY_REPLICATION_INDEX,
|
|
5
|
+
MUTUAL_REPLICATION_INDEX
|
|
6
|
+
} from "./chunk-QV4Q5377.js";
|
|
7
|
+
export {
|
|
8
|
+
CORE_EVENT_BUS,
|
|
9
|
+
CORE_TABLE,
|
|
10
|
+
ENTITY_REPLICATION_INDEX,
|
|
11
|
+
MUTUAL_REPLICATION_INDEX
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=service.config-ZJEZ6EKA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Entity } from '../base/index';
|
|
2
|
+
|
|
3
|
+
interface GenerateTicketOptions {
|
|
4
|
+
entityType: Entity;
|
|
5
|
+
entityId: string;
|
|
6
|
+
feedTypes?: Entity[];
|
|
7
|
+
}
|
|
8
|
+
interface TicketResponse {
|
|
9
|
+
ticket: string;
|
|
10
|
+
wsUrl: string;
|
|
11
|
+
expiresIn: number;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Generate a WebSocket ticket for entity feed subscriptions.
|
|
15
|
+
* Call this from your proxy route (e.g., Next.js API route) after validating auth.
|
|
16
|
+
*
|
|
17
|
+
* @example
|
|
18
|
+
* ```ts
|
|
19
|
+
* import { generateWebSocketTicket } from 'monorise/proxy';
|
|
20
|
+
* import { Entity } from './monorise/entities';
|
|
21
|
+
*
|
|
22
|
+
* export async function POST(req) {
|
|
23
|
+
* const session = await getSession(req);
|
|
24
|
+
* const ticket = await generateWebSocketTicket({
|
|
25
|
+
* entityType: Entity.USER,
|
|
26
|
+
* entityId: session.userId,
|
|
27
|
+
* feedTypes: [Entity.CHANNEL, Entity.MESSAGE],
|
|
28
|
+
* });
|
|
29
|
+
* return Response.json(ticket);
|
|
30
|
+
* }
|
|
31
|
+
* ```
|
|
32
|
+
*/
|
|
33
|
+
declare const generateWebSocketTicket: (options: GenerateTicketOptions) => Promise<TicketResponse>;
|
|
34
|
+
|
|
35
|
+
export { generateWebSocketTicket };
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __getOwnPropSymbols = Object.getOwnPropertySymbols;
|
|
3
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
4
|
+
var __propIsEnum = Object.prototype.propertyIsEnumerable;
|
|
5
|
+
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
6
|
+
var __spreadValues = (a, b) => {
|
|
7
|
+
for (var prop in b || (b = {}))
|
|
8
|
+
if (__hasOwnProp.call(b, prop))
|
|
9
|
+
__defNormalProp(a, prop, b[prop]);
|
|
10
|
+
if (__getOwnPropSymbols)
|
|
11
|
+
for (var prop of __getOwnPropSymbols(b)) {
|
|
12
|
+
if (__propIsEnum.call(b, prop))
|
|
13
|
+
__defNormalProp(a, prop, b[prop]);
|
|
14
|
+
}
|
|
15
|
+
return a;
|
|
16
|
+
};
|
|
17
|
+
var __async = (__this, __arguments, generator) => {
|
|
18
|
+
return new Promise((resolve, reject) => {
|
|
19
|
+
var fulfilled = (value) => {
|
|
20
|
+
try {
|
|
21
|
+
step(generator.next(value));
|
|
22
|
+
} catch (e) {
|
|
23
|
+
reject(e);
|
|
24
|
+
}
|
|
25
|
+
};
|
|
26
|
+
var rejected = (value) => {
|
|
27
|
+
try {
|
|
28
|
+
step(generator.throw(value));
|
|
29
|
+
} catch (e) {
|
|
30
|
+
reject(e);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
34
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
35
|
+
});
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// index.ts
|
|
39
|
+
var getApiBaseUrl = () => {
|
|
40
|
+
const url = process.env.API_BASE_URL;
|
|
41
|
+
if (!url) {
|
|
42
|
+
throw new Error(
|
|
43
|
+
"API_BASE_URL environment variable is required for generateWebSocketTicket"
|
|
44
|
+
);
|
|
45
|
+
}
|
|
46
|
+
return url;
|
|
47
|
+
};
|
|
48
|
+
var getApiKey = () => {
|
|
49
|
+
return process.env.MONORISE_API_KEY || process.env.API_KEY || "";
|
|
50
|
+
};
|
|
51
|
+
var generateWebSocketTicket = (options) => __async(null, null, function* () {
|
|
52
|
+
const apiBaseUrl = getApiBaseUrl();
|
|
53
|
+
const apiKey = getApiKey();
|
|
54
|
+
const { entityType, entityId, feedTypes } = options;
|
|
55
|
+
const response = yield fetch(
|
|
56
|
+
`${apiBaseUrl}/ws/ticket/${entityType}/${entityId}`,
|
|
57
|
+
{
|
|
58
|
+
method: "POST",
|
|
59
|
+
headers: __spreadValues({
|
|
60
|
+
"Content-Type": "application/json"
|
|
61
|
+
}, apiKey && { "x-api-key": apiKey }),
|
|
62
|
+
body: JSON.stringify(__spreadValues({}, feedTypes && { feedTypes }))
|
|
63
|
+
}
|
|
64
|
+
);
|
|
65
|
+
if (!response.ok) {
|
|
66
|
+
throw new Error(
|
|
67
|
+
`Failed to generate WebSocket ticket: ${response.status} ${response.statusText}`
|
|
68
|
+
);
|
|
69
|
+
}
|
|
70
|
+
return response.json();
|
|
71
|
+
});
|
|
72
|
+
export {
|
|
73
|
+
generateWebSocketTicket
|
|
74
|
+
};
|
|
75
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../index.ts"],"sourcesContent":["import type { Entity } from '@monorise/base';\n\ninterface GenerateTicketOptions {\n entityType: Entity;\n entityId: string;\n feedTypes?: Entity[];\n}\n\ninterface TicketResponse {\n ticket: string;\n wsUrl: string;\n expiresIn: number;\n}\n\nconst getApiBaseUrl = (): string => {\n const url = process.env.API_BASE_URL;\n if (!url) {\n throw new Error(\n 'API_BASE_URL environment variable is required for generateWebSocketTicket',\n );\n }\n return url;\n};\n\nconst getApiKey = (): string => {\n return process.env.MONORISE_API_KEY || process.env.API_KEY || '';\n};\n\n/**\n * Generate a WebSocket ticket for entity feed subscriptions.\n * Call this from your proxy route (e.g., Next.js API route) after validating auth.\n *\n * @example\n * ```ts\n * import { generateWebSocketTicket } from 'monorise/proxy';\n * import { Entity } from './monorise/entities';\n *\n * export async function POST(req) {\n * const session = await getSession(req);\n * const ticket = await generateWebSocketTicket({\n * entityType: Entity.USER,\n * entityId: session.userId,\n * feedTypes: [Entity.CHANNEL, Entity.MESSAGE],\n * });\n * return Response.json(ticket);\n * }\n * ```\n */\nexport const generateWebSocketTicket = async (\n options: GenerateTicketOptions,\n): Promise<TicketResponse> => {\n const apiBaseUrl = getApiBaseUrl();\n const apiKey = getApiKey();\n\n const { entityType, entityId, feedTypes } = options;\n\n const response = await fetch(\n `${apiBaseUrl}/ws/ticket/${entityType}/${entityId}`,\n {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n ...(apiKey && { 'x-api-key': apiKey }),\n },\n body: JSON.stringify({\n ...(feedTypes && { feedTypes }),\n }),\n },\n );\n\n if (!response.ok) {\n throw new Error(\n `Failed to generate WebSocket ticket: ${response.status} ${response.statusText}`,\n );\n }\n\n return response.json() as Promise<TicketResponse>;\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAcA,IAAM,gBAAgB,MAAc;AAClC,QAAM,MAAM,QAAQ,IAAI;AACxB,MAAI,CAAC,KAAK;AACR,UAAM,IAAI;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEA,IAAM,YAAY,MAAc;AAC9B,SAAO,QAAQ,IAAI,oBAAoB,QAAQ,IAAI,WAAW;AAChE;AAsBO,IAAM,0BAA0B,CACrC,YAC4B;AAC5B,QAAM,aAAa,cAAc;AACjC,QAAM,SAAS,UAAU;AAEzB,QAAM,EAAE,YAAY,UAAU,UAAU,IAAI;AAE5C,QAAM,WAAW,MAAM;AAAA,IACrB,GAAG,UAAU,cAAc,UAAU,IAAI,QAAQ;AAAA,IACjD;AAAA,MACE,QAAQ;AAAA,MACR,SAAS;AAAA,QACP,gBAAgB;AAAA,SACZ,UAAU,EAAE,aAAa,OAAO;AAAA,MAEtC,MAAM,KAAK,UAAU,mBACf,aAAa,EAAE,UAAU,EAC9B;AAAA,IACH;AAAA,EACF;AAEA,MAAI,CAAC,SAAS,IAAI;AAChB,UAAM,IAAI;AAAA,MACR,wCAAwC,SAAS,MAAM,IAAI,SAAS,UAAU;AAAA,IAChF;AAAA,EACF;AAEA,SAAO,SAAS,KAAK;AACvB;","names":[]}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import type { CreatedEntity, Entity } from '../../base/index';
|
|
2
|
+
import type { MonoriseStore } from '../store/monorise.store';
|
|
3
|
+
import type { WebSocketManager } from '../websocket';
|
|
4
|
+
export interface UseEntitySocketReturn<T extends Entity> {
|
|
5
|
+
entities: CreatedEntity<T>[];
|
|
6
|
+
isLoading: boolean;
|
|
7
|
+
isFetchingMore: boolean;
|
|
8
|
+
isSubscribed: boolean;
|
|
9
|
+
error: Error | null;
|
|
10
|
+
isRefreshing: boolean;
|
|
11
|
+
fetchMore: () => Promise<void>;
|
|
12
|
+
hasMore: boolean;
|
|
13
|
+
}
|
|
14
|
+
export interface UseMutualSocketReturn<T extends Entity> {
|
|
15
|
+
mutuals: unknown[];
|
|
16
|
+
isLoading: boolean;
|
|
17
|
+
isFetchingMore: boolean;
|
|
18
|
+
isSubscribed: boolean;
|
|
19
|
+
error: Error | null;
|
|
20
|
+
isRefreshing: boolean;
|
|
21
|
+
fetchMore: () => Promise<void>;
|
|
22
|
+
hasMore: boolean;
|
|
23
|
+
}
|
|
24
|
+
export interface UseEntityFeedOptions {
|
|
25
|
+
entityType: Entity;
|
|
26
|
+
entityId: string;
|
|
27
|
+
ticketEndpoint?: string;
|
|
28
|
+
}
|
|
29
|
+
export interface UseEntityFeedReturn {
|
|
30
|
+
isConnected: boolean;
|
|
31
|
+
error: {
|
|
32
|
+
code: string;
|
|
33
|
+
message: string;
|
|
34
|
+
} | null;
|
|
35
|
+
}
|
|
36
|
+
export declare const initializeWebSocketManager: (WebSocketManagerClass: typeof WebSocketManager, endpoint: string, token?: string) => WebSocketManager;
|
|
37
|
+
export declare const getWebSocketManager: () => WebSocketManager | null;
|
|
38
|
+
export declare const initWebSocketActions: (monoriseStore: MonoriseStore, httpActions?: {
|
|
39
|
+
listEntities: <T extends Entity>(entityType: T, params?: {
|
|
40
|
+
limit?: number;
|
|
41
|
+
lastKey?: string;
|
|
42
|
+
}) => Promise<{
|
|
43
|
+
data: CreatedEntity<T>[];
|
|
44
|
+
lastKey?: string;
|
|
45
|
+
}>;
|
|
46
|
+
listEntitiesByEntity: <B extends Entity, T extends Entity>(byEntityType: B, byEntityId: string, entityType: T, params?: {
|
|
47
|
+
limit?: number;
|
|
48
|
+
lastKey?: string;
|
|
49
|
+
}) => Promise<{
|
|
50
|
+
entities: unknown[];
|
|
51
|
+
lastKey?: string;
|
|
52
|
+
}>;
|
|
53
|
+
}) => {
|
|
54
|
+
useEntitySocket: <T extends Entity>(entityType: T, opts?: {
|
|
55
|
+
limit?: number;
|
|
56
|
+
skipInitialFetch?: boolean;
|
|
57
|
+
}) => UseEntitySocketReturn<T>;
|
|
58
|
+
useMutualSocket: <B extends Entity, T extends Entity>(byEntityType: B, byEntityId: string | undefined, mutualEntityType: T, opts?: {
|
|
59
|
+
limit?: number;
|
|
60
|
+
skipInitialFetch?: boolean;
|
|
61
|
+
}) => UseMutualSocketReturn<T>;
|
|
62
|
+
useEphemeralSocket: <T = unknown>(channel: string | undefined, opts?: {
|
|
63
|
+
onMessage?: (data: T, senderId?: string) => void;
|
|
64
|
+
}) => {
|
|
65
|
+
isSubscribed: boolean;
|
|
66
|
+
send: (data: T) => void;
|
|
67
|
+
};
|
|
68
|
+
useEntityFeed: (opts: UseEntityFeedOptions) => UseEntityFeedReturn;
|
|
69
|
+
};
|
|
70
|
+
export type WebSocketActions = ReturnType<typeof initWebSocketActions>;
|
|
71
|
+
//# sourceMappingURL=websocket.action.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"websocket.action.d.ts","sourceRoot":"","sources":["../../actions/websocket.action.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
import {
|
|
2
|
+
fromBase64,
|
|
3
|
+
streamCollector,
|
|
4
|
+
toBase64,
|
|
5
|
+
toHex
|
|
6
|
+
} from "./chunk-U6RIOMF4.js";
|
|
7
|
+
import {
|
|
8
|
+
fromArrayBuffer,
|
|
9
|
+
toUtf8
|
|
10
|
+
} from "./chunk-KJX5LOMN.js";
|
|
11
|
+
|
|
12
|
+
// ../../node_modules/@smithy/util-stream/dist-es/sdk-stream-mixin.js
|
|
13
|
+
import { Readable } from "stream";
|
|
14
|
+
|
|
15
|
+
// ../../node_modules/@smithy/fetch-http-handler/dist-es/stream-collector.js
|
|
16
|
+
var streamCollector2 = async (stream) => {
|
|
17
|
+
var _a;
|
|
18
|
+
if (typeof Blob === "function" && stream instanceof Blob || ((_a = stream.constructor) == null ? void 0 : _a.name) === "Blob") {
|
|
19
|
+
if (Blob.prototype.arrayBuffer !== void 0) {
|
|
20
|
+
return new Uint8Array(await stream.arrayBuffer());
|
|
21
|
+
}
|
|
22
|
+
return collectBlob(stream);
|
|
23
|
+
}
|
|
24
|
+
return collectStream(stream);
|
|
25
|
+
};
|
|
26
|
+
async function collectBlob(blob) {
|
|
27
|
+
const base64 = await readToBase64(blob);
|
|
28
|
+
const arrayBuffer = fromBase64(base64);
|
|
29
|
+
return new Uint8Array(arrayBuffer);
|
|
30
|
+
}
|
|
31
|
+
async function collectStream(stream) {
|
|
32
|
+
const chunks = [];
|
|
33
|
+
const reader = stream.getReader();
|
|
34
|
+
let isDone = false;
|
|
35
|
+
let length = 0;
|
|
36
|
+
while (!isDone) {
|
|
37
|
+
const { done, value } = await reader.read();
|
|
38
|
+
if (value) {
|
|
39
|
+
chunks.push(value);
|
|
40
|
+
length += value.length;
|
|
41
|
+
}
|
|
42
|
+
isDone = done;
|
|
43
|
+
}
|
|
44
|
+
const collected = new Uint8Array(length);
|
|
45
|
+
let offset = 0;
|
|
46
|
+
for (const chunk of chunks) {
|
|
47
|
+
collected.set(chunk, offset);
|
|
48
|
+
offset += chunk.length;
|
|
49
|
+
}
|
|
50
|
+
return collected;
|
|
51
|
+
}
|
|
52
|
+
function readToBase64(blob) {
|
|
53
|
+
return new Promise((resolve, reject) => {
|
|
54
|
+
const reader = new FileReader();
|
|
55
|
+
reader.onloadend = () => {
|
|
56
|
+
var _a;
|
|
57
|
+
if (reader.readyState !== 2) {
|
|
58
|
+
return reject(new Error("Reader aborted too early"));
|
|
59
|
+
}
|
|
60
|
+
const result = (_a = reader.result) != null ? _a : "";
|
|
61
|
+
const commaIndex = result.indexOf(",");
|
|
62
|
+
const dataOffset = commaIndex > -1 ? commaIndex + 1 : result.length;
|
|
63
|
+
resolve(result.substring(dataOffset));
|
|
64
|
+
};
|
|
65
|
+
reader.onabort = () => reject(new Error("Read aborted"));
|
|
66
|
+
reader.onerror = () => reject(reader.error);
|
|
67
|
+
reader.readAsDataURL(blob);
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// ../../node_modules/@smithy/util-stream/dist-es/stream-type-check.js
|
|
72
|
+
var isReadableStream = (stream) => {
|
|
73
|
+
var _a;
|
|
74
|
+
return typeof ReadableStream === "function" && (((_a = stream == null ? void 0 : stream.constructor) == null ? void 0 : _a.name) === ReadableStream.name || stream instanceof ReadableStream);
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
// ../../node_modules/@smithy/util-stream/dist-es/sdk-stream-mixin.browser.js
|
|
78
|
+
var ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED = "The stream has already been transformed.";
|
|
79
|
+
var sdkStreamMixin = (stream) => {
|
|
80
|
+
var _a, _b;
|
|
81
|
+
if (!isBlobInstance(stream) && !isReadableStream(stream)) {
|
|
82
|
+
const name = ((_b = (_a = stream == null ? void 0 : stream.__proto__) == null ? void 0 : _a.constructor) == null ? void 0 : _b.name) || stream;
|
|
83
|
+
throw new Error(`Unexpected stream implementation, expect Blob or ReadableStream, got ${name}`);
|
|
84
|
+
}
|
|
85
|
+
let transformed = false;
|
|
86
|
+
const transformToByteArray = async () => {
|
|
87
|
+
if (transformed) {
|
|
88
|
+
throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);
|
|
89
|
+
}
|
|
90
|
+
transformed = true;
|
|
91
|
+
return await streamCollector2(stream);
|
|
92
|
+
};
|
|
93
|
+
const blobToWebStream = (blob) => {
|
|
94
|
+
if (typeof blob.stream !== "function") {
|
|
95
|
+
throw new Error("Cannot transform payload Blob to web stream. Please make sure the Blob.stream() is polyfilled.\nIf you are using React Native, this API is not yet supported, see: https://react-native.canny.io/feature-requests/p/fetch-streaming-body");
|
|
96
|
+
}
|
|
97
|
+
return blob.stream();
|
|
98
|
+
};
|
|
99
|
+
return Object.assign(stream, {
|
|
100
|
+
transformToByteArray,
|
|
101
|
+
transformToString: async (encoding) => {
|
|
102
|
+
const buf = await transformToByteArray();
|
|
103
|
+
if (encoding === "base64") {
|
|
104
|
+
return toBase64(buf);
|
|
105
|
+
} else if (encoding === "hex") {
|
|
106
|
+
return toHex(buf);
|
|
107
|
+
} else if (encoding === void 0 || encoding === "utf8" || encoding === "utf-8") {
|
|
108
|
+
return toUtf8(buf);
|
|
109
|
+
} else if (typeof TextDecoder === "function") {
|
|
110
|
+
return new TextDecoder(encoding).decode(buf);
|
|
111
|
+
} else {
|
|
112
|
+
throw new Error("TextDecoder is not available, please make sure polyfill is provided.");
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
transformToWebStream: () => {
|
|
116
|
+
if (transformed) {
|
|
117
|
+
throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);
|
|
118
|
+
}
|
|
119
|
+
transformed = true;
|
|
120
|
+
if (isBlobInstance(stream)) {
|
|
121
|
+
return blobToWebStream(stream);
|
|
122
|
+
} else if (isReadableStream(stream)) {
|
|
123
|
+
return stream;
|
|
124
|
+
} else {
|
|
125
|
+
throw new Error(`Cannot transform payload to web stream, got ${stream}`);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
});
|
|
129
|
+
};
|
|
130
|
+
var isBlobInstance = (stream) => typeof Blob === "function" && stream instanceof Blob;
|
|
131
|
+
|
|
132
|
+
// ../../node_modules/@smithy/util-stream/dist-es/sdk-stream-mixin.js
|
|
133
|
+
var ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED2 = "The stream has already been transformed.";
|
|
134
|
+
var sdkStreamMixin2 = (stream) => {
|
|
135
|
+
var _a, _b;
|
|
136
|
+
if (!(stream instanceof Readable)) {
|
|
137
|
+
try {
|
|
138
|
+
return sdkStreamMixin(stream);
|
|
139
|
+
} catch (e) {
|
|
140
|
+
const name = ((_b = (_a = stream == null ? void 0 : stream.__proto__) == null ? void 0 : _a.constructor) == null ? void 0 : _b.name) || stream;
|
|
141
|
+
throw new Error(`Unexpected stream implementation, expect Stream.Readable instance, got ${name}`);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
let transformed = false;
|
|
145
|
+
const transformToByteArray = async () => {
|
|
146
|
+
if (transformed) {
|
|
147
|
+
throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED2);
|
|
148
|
+
}
|
|
149
|
+
transformed = true;
|
|
150
|
+
return await streamCollector(stream);
|
|
151
|
+
};
|
|
152
|
+
return Object.assign(stream, {
|
|
153
|
+
transformToByteArray,
|
|
154
|
+
transformToString: async (encoding) => {
|
|
155
|
+
const buf = await transformToByteArray();
|
|
156
|
+
if (encoding === void 0 || Buffer.isEncoding(encoding)) {
|
|
157
|
+
return fromArrayBuffer(buf.buffer, buf.byteOffset, buf.byteLength).toString(encoding);
|
|
158
|
+
} else {
|
|
159
|
+
const decoder = new TextDecoder(encoding);
|
|
160
|
+
return decoder.decode(buf);
|
|
161
|
+
}
|
|
162
|
+
},
|
|
163
|
+
transformToWebStream: () => {
|
|
164
|
+
if (transformed) {
|
|
165
|
+
throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED2);
|
|
166
|
+
}
|
|
167
|
+
if (stream.readableFlowing !== null) {
|
|
168
|
+
throw new Error("The stream has been consumed by other callbacks.");
|
|
169
|
+
}
|
|
170
|
+
if (typeof Readable.toWeb !== "function") {
|
|
171
|
+
throw new Error("Readable.toWeb() is not supported. Please ensure a polyfill is available.");
|
|
172
|
+
}
|
|
173
|
+
transformed = true;
|
|
174
|
+
return Readable.toWeb(stream);
|
|
175
|
+
}
|
|
176
|
+
});
|
|
177
|
+
};
|
|
178
|
+
|
|
179
|
+
export {
|
|
180
|
+
sdkStreamMixin2 as sdkStreamMixin
|
|
181
|
+
};
|
|
182
|
+
//# sourceMappingURL=chunk-2QOYO3GF.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../node_modules/@smithy/util-stream/dist-es/sdk-stream-mixin.js","../../../node_modules/@smithy/fetch-http-handler/dist-es/stream-collector.js","../../../node_modules/@smithy/util-stream/dist-es/stream-type-check.js","../../../node_modules/@smithy/util-stream/dist-es/sdk-stream-mixin.browser.js"],"sourcesContent":["import { streamCollector } from \"@smithy/node-http-handler\";\nimport { fromArrayBuffer } from \"@smithy/util-buffer-from\";\nimport { Readable } from \"stream\";\nimport { sdkStreamMixin as sdkStreamMixinReadableStream } from \"./sdk-stream-mixin.browser\";\nconst ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED = \"The stream has already been transformed.\";\nexport const sdkStreamMixin = (stream) => {\n if (!(stream instanceof Readable)) {\n try {\n return sdkStreamMixinReadableStream(stream);\n }\n catch (e) {\n const name = stream?.__proto__?.constructor?.name || stream;\n throw new Error(`Unexpected stream implementation, expect Stream.Readable instance, got ${name}`);\n }\n }\n let transformed = false;\n const transformToByteArray = async () => {\n if (transformed) {\n throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);\n }\n transformed = true;\n return await streamCollector(stream);\n };\n return Object.assign(stream, {\n transformToByteArray,\n transformToString: async (encoding) => {\n const buf = await transformToByteArray();\n if (encoding === undefined || Buffer.isEncoding(encoding)) {\n return fromArrayBuffer(buf.buffer, buf.byteOffset, buf.byteLength).toString(encoding);\n }\n else {\n const decoder = new TextDecoder(encoding);\n return decoder.decode(buf);\n }\n },\n transformToWebStream: () => {\n if (transformed) {\n throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);\n }\n if (stream.readableFlowing !== null) {\n throw new Error(\"The stream has been consumed by other callbacks.\");\n }\n if (typeof Readable.toWeb !== \"function\") {\n throw new Error(\"Readable.toWeb() is not supported. Please ensure a polyfill is available.\");\n }\n transformed = true;\n return Readable.toWeb(stream);\n },\n });\n};\n","import { fromBase64 } from \"@smithy/util-base64\";\nexport const streamCollector = async (stream) => {\n if ((typeof Blob === \"function\" && stream instanceof Blob) || stream.constructor?.name === \"Blob\") {\n if (Blob.prototype.arrayBuffer !== undefined) {\n return new Uint8Array(await stream.arrayBuffer());\n }\n return collectBlob(stream);\n }\n return collectStream(stream);\n};\nasync function collectBlob(blob) {\n const base64 = await readToBase64(blob);\n const arrayBuffer = fromBase64(base64);\n return new Uint8Array(arrayBuffer);\n}\nasync function collectStream(stream) {\n const chunks = [];\n const reader = stream.getReader();\n let isDone = false;\n let length = 0;\n while (!isDone) {\n const { done, value } = await reader.read();\n if (value) {\n chunks.push(value);\n length += value.length;\n }\n isDone = done;\n }\n const collected = new Uint8Array(length);\n let offset = 0;\n for (const chunk of chunks) {\n collected.set(chunk, offset);\n offset += chunk.length;\n }\n return collected;\n}\nfunction readToBase64(blob) {\n return new Promise((resolve, reject) => {\n const reader = new FileReader();\n reader.onloadend = () => {\n if (reader.readyState !== 2) {\n return reject(new Error(\"Reader aborted too early\"));\n }\n const result = (reader.result ?? \"\");\n const commaIndex = result.indexOf(\",\");\n const dataOffset = commaIndex > -1 ? commaIndex + 1 : result.length;\n resolve(result.substring(dataOffset));\n };\n reader.onabort = () => reject(new Error(\"Read aborted\"));\n reader.onerror = () => reject(reader.error);\n reader.readAsDataURL(blob);\n });\n}\n","export const isReadableStream = (stream) => typeof ReadableStream === \"function\" &&\n (stream?.constructor?.name === ReadableStream.name || stream instanceof ReadableStream);\nexport const isBlob = (blob) => {\n return typeof Blob === \"function\" && (blob?.constructor?.name === Blob.name || blob instanceof Blob);\n};\n","import { streamCollector } from \"@smithy/fetch-http-handler\";\nimport { toBase64 } from \"@smithy/util-base64\";\nimport { toHex } from \"@smithy/util-hex-encoding\";\nimport { toUtf8 } from \"@smithy/util-utf8\";\nimport { isReadableStream } from \"./stream-type-check\";\nconst ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED = \"The stream has already been transformed.\";\nexport const sdkStreamMixin = (stream) => {\n if (!isBlobInstance(stream) && !isReadableStream(stream)) {\n const name = stream?.__proto__?.constructor?.name || stream;\n throw new Error(`Unexpected stream implementation, expect Blob or ReadableStream, got ${name}`);\n }\n let transformed = false;\n const transformToByteArray = async () => {\n if (transformed) {\n throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);\n }\n transformed = true;\n return await streamCollector(stream);\n };\n const blobToWebStream = (blob) => {\n if (typeof blob.stream !== \"function\") {\n throw new Error(\"Cannot transform payload Blob to web stream. Please make sure the Blob.stream() is polyfilled.\\n\" +\n \"If you are using React Native, this API is not yet supported, see: https://react-native.canny.io/feature-requests/p/fetch-streaming-body\");\n }\n return blob.stream();\n };\n return Object.assign(stream, {\n transformToByteArray: transformToByteArray,\n transformToString: async (encoding) => {\n const buf = await transformToByteArray();\n if (encoding === \"base64\") {\n return toBase64(buf);\n }\n else if (encoding === \"hex\") {\n return toHex(buf);\n }\n else if (encoding === undefined || encoding === \"utf8\" || encoding === \"utf-8\") {\n return toUtf8(buf);\n }\n else if (typeof TextDecoder === \"function\") {\n return new TextDecoder(encoding).decode(buf);\n }\n else {\n throw new Error(\"TextDecoder is not available, please make sure polyfill is provided.\");\n }\n },\n transformToWebStream: () => {\n if (transformed) {\n throw new Error(ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED);\n }\n transformed = true;\n if (isBlobInstance(stream)) {\n return blobToWebStream(stream);\n }\n else if (isReadableStream(stream)) {\n return stream;\n }\n else {\n throw new Error(`Cannot transform payload to web stream, got ${stream}`);\n }\n },\n });\n};\nconst isBlobInstance = (stream) => typeof Blob === \"function\" && stream instanceof Blob;\n"],"mappings":"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","names":["streamCollector","streamCollector","ERR_MSG_STREAM_HAS_BEEN_TRANSFORMED","sdkStreamMixin"]}
|