--- sidebar_position: 5 --- import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem'; # Finish parts upload Confirms the multipart uploading finish `Function FinishPartsUpload(Val Name, Val Bucket, Val BasicData, Val UploadID, Val TagsArray, Val Headers = Undefined) Export` | Parameter | CLI option | Type | Required | Description | |-|-|-|-|-| | Name | --name | String | ✔ | Name of the object in the bucket | | Bucket | --bucket | String | ✔ | Name of the bucket to put the object | | BasicData | --basic | Structure Of KeyAndValue | ✔ | Basic request data. See GetBasicDataStructure | | UploadID | --upload | String | ✔ | Upload ID. See InitPartsUpload | | TagsArray | --tags | Array Of String | ✔ | An array of tags (Etag) from the uploads responses of each part | | Headers | --headers | Map Of KeyAndValue | ✖ | Additional request headers, if necessary | Returns: Structure Of KeyAndValue - serialized JSON response from storage
:::tip Method at AWS documentation: [CompleteMultipartUpload](https://docs.aws.amazon.com/AmazonS3/latest/API/API_CompleteMultipartUpload.html) This is a service method. A `PutObject` method is intended for the common scenario of files uploading :::
```bsl title="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(); ETag = Result["headers"]["Etag"]; ETag = ?(ETag = Undefined, Result["headers"]["ETag"], ETag); TagsArray.Add(ETag); PartNumber = PartNumber + 1; EndDo; Result = OPI_S3.FinishPartsUpload(Name, Bucket, BasicData, UploadID, TagsArray); // ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ ``` ```bash # 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 "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjIzNDMzMzIzLTI1YmUtNDgwYi1iMGRjLTk2MWJkY2NjMjljYw" \ --tags "['\"566e2d464b39b91eb8b5d89fb9f1a318\"','\"adb76a9a9ff8226ed08fb6f343102908\"']" ``` ```batch :: 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 "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjIzNDMzMzIzLTI1YmUtNDgwYi1iMGRjLTk2MWJkY2NjMjljYw" ^ --tags "['\"566e2d464b39b91eb8b5d89fb9f1a318\"','\"adb76a9a9ff8226ed08fb6f343102908\"']" ``` ```json title="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" } } ```