diff --git a/manual_tests/upload_new.ts b/manual_tests/upload_new.ts index a5b8a43e..cae66b9e 100644 --- a/manual_tests/upload_new.ts +++ b/manual_tests/upload_new.ts @@ -14,36 +14,43 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +import * as Path from 'path'; -// import { Client } from './../src/lib/client'; -// import * as Path from 'path'; -// import * as Sentry from '@sentry/node'; - -import { S3Uploader } from './../src/lib/api/upload/uploaders/s3'; import { getFile } from '../src/lib/api/upload'; +import { S3Uploader } from './../src/lib/api/upload/uploaders/s3'; +import { Client } from './../src/lib/client'; + +// import * as Sentry from '@sentry/node'; const createFile = (size = 10 * 1024 * 1024) => Buffer.alloc(size).fill('a'); // Sentry.init({ dsn: 'DSN' }); -// const fs = new Client(process.env.API_KEY); +const fs = new Client(process.env.API_KEY); // fs.on('upload.error', (e) => { // console.log('uploadError', e); // }); -// fs.multiupload( -// [ -// { -// file: Path.resolve(__dirname, './manual_10mb.mp4'), -// name: 'test.mp4', -// }, -// ], -// {}, -// { -// filename: () => 'test2.mp4', -// } -// ).then(res => { -// console.dir(res, { depth: null }); -// }); +(async () => { + const file1 = createFile(5 * 1024 * 1024); + const file2 = createFile(2 * 1024 * 1024); + + fs.multiupload( + [ { file: file1, name: 'test1' }, { file: file2, name: 'test 2' } ], + { + onProgress: (e) => { + console.log('prog', e); + if (e.files) { + Object.keys(e.files).forEach(f => console.log(e.files[f])); + } + }, + } + // { + // filename: () => 'test2.mp4', + // } + ).then(res => { + console.dir(res, { depth: null }); + }); +})(); // try { // fs.upload('./upload.js').then((res) => { @@ -53,30 +60,30 @@ const createFile = (size = 10 * 1024 * 1024) => Buffer.alloc(size).fill('a'); // console.log(e.details); // } -const b64jpg = ''; +// const b64jpg = ''; -(async () => { - // const file = await getFile(createFile()); - const file = await getFile(b64jpg); - // file.name = 'test.txt'; - console.log('Uploadinf file', file.size); - // const token = new FsCancelToken(); +// (async () => { +// // const file = await getFile(createFile()); +// const file = await getFile(b64jpg); +// // file.name = 'test.txt'; +// console.log('Uploadinf file', file.size); +// // const token = new FsCancelToken(); - const u = new S3Uploader({}); - u.setUrl('https://upload.filestackapi.com'); - u.setApikey(process.env.API_KEY); - // u.setIntegrityCheck(false); - u.addFile(file); - // u.addFile(file1); +// const u = new S3Uploader({}); +// u.setUrl('https://upload.filestackapi.com'); +// u.setApikey(process.env.API_KEY); +// // u.setIntegrityCheck(false); +// u.addFile(file); +// // u.addFile(file1); - // setTimeout(() => { - // console.log('abort call'); - // u.abort(); - // }, 3000); +// // setTimeout(() => { +// // console.log('abort call'); +// // u.abort(); +// // }, 3000); - const res = await u.execute().catch((e) => { - console.log('ERROR', e); - }); +// const res = await u.execute().catch((e) => { +// console.log('ERROR', e); +// }); - console.log(res); -})(); +// console.log(res); +// })(); diff --git a/src/lib/api/upload/file.ts b/src/lib/api/upload/file.ts index 88a8124f..b0baebdf 100644 --- a/src/lib/api/upload/file.ts +++ b/src/lib/api/upload/file.ts @@ -74,7 +74,10 @@ export class File { public uploadTags: UploadTags; + public originalName: string; + constructor(private readonly _file: FileInstance, private readonly _sanitizeOptions?: SanitizeOptions) { + this.originalName = this._file.name + ''; this._file.name = sanitizeName(this._file.name, this._sanitizeOptions); } diff --git a/src/lib/api/upload/types.ts b/src/lib/api/upload/types.ts index 1c927303..e7aedd8b 100644 --- a/src/lib/api/upload/types.ts +++ b/src/lib/api/upload/types.ts @@ -14,10 +14,9 @@ * See the License for the specific language governing permissions and * limitations under the License. */ - import { StoreBaseParams } from './../../filelink'; +import { SanitizeOptions } from './../../utils'; import { UploadTags } from './file'; -import { SanitizeOptions } from './../../utils/index'; export interface UploadOptions { /** @@ -31,7 +30,7 @@ export interface UploadOptions { /** * Callback for progress events. */ - onProgress?: (evt: FSProgressEvent) => void; + onProgress?: (evt: ProgressEvent) => void; /** * How often to report progress. Default is 1000 (in milliseconds). */ @@ -114,7 +113,15 @@ export interface WorkflowConfig { id: string; } -export interface FSProgressEvent { +export interface ProgressEvent { totalPercent: number; totalBytes: number; + files?: { (key: string): ProgressEvent & { + file?: { + name: string; + size: number; + mimetype: string; + uploadTags: UploadTags; + }; + }}; } diff --git a/src/lib/api/upload/upload.ts b/src/lib/api/upload/upload.ts index 6ae39da9..1af2a125 100644 --- a/src/lib/api/upload/upload.ts +++ b/src/lib/api/upload/upload.ts @@ -14,30 +14,24 @@ * See the License for the specific language governing permissions and * limitations under the License. */ - import { EventEmitter } from 'eventemitter3'; -import { Session, Security } from '../../client'; -import { S3Uploader } from './uploaders/s3'; + +import { Security, Session } from '../../client'; +import { ProgressEvent, StoreUploadOptions, UploadOptions } from '../upload/types'; import { FilestackError, FilestackErrorType } from './../../../filestack_error'; +import { getValidator, StoreParamsSchema, UploadParamsSchema } from './../../../schema'; import { SanitizeOptions } from './../../utils'; - -import { UploadOptions, StoreUploadOptions } from '../upload/types'; -import { getFile, InputFile } from './file_tools'; import { FileState, UploadTags } from './file'; +import { getFile, InputFile } from './file_tools'; import { UploadMode } from './uploaders/abstract'; -import { getValidator, UploadParamsSchema, StoreParamsSchema } from './../../../schema'; - -export interface ProgressEvent { - totalPercent: number; - totalBytes: number; - files?: { (key: string): ProgressEvent }; -} +import { S3Uploader } from './uploaders/s3'; const DEFAULT_PROGRESS_INTERVAL = 1000; const normalizeProgress = (current, last) => { current.totalBytes = Math.max(current.totalBytes, last.totalBytes); current.totalPercent = Math.max(current.totalPercent, last.totalPercent); + current.file = last?.file; return current; }; diff --git a/src/lib/api/upload/uploaders/s3.ts b/src/lib/api/upload/uploaders/s3.ts index 05e9c983..63573be9 100644 --- a/src/lib/api/upload/uploaders/s3.ts +++ b/src/lib/api/upload/uploaders/s3.ts @@ -775,6 +775,13 @@ export class S3Uploader extends UploaderAbstract { filesProgress[i] = { totalBytes: totalParts, totalPercent: Math.round((totalParts * 100) / payload.file.size) || 0, + file: { + name: payload.file.name, + originalName: payload.file.originalName, + size: payload.file.size, + mimetype: payload.file.mimetype, + uploadTags: payload.file.uploadTags, + }, }; totalSize = totalSize + payload.file.size; diff --git a/src/lib/picker.ts b/src/lib/picker.ts index 42960731..f712a1d0 100644 --- a/src/lib/picker.ts +++ b/src/lib/picker.ts @@ -14,12 +14,12 @@ * See the License for the specific language governing permissions and * limitations under the License. */ +import { FILESTACK_MODULES, loadModule } from '@filestack/loader'; -import { loadModule, FILESTACK_MODULES } from '@filestack/loader'; import { FilestackError, FilestackErrorType } from './../filestack_error'; -import { Client } from './client'; -import { FSProgressEvent, UploadOptions, WorkflowConfig } from './api/upload/types'; import { getValidator, PickerParamsSchema } from './../schema'; +import { UploadOptions, WorkflowConfig } from './api/upload/types'; +import { Client } from './client'; export interface PickerInstance { /** @@ -185,7 +185,7 @@ export interface PickerFileErrorCallback { } export interface PickerFileProgressCallback { - (file: PickerFileMetadata, event: FSProgressEvent): void; + (file: PickerFileMetadata, event: ProgressEvent): void; } export interface PickerUploadStartedCallback {