google_cloud_storage/storage/
request_options.rs1use crate::read_resume_policy::{ReadResumePolicy, Recommended};
16use crate::storage::checksum::details::{Checksum, Crc32c};
17use gax::{
18 backoff_policy::BackoffPolicy,
19 retry_policy::RetryPolicy,
20 retry_throttler::{AdaptiveThrottler, SharedRetryThrottler},
21};
22use std::sync::{Arc, Mutex};
23
24#[derive(Clone, Debug)]
29pub struct RequestOptions {
30 pub(crate) retry_policy: Arc<dyn RetryPolicy>,
31 pub(crate) backoff_policy: Arc<dyn BackoffPolicy>,
32 pub(crate) retry_throttler: SharedRetryThrottler,
33 pub(crate) read_resume_policy: Arc<dyn ReadResumePolicy>,
34 pub(crate) resumable_upload_threshold: usize,
35 pub(crate) resumable_upload_buffer_size: usize,
36 pub(crate) idempotency: Option<bool>,
37 pub(crate) checksum: Checksum,
38 pub(crate) automatic_decompression: bool,
39}
40
41const MIB: usize = 1024 * 1024_usize;
42const RESUMABLE_UPLOAD_THRESHOLD: usize = 16 * MIB;
45const RESUMABLE_UPLOAD_TARGET_CHUNK: usize = 8 * MIB;
46
47impl RequestOptions {
48 pub(crate) fn new() -> Self {
49 let retry_policy = Arc::new(crate::retry_policy::storage_default());
50 let backoff_policy = Arc::new(crate::backoff_policy::default());
51 let retry_throttler = Arc::new(Mutex::new(AdaptiveThrottler::default()));
52 let read_resume_policy = Arc::new(Recommended);
53 Self {
54 retry_policy,
55 backoff_policy,
56 retry_throttler,
57 read_resume_policy,
58 resumable_upload_threshold: RESUMABLE_UPLOAD_THRESHOLD,
59 resumable_upload_buffer_size: RESUMABLE_UPLOAD_TARGET_CHUNK,
60 idempotency: None,
61 checksum: Checksum {
62 crc32c: Some(Crc32c::default()),
63 md5_hash: None,
64 },
65 automatic_decompression: false,
66 }
67 }
68}