Skip to main content

Finish parts upload

Confirms the multipart uploading finish

Function FinishPartsUpload(Val Name, Val Bucket, Val BasicData, Val UploadID, Val TagsArray, Val Headers = Undefined) Export

ParameterCLI optionTypeRequiredDescription
Name--nameStringName of the object in the bucket
Bucket--bucketStringName of the bucket to put the object
BasicData--basicStructure of KeyAndValueBasic request data. See GetBasicDataStructure
UploadID--uploadStringUpload ID. See InitPartsUpload
TagsArray--tagsArray Of StringAn array of tags (Etag) from the uploads responses of each part
Headers--headersMap Of KeyAndValueAdditional request headers, if necessary

Returns: Structure of KeyAndValue - serialized JSON response from storage


tip

Method at AWS documentation: CompleteMultipartUpload

This is a service method. A PutObject method is intended for the common scenario of files uploading


1C:Enterprise/OneScript code example
    URL       = "storage-155.s3hoster.by";
AccessKey = "BRN5RKJE67...";
SecretKey = "NNhv+i9PrytpT8Tu0C1N...";
Region = "BTC";

BasicData = OPI_S3.GetBasicDataStructure(URL, AccessKey, SecretKey, Region);

Name = "fileChunked.mp3";
Bucket = "opi-gpbucket3";

Entity = "https://api.athenaeum.digital/test_data/song.mp3"; // URL, Path or Binary Data
Entity = OPI_Tools.Get(Entity);

Result = OPI_S3.InitPartsUpload(Name, Bucket, BasicData);

UploadID = Result["response"]["InitiateMultipartUploadResult"]["UploadId"];
TotalSize = Entity.Size();
ChunkSize = 5242880;
BytesRead = 0;
PartNumber = 1;

DataReader = New DataReader(Entity);
SourceStream = DataReader.SourceStream();
TagsArray = New Array;

WHile BytesRead < TotalSize Do

CurrentReading = DataReader.Read(ChunkSize);
CurrentData = CurrentReading.GetBinaryData();

If CurrentData.Size() = 0 Then
Break;
EndIf;

Result = OPI_S3.UploadObjectPart(Name
, Bucket
, BasicData
, UploadID
, PartNumber
, CurrentData);

BytesRead = SourceStream.CurrentPosition();
TagsArray.Add(Result["headers"]["Etag"]);

PartNumber = PartNumber + 1;

EndDo;

Result = OPI_S3.FinishPartsUpload(Name, Bucket, BasicData, UploadID, TagsArray);
// ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    # JSON data can also be passed as a path to a .json file

oint s3 FinishPartsUpload \
--name "fileChunked.mp3" \
--bucket "opi-gpbucket3" \
--basic "{'URL':'storage-155.s3hoster.by','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" \
--upload "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjEzODRlOTAxLTA1MDItNGU3ZS05YjMwLWY3NjVhNGYwODM4Zg" \
--tags "['\"566e2d464b39b91eb8b5d89fb9f1a318\"','\"adb76a9a9ff8226ed08fb6f343102908\"']"
Result
{
"status": 200,
"response": {
"CompleteMultipartUploadResult": {
"Location": "https://opi-gpbucket3.storage-155.s3hoster.by/fileChunked.mp3",
"Bucket": "opi-gpbucket3",
"Key": "fileChunked.mp3",
"ETag": "\"22c09aeeb42144b375de8a4c1a1bb573-2\""
}
},
"headers": {
"Accept-Ranges": "bytes",
"Content-Length": "345",
"Content-Type": "application/xml",
"Date": "Fri, 22 Nov 2024 10:12:23 GMT",
"Etag": "\"22c09aeeb42144b375de8a4c1a1bb573-2\"",
"Server": "MinIO",
"Strict-Transport-Security": "max-age=31536000; includeSubDomains",
"Vary": "Origin,Accept-Encoding",
"X-Amz-Id-2": "93c576aa54c960b355da9e2934476635fe3243f5df9dbb4db8b7c0d94bec7cd1",
"X-Amz-Request-Id": "180A42B31F29A49F",
"X-Content-Type-Options": "nosniff",
"X-Xss-Protection": "1; mode=block"
}
}