[Spaces] Unable to do multipart upload in JS

Hi, I have the simple upload code using the aws js api

AWS.config.region = 'nyc3'; 
const spacesEndpoint = new AWS.Endpoint('');
const s3 = new AWS.S3({
    endpoint: spacesEndpoint,
    accessKeyId: '',
    secretAccessKey: ''
 		var params = {
			Bucket: bucket,
			Key: key,
			ContentType: file.type,
			Body: file,
			ACL: 'public-read'
		var upload = s3.upload(params, function (err, data) {
		  if (err) {

Everytime I upload a file large enough for a multipart upload, I get the error

ETagMissing: No access to ETag property on response. Check CORS configuration to expose ETag header

but in my CORS config, I’ve given all domains access to everything!

Do Spaces not support the ETag header required for this?


Getting the same results. I do see ETag headers listed in the documentation, so it is a bit confusing.

Does Digitalocean not have the ability to set “Expose Header” in CORS config, like on AWS?

Did you find a solution ? I’m also getting the same error message

Submit an answer
You can type!ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!

These answers are provided by our Community. If you find them useful, show some love by clicking the heart. If you run into issues leave a comment, or add your own answer to help others.

Accepted Answer

Hi. You can upload CORS file configuration by s3cmd tool.

python s3cmd setcors cors.xml s3://[bucket]

Sample cors.xml:

<?xml version="1.0" encoding="UTF-8"?>
<CORSConfiguration xmlns="">

It works for me:)