filepizza-client 2.0.1 → 2.1.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.
- package/README.md +50 -4
- package/dist/filepizza-downloader.d.ts +18 -100
- package/dist/filepizza-downloader.js +88 -215
- package/dist/filepizza-downloader.js.map +1 -1
- package/dist/filepizza-uploader.d.ts +14 -95
- package/dist/filepizza-uploader.js +79 -249
- package/dist/filepizza-uploader.js.map +1 -1
- package/dist/peerjs.d.ts +12 -0
- package/dist/peerjs.js +85 -0
- package/dist/peerjs.js.map +1 -0
- package/dist/types.d.ts +6 -2
- package/dist/types.js +4 -2
- package/dist/types.js.map +1 -1
- package/package.json +1 -1
- package/src/filepizza-downloader.ts +373 -459
- package/src/filepizza-uploader.ts +237 -391
- package/src/peerjs.ts +125 -0
- package/src/types.ts +37 -28
package/dist/peerjs.js
ADDED
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
// src/peerjs.ts
|
|
2
|
+
import Peer from 'peerjs';
|
|
3
|
+
const DEFAULT_ICE_SERVERS = [
|
|
4
|
+
{ urls: 'stun:stun.l.google.com:19302' },
|
|
5
|
+
];
|
|
6
|
+
function normalizeBaseUrl(url) {
|
|
7
|
+
return url.replace(/\/+$/, '');
|
|
8
|
+
}
|
|
9
|
+
function parsePeerJSServerUrl(serverUrlString) {
|
|
10
|
+
const serverUrl = new URL(serverUrlString);
|
|
11
|
+
return {
|
|
12
|
+
host: serverUrl.hostname,
|
|
13
|
+
port: serverUrl.port
|
|
14
|
+
? Number.parseInt(serverUrl.port, 10)
|
|
15
|
+
: serverUrl.protocol === 'https:'
|
|
16
|
+
? 443
|
|
17
|
+
: 80,
|
|
18
|
+
path: serverUrl.pathname,
|
|
19
|
+
secure: serverUrl.protocol === 'https:',
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
export async function getIceServers(filePizzaServerUrl) {
|
|
23
|
+
try {
|
|
24
|
+
const response = await fetch(`${normalizeBaseUrl(filePizzaServerUrl)}/api/ice`, {
|
|
25
|
+
method: 'POST',
|
|
26
|
+
});
|
|
27
|
+
if (!response.ok) {
|
|
28
|
+
throw new Error(`Failed to get ICE servers: ${response.status}`);
|
|
29
|
+
}
|
|
30
|
+
const data = await response.json();
|
|
31
|
+
return data.iceServers || DEFAULT_ICE_SERVERS;
|
|
32
|
+
}
|
|
33
|
+
catch (error) {
|
|
34
|
+
console.error('Error getting ICE servers:', error);
|
|
35
|
+
return DEFAULT_ICE_SERVERS;
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
export async function discoverPeerJSSignalingServer(filePizzaServerUrl) {
|
|
39
|
+
try {
|
|
40
|
+
const response = await fetch(`${normalizeBaseUrl(filePizzaServerUrl)}/api/peerjs-servers`);
|
|
41
|
+
if (!response.ok) {
|
|
42
|
+
return undefined;
|
|
43
|
+
}
|
|
44
|
+
const data = await response.json();
|
|
45
|
+
const firstServer = data.servers?.[0];
|
|
46
|
+
if (!firstServer) {
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
return parsePeerJSServerUrl(firstServer);
|
|
50
|
+
}
|
|
51
|
+
catch (error) {
|
|
52
|
+
console.error('Error discovering PeerJS signaling server:', error);
|
|
53
|
+
return undefined;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
export async function buildPeerOptions({ filePizzaServerUrl, iceServers, peerJSSignalingServer, discoverPeerJSSignalingServer: shouldDiscover = true, }) {
|
|
57
|
+
const resolvedIceServers = iceServers || (await getIceServers(filePizzaServerUrl));
|
|
58
|
+
const discoveredPeerJSSignalingServer = peerJSSignalingServer || shouldDiscover
|
|
59
|
+
? peerJSSignalingServer ||
|
|
60
|
+
(await discoverPeerJSSignalingServer(filePizzaServerUrl))
|
|
61
|
+
: undefined;
|
|
62
|
+
return {
|
|
63
|
+
...discoveredPeerJSSignalingServer,
|
|
64
|
+
config: {
|
|
65
|
+
iceServers: resolvedIceServers,
|
|
66
|
+
},
|
|
67
|
+
debug: 2,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
export async function createPeer(options) {
|
|
71
|
+
const peerOptions = await buildPeerOptions(options);
|
|
72
|
+
const peer = new Peer(peerOptions);
|
|
73
|
+
if (peer.id) {
|
|
74
|
+
return peer;
|
|
75
|
+
}
|
|
76
|
+
await new Promise((resolve) => {
|
|
77
|
+
const onOpen = () => {
|
|
78
|
+
peer.off('open', onOpen);
|
|
79
|
+
resolve();
|
|
80
|
+
};
|
|
81
|
+
peer.on('open', onOpen);
|
|
82
|
+
});
|
|
83
|
+
return peer;
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=peerjs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"peerjs.js","sourceRoot":"","sources":["../src/peerjs.ts"],"names":[],"mappings":"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"}
|
package/dist/types.d.ts
CHANGED
|
@@ -1,8 +1,10 @@
|
|
|
1
|
+
import type { PeerOptions } from 'peerjs';
|
|
1
2
|
export interface EventEmitter {
|
|
2
3
|
on(event: string, listener: (...args: any[]) => void): this;
|
|
3
4
|
off(event: string, listener: (...args: any[]) => void): this;
|
|
4
5
|
emit(event: string, ...args: any[]): boolean;
|
|
5
6
|
}
|
|
7
|
+
export type PeerJSSignalingServer = Pick<PeerOptions, 'host' | 'port' | 'path' | 'secure' | 'key' | 'token' | 'pingInterval'>;
|
|
6
8
|
/**
|
|
7
9
|
* Connection status
|
|
8
10
|
*/
|
|
@@ -59,15 +61,17 @@ export interface ConnectionInfo {
|
|
|
59
61
|
mobileModel?: string;
|
|
60
62
|
}
|
|
61
63
|
/**
|
|
62
|
-
* Message types for peer-to-peer communication
|
|
64
|
+
* Message types for peer-to-peer communication.
|
|
65
|
+
*
|
|
66
|
+
* This mirrors the server frontend protocol in filepizza-server/src/messages.ts.
|
|
63
67
|
*/
|
|
64
68
|
export declare enum MessageType {
|
|
65
69
|
RequestInfo = "RequestInfo",
|
|
66
70
|
Info = "Info",
|
|
67
71
|
Start = "Start",
|
|
68
72
|
Chunk = "Chunk",
|
|
73
|
+
ChunkAck = "ChunkAck",
|
|
69
74
|
Pause = "Pause",
|
|
70
|
-
Resume = "Resume",
|
|
71
75
|
Done = "Done",
|
|
72
76
|
Error = "Error",
|
|
73
77
|
PasswordRequired = "PasswordRequired",
|
package/dist/types.js
CHANGED
|
@@ -15,7 +15,9 @@ export var ConnectionStatus;
|
|
|
15
15
|
ConnectionStatus["Error"] = "ERROR";
|
|
16
16
|
})(ConnectionStatus || (ConnectionStatus = {}));
|
|
17
17
|
/**
|
|
18
|
-
* Message types for peer-to-peer communication
|
|
18
|
+
* Message types for peer-to-peer communication.
|
|
19
|
+
*
|
|
20
|
+
* This mirrors the server frontend protocol in filepizza-server/src/messages.ts.
|
|
19
21
|
*/
|
|
20
22
|
export var MessageType;
|
|
21
23
|
(function (MessageType) {
|
|
@@ -23,8 +25,8 @@ export var MessageType;
|
|
|
23
25
|
MessageType["Info"] = "Info";
|
|
24
26
|
MessageType["Start"] = "Start";
|
|
25
27
|
MessageType["Chunk"] = "Chunk";
|
|
28
|
+
MessageType["ChunkAck"] = "ChunkAck";
|
|
26
29
|
MessageType["Pause"] = "Pause";
|
|
27
|
-
MessageType["Resume"] = "Resume";
|
|
28
30
|
MessageType["Done"] = "Done";
|
|
29
31
|
MessageType["Error"] = "Error";
|
|
30
32
|
MessageType["PasswordRequired"] = "PasswordRequired";
|
package/dist/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAcA;;GAEG;AACH,MAAM,CAAN,IAAY,gBAWX;AAXD,WAAY,gBAAgB;IAC1B,uCAAmB,CAAA;IACnB,mCAAe,CAAA;IACf,qCAAiB,CAAA;IACjB,2CAAuB,CAAA;IACvB,+CAA2B,CAAA;IAC3B,iCAAa,CAAA;IACb,qDAAiC,CAAA;IACjC,wDAAoC,CAAA;IACpC,qCAAiB,CAAA;IACjB,mCAAe,CAAA;AACjB,CAAC,EAXW,gBAAgB,KAAhB,gBAAgB,QAW3B;AA8CD;;;;GAIG;AACH,MAAM,CAAN,IAAY,WAYX;AAZD,WAAY,WAAW;IACrB,0CAA2B,CAAA;IAC3B,4BAAa,CAAA;IACb,8BAAe,CAAA;IACf,8BAAe,CAAA;IACf,oCAAqB,CAAA;IACrB,8BAAe,CAAA;IACf,4BAAa,CAAA;IACb,8BAAe,CAAA;IACf,oDAAqC,CAAA;IACrC,0CAA2B,CAAA;IAC3B,gCAAiB,CAAA;AACnB,CAAC,EAZW,WAAW,KAAX,WAAW,QAYtB"}
|
package/package.json
CHANGED