mirror of
https://github.com/Bayselonarrend/OpenIntegrations.git
synced 2025-03-29 21:57:16 +02:00
151 lines
4.9 KiB
Plaintext
151 lines
4.9 KiB
Plaintext
---
|
|
sidebar_position: 4
|
|
---
|
|
|
|
import Tabs from '@theme/Tabs';
|
|
import TabItem from '@theme/TabItem';
|
|
|
|
# Upload object part
|
|
Uploads a part of an object for multipart uploading
|
|
|
|
|
|
|
|
`Function UploadObjectPart(Val Name, Val Bucket, Val BasicData, Val UploadID, Val PartNumber, Val Data, 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 |
|
|
| PartNumber | --part | Number, String | ✔ | Number of the object part from 1 to 10000 |
|
|
| Data | --content | BinaryData, String | ✔ | Part content for uploading |
|
|
| Headers | --headers | Map Of KeyAndValue | ✖ | Additional request headers, if necessary |
|
|
|
|
|
|
Returns: Structure of KeyAndValue - serialized JSON response from storage
|
|
|
|
<br/>
|
|
|
|
:::tip
|
|
Method at AWS documentation: [UploadPart](https://docs.aws.amazon.com/AmazonS3/latest/API/API_UploadPart.html)
|
|
|
|
This is a service method. A `PutObject` method is intended for the common scenario of files uploading
|
|
|
|
Parameters with Binary data type can also accept file paths on disk and URLs
|
|
:::
|
|
<br/>
|
|
|
|
|
|
```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);
|
|
```
|
|
|
|
|
|
<Tabs>
|
|
|
|
<TabItem value="bash" label="Bash" default>
|
|
```bash
|
|
# JSON data can also be passed as a path to a .json file
|
|
|
|
oint s3 UploadObjectPart \
|
|
--name "fileChunked.mp3" \
|
|
--bucket "opi-gpbucket3" \
|
|
--basic "{'URL':'storage-155.s3hoster.by','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" \
|
|
--upload "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjEzODRlOTAxLTA1MDItNGU3ZS05YjMwLWY3NjVhNGYwODM4Zg" \
|
|
--part 2 \
|
|
--content "C:\Users\Administrator\AppData\Local\Temp\qisxv3a0wfb.tmp"
|
|
```
|
|
</TabItem>
|
|
|
|
<TabItem value="bat" label="CMD/Bat" default>
|
|
```batch
|
|
:: JSON data can also be passed as a path to a .json file
|
|
|
|
oint s3 UploadObjectPart ^
|
|
--name "fileChunked.mp3" ^
|
|
--bucket "opi-gpbucket3" ^
|
|
--basic "{'URL':'storage-155.s3hoster.by','AccessKey':'***','SecretKey':'***','Region':'BTC','Service':'s3'}" ^
|
|
--upload "MDk2NGE5MDUtNDcxZS00ZDljLTkzYjMtODM5ZDM4NGMyMWVhLjEzODRlOTAxLTA1MDItNGU3ZS05YjMwLWY3NjVhNGYwODM4Zg" ^
|
|
--part 2 ^
|
|
--content "C:\Users\Administrator\AppData\Local\Temp\qisxv3a0wfb.tmp"
|
|
```
|
|
</TabItem>
|
|
</Tabs>
|
|
|
|
|
|
```json title="Result"
|
|
{
|
|
"status": 200,
|
|
"response": {},
|
|
"headers": {
|
|
"Accept-Ranges": "bytes",
|
|
"Content-Length": "0",
|
|
"Content-Type": "text/plain; charset=utf-8",
|
|
"Date": "Fri, 22 Nov 2024 10:12:18 GMT",
|
|
"Etag": "\"566e2d464b39b91eb8b5d89fb9f1a318\"",
|
|
"Server": "MinIO",
|
|
"Strict-Transport-Security": "max-age=31536000; includeSubDomains",
|
|
"Vary": "Origin,Accept-Encoding",
|
|
"X-Amz-Id-2": "057275ee0636b36a8256f409a6ff665de46bfaa1f0d5faf2d1b4f312e55c34fa",
|
|
"X-Amz-Request-Id": "180A42B1B07D2379",
|
|
"X-Content-Type-Options": "nosniff",
|
|
"X-Xss-Protection": "1; mode=block"
|
|
}
|
|
}
|
|
```
|