Я пытаюсь загрузить большие файлы (видео) в нескольких частях с Dropzone JS в Васаби (копия AWS). Ошибка, которую я получил, состоит в том, что загружается только последний кусок. и я не знаю почему, но последний вызов dropzone не компилирует файл. Я пробовал разные способы, и никто не работал со мной. Это мой объект дропзоны:
var dropzone = new Dropzone('#video-dropzone', {
previewTemplate: document.querySelector('#preview-template').innerHTML,
parallelUploads: 2,
thumbnailHeight: 120,
thumbnailWidth: 120,
method: 'POST',
paramName: "file",
autoProcessQueue: false,
timeout: 7200000,
maxFilesize: 500000,
chunking: true,
parallelChunkUploads: false,
chunkSize: 100000000, {# 1000000000 1GB per part #}
params: function (files, xhr, chunk) {
if (chunk) {
return {
UploadId: chunk.file.upload.uuid,
PartNumber: chunk.index,
TotalFileSize: chunk.file.size,
CurrentChunkSize: chunk.dataBlock.data.size,
TotalChunkCount: chunk.file.upload.totalChunkCount,
ChunkByteOffset: chunk.index * this.options.chunkSize,
ChunkSize: this.options.chunkSize,
Filename: chunk.file.name,
};
}
},
init: function () {
thisDropzone = this;
{# When a file is added, we need to put the fields of the video, #}
{# so we show a video create form #}
thisDropzone.on('addedfile', function (file) {
thisDropzone.options.url = $("#video-dropzone").attr("action");
$.confirm({
title: "{% trans 'Video Create' %}",
content: 'url:{% url 'video-create' %}',
useBootstrap: false,
theme: 'material',
buttons: {
create: function () {
{# If the title is empty, you can't create it #}
if ($("#id_title").val() == "") {
$("#id_title").addClass("is-invalid");
return false;
}
{# Creation of the video fields #}
let create_video = video_create(file);
{# If all fields has been created correctly,#}
{# the generate a signature and launch the queue #}
if (create_video.status == 200) {
file.customName = create_video.data.filename;
generar_signature(file);
{# When all fields are correct, the dropzone can start#}
{# to upload the files #}
thisDropzone.processQueue();
}
},
cancel: function () {
{# Removes the file if you click cancel #}
thisDropzone.removeFile(file);
}
}
});
});
Он правильно разбивает файл на части, но по окончании хранения я вижу только последнюю часть