MongoDB C++ Driver 4.1.0
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
downloader.hpp
Go to the documentation of this file.
1// Copyright 2009-present MongoDB, Inc.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
15#pragma once
16
17#include <cstddef>
18#include <cstdint>
19#include <memory>
20
23
28
29#include <mongocxx/cursor.hpp>
30
32
33namespace mongocxx {
34namespace v_noabi {
35namespace gridfs {
36
41 std::int32_t chunks_offset = 0;
42 std::int32_t bytes_offset = 0;
43};
44
49 public:
56
61
66
67 downloader(downloader const&) = delete;
68
69 downloader& operator=(downloader const&) = delete;
70
75
80 explicit MONGOCXX_ABI_EXPORT_CDECL() operator bool() const noexcept;
81
102 MONGOCXX_ABI_EXPORT_CDECL(std::size_t) read(std::uint8_t* buffer, std::size_t length);
103
110
118
126
134
135 private:
136 friend ::mongocxx::v_noabi::gridfs::bucket;
137
138 //
139 // Constructs a new downloader stream.
140 //
141 // @param chunks
142 // The cursor to read the chunks of the file from. It must have a value if the length of the
143 // file is non-zero.
144 //
145 // @param start
146 // The offset from which to start reading the chunks of the file.
147 //
148 // @param chunk_size
149 // The expected size of a chunk in bytes.
150 //
151 // @param file_len
152 // The expected size of the file in bytes.
153 //
154 // @param files_doc
155 // The files collection document of the file being downloaded.
156 //
158 bsoncxx::v_noabi::stdx::optional<cursor> chunks,
160 std::int32_t chunk_size,
161 std::int64_t file_len,
162 bsoncxx::v_noabi::document::value files_doc);
163
164 void fetch_chunk();
165
166 class impl;
167
168 impl& _get_impl();
169 impl const& _get_impl() const;
170
171 std::unique_ptr<impl> _impl;
172};
173
174} // namespace gridfs
175} // namespace v_noabi
176} // namespace mongocxx
177
178#include <mongocxx/config/postlude.hpp>
179
downloader() noexcept
Default constructs a downloader object. The downloader is equivalent to the state of a moved from dow...
A cursor over the documents returned by a query to a MongoDB server.
Definition cursor.hpp:42
A GridFS bucket.
Definition bucket.hpp:66
downloader() noexcept
Default constructs a downloader object. The downloader is equivalent to the state of a moved from dow...
bsoncxx::v_noabi::document::view files_document() const
Gets the files collection document of the file being downloaded.
std::int32_t chunk_size() const
Gets the chunk size of the file being downloaded.
void close()
Closes the downloader stream.
std::size_t read(std::uint8_t *buffer, std::size_t length)
Reads a specified number of bytes from the GridFS file being downloaded.
std::int64_t file_length() const
Gets the length of the file being downloaded.
Provides mongocxx::v_noabi::cursor.
Provides bsoncxx::v_noabi::document::value.
Provides bsoncxx::v_noabi::document::view.
Declares utilities to download GridFS files.
Declares mongocxx::v_noabi::gridfs::bucket.
#define MONGOCXX_ABI_EXPORT_CDECL(...)
Equivalent to MONGOCXX_ABI_EXPORT with MONGOCXX_ABI_CDECL.
Definition export.hpp:52
The mongocxx v_noabi macro guard prelude header.
The top-level namespace within which all bsoncxx library entities are declared.
Declares entities related to GridFS.
Declares entities whose ABI stability is NOT guaranteed.
The top-level namespace within which all mongocxx library entities are declared.
Used to specify the offset from which to start reading the chunks of the file.
Definition downloader.hpp:40
Provides bsoncxx::v_noabi::types::bson_value::view.
Provides std::optional-related polyfills for library API usage.