forked from GetStream/stream-js
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfiles.ts
45 lines (41 loc) · 1.45 KB
/
files.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
import AxiosProgressEvent from 'axios';
import { StreamClient } from './client';
export class StreamFileStore {
client: StreamClient;
token: string;
constructor(client: StreamClient, token: string) {
this.client = client;
this.token = token;
}
// React Native does not auto-detect MIME type, you need to pass that via contentType
// param. If you don't then Android will refuse to perform the upload
/**
* upload a File instance or a readable stream of data
* @link https://getstream.io/activity-feeds/docs/node/files_introduction/?language=js#upload
* @param {File|Buffer|NodeJS.ReadStream|string} uri - File object or stream or URI
* @param {string} [name] - file name
* @param {string} [contentType] - mime-type
* @param {function} [onUploadProgress] - browser only, Function that is called with upload progress
* @return {Promise<FileUploadAPIResponse>}
*/
upload(
uri: string | File | Buffer | NodeJS.ReadStream,
name?: string,
contentType?: string,
onUploadProgress?: (progressEvent: typeof AxiosProgressEvent) => void,
) {
return this.client.upload('files/', uri, name, contentType, onUploadProgress);
}
/**
* delete an uploaded file
* @link https://getstream.io/activity-feeds/docs/node/files_introduction/?language=js#delete
* @param {string} uri
*/
delete(uri: string) {
return this.client.delete({
url: `files/`,
qs: { url: uri },
token: this.token,
});
}
}