| 1 | #include <Common/config.h> | 
|---|---|
| 2 | |
| 3 | #if USE_AWS_S3 | 
| 4 | |
| 5 | #include <IO/ReadBufferFromS3.h> | 
| 6 | #include <IO/ReadBufferFromIStream.h> | 
| 7 | |
| 8 | #include <common/logger_useful.h> | 
| 9 | #include <aws/s3/model/GetObjectRequest.h> | 
| 10 | #include <aws/s3/S3Client.h> | 
| 11 | |
| 12 | namespace DB | 
| 13 | { | 
| 14 | |
| 15 | namespace ErrorCodes | 
| 16 | { | 
| 17 | extern const int S3_ERROR; | 
| 18 | } | 
| 19 | |
| 20 | |
| 21 | ReadBufferFromS3::ReadBufferFromS3(const std::shared_ptr<Aws::S3::S3Client> & client_ptr, | 
| 22 | const String & bucket, | 
| 23 | const String & key, | 
| 24 | size_t buffer_size_): ReadBuffer(nullptr, 0) | 
| 25 | { | 
| 26 | Aws::S3::Model::GetObjectRequest req; | 
| 27 | req.SetBucket(bucket); | 
| 28 | req.SetKey(key); | 
| 29 | |
| 30 | Aws::S3::Model::GetObjectOutcome outcome = client_ptr->GetObject(req); | 
| 31 | |
| 32 | if (outcome.IsSuccess()) | 
| 33 | { | 
| 34 | read_result = outcome.GetResultWithOwnership(); | 
| 35 | impl = std::make_unique<ReadBufferFromIStream>(read_result.GetBody(), buffer_size_); | 
| 36 | } | 
| 37 | else | 
| 38 | throw Exception(outcome.GetError().GetMessage(), ErrorCodes::S3_ERROR); | 
| 39 | } | 
| 40 | |
| 41 | bool ReadBufferFromS3::nextImpl() | 
| 42 | { | 
| 43 | if (!impl->next()) | 
| 44 | return false; | 
| 45 | internal_buffer = impl->buffer(); | 
| 46 | working_buffer = internal_buffer; | 
| 47 | return true; | 
| 48 | } | 
| 49 | |
| 50 | } | 
| 51 | |
| 52 | #endif | 
| 53 | 
