coding-socks/multipart-of-madness 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

coding-socks/multipart-of-madness

最新稳定版本:v0.1.2

Composer 安装命令:

composer require coding-socks/multipart-of-madness

包简介

This package helps to integrate your library with @uppy/aws-s3-multipart

README 文档

README

This package helps to integrate your library with @uppy/aws-s3-multipart.

Installation

You can easily install this package using Composer.

composer require coding-socks/multipart-of-madness

You have to install @uppy/aws-s3-multipart to be able to use it as an uploader.

npm i -D @uppy/aws-s3-multipart

Usage

Configure Uppy with AwsS3Multipart uploader.

uppy.use(AwsS3Multipart, {
    companionUrl: '/uppy',
    shouldUseMultipart(file) {
        return file.size > 10 * 1024 * 1024;
    }
})
uppy.addPreProcessor(() => {
    return new Promise((resolve) => {
        const cookieName = window.axios.defaults.xsrfCookieName
        const headerName = window.axios.defaults.xsrfHeaderName
        /** @type {AwsS3Multipart} */
        const plugin = uppy.getPlugin('AwsS3Multipart')
        plugin?.setOptions({
            // You have to implement `cookies.read`
            companionHeaders: {[headerName]: cookies.read(cookieName)},
        })
        resolve()
    })
})

Configure the CORS of your S3 or S3-compatible solution. It needs to allow GET and PUT requests from your domain and expose some unsafe HTTP headers to Uppy. Example:

[
	{
		"AllowedOrigins": ["https://my-app.com"],
		"AllowedMethods": ["GET", "PUT"],
		"MaxAgeSeconds": 3000,
		"AllowedHeaders": [
			"Authorization",
			"x-amz-date",
			"x-amz-content-sha256",
			"content-type"
		],
		"ExposeHeaders": ["ETag", "Location"]
	}
]

Defaults

The expiration times for the signe links is 15 minutes.

The target filesystem disk is s3.

The endpoint routes registered under web route with /uppy prefix.

Implementation

This implementation uses PutObject command instead of PostObject on non-multipart upload request. This is only for compatibility with Backblaze B2 and Cloudflare R2. @uppy/companion uses PostObject.

All other routes were implemented based on @uppy/companion.

统计信息

  • 总下载量: 326
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-04-01