Working on it...

This commit is contained in:
split / May 2023-12-11 16:15:05 -08:00
parent 79ecb5e408
commit 3de215ee35

View file

@ -95,11 +95,55 @@ async function pushWebStream(stream: Readable, webStream: ReadableStream) {
return last
}
namespace StreamHelpers {
interface UploadStream {
uploaded: number // number of bytes uploaded
stream : Readable
}
class StreamBuffer {
readonly targetSize: number
filled: number = 0
buffer: UploadStream[] = []
api: API
constructor( api: API, targetSize: number ) {
this.api = api
this.targetSize = targetSize
}
private startMessage(streamCount: number): UploadStream[] {
let streams = []
// can't think of a better way to do
for (let i = 0; i < streamCount; i++) {
streams.push({
uploaded: 0,
stream: new Readable()
})
}
this.api.send(streams.map(e => e.stream));
return streams
}
async getNextStream() {
if (this.buffer[0]) return this.buffer[0]
else {
// startmessage.... idk
}
}
}
}
export default class Files {
config: Configuration
api: API
@ -116,28 +160,6 @@ export default class Files {
.catch(console.error)
}
/**
* @description Start a new message.
* @param streamCount Number of files to upload.
*/
private startMessage(streamCount: number): UploadStream[] {
let streams = []
// can't think of a better way to do
for (let i = 0; i < streamCount; i++) {
streams.push({
uploaded: 0,
stream: new Readable()
})
}
this.api.send(streams.map(e =< e.stream));
return streams
}
writeFileStream(metadata: FileUploadSettings & { size: number }) {
let uploadId = (metadata.uploadId || generateFileId()).toString()