AFFiNE/libs/datasource/remote-kv
2022-08-13 03:16:26 +08:00
..
src chore: sort imports 2022-08-13 03:16:26 +08:00
.babelrc init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
.eslintrc.json init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
jest.config.js init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
package.json chore: update deps 2022-08-08 01:16:25 +08:00
project.json init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
README.md init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
tsconfig.json init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
tsconfig.lib.json init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00
tsconfig.spec.json init: the first public commit for AFFiNE 2022-07-22 15:49:21 +08:00

Attachment module documentation

describe

The attachment system currently provides AWS S3 object storage service, using the default IAM account for read and write operations;

###Instructions for use

Initialize attachment system

// Initialize the accessory system, the platorm configuration is as follows, for reference
const PLATFORM_CONFIG = {
    AWSS3: 'awss3', // key replace with uuid
    ALIYUN: 'ailiyun',
};

// It is recommended not to pass the platform type for initialization, AWS S3 is used by default
import { upload, multipartUpload } from '@toeverything/components/attachment';

Instance methods

_In the function description, if "batch" is not marked, the default is a single file operation; _

  • upload: file upload

    • Type definition

      type upload = (file: File) => Promise<Error | Url>;
      
    • Usage example

      const onChange = async info => {
          const { file } = info;
          const url = await upload(file.originFileObj);
          console.log(url);
      };
      
      // or
      const onChange = async info => {
          const { file } = info;
          const [err, url] = await toAsync(upload(file.originFileObj));
      
          if (err) {
              return;
          }
      
          console.log(url);
      };
      
  • multipartUpload: file upload in parts

    • Type definition

      type multipartUpload = (file: File) => Promise<Error | Url>;
      
    • Usage example

      const onChange = async info => {
          const { file } = info;
          const url = await multipartUpload(file.originFileObj);
          console.log(url);
      };
      
  • batchUpload: batch upload

    • Type definition

      interface data {
          success: Array<{ name: string; url: string }>;
          failed: Array<{ name: string; reason: string }>;
      }
      
      type batchUpload = (fileList: File[]) => Promise<Error | data>;
      
    • Usage example

      const onChange = async info => {
          const fileList = info.fileList.map(file => file.originFileObj);
          const { success } = await batchUpload(fileList);
          const urls = success.map(item => item.url);
      };
      
  • download: file download

    • Type definition

      type download = (fileName: string) => Promise<Error | true>;
      
    • Usage example

      const onChange = async fileName => {
          // browser download
          await download(fileName);
      };
      
  • recovery: file deletion

    • Type definition

      type recovery = (fileName: string) => Promise<Error | true>;
      
    • Usage example

      const onChange = async fileName => {
          await recovery(fileName);
      };