Struct api_key_pool::APIKeyPool
source · pub struct APIKeyPool { /* private fields */ }Expand description
A pool of API keys.
Implementations§
source§impl APIKeyPool
impl APIKeyPool
sourcepub fn new() -> Self
pub fn new() -> Self
Returns an empty API key pool.
Examples found in repository?
examples/api-key-pool.rs (line 19)
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
async fn main() {
// Create a RateLimitPolicy to be applied to all API keys.
// Note: An APIPool can have APIKeys with different RateLimitPolicies.
// For the sake of simplicity, this example assumes identical policies.
let pol = RateLimitPolicy::new(1, Duration::seconds(2));
// Create the APIKeys.
let api1 = APIKey::new("1", pol);
let api2 = APIKey::new("2", pol);
let api3 = APIKey::new("3", pol);
// Create the APIKeyPool.
let mut pool = APIKeyPool::new();
pool.add_key(api1).await;
pool.add_key(api2).await;
pool.add_key(api3).await;
// Simulate 20 requests.
let mut ctr = 0;
while ctr < 20 {
// Use the APIKey if available (according to its respective RateLimitPolicy) or sleep.
if let Some(key) = pool.poll_for_key().await {
println!("{}", key);
ctr += 1;
} else {
println!("Have to sleep.");
time::sleep(time::Duration::from_millis(500)).await;
}
}
}sourcepub async fn add_key(&mut self, key: APIKey)
pub async fn add_key(&mut self, key: APIKey)
Examples found in repository?
examples/api-key-pool.rs (line 20)
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
async fn main() {
// Create a RateLimitPolicy to be applied to all API keys.
// Note: An APIPool can have APIKeys with different RateLimitPolicies.
// For the sake of simplicity, this example assumes identical policies.
let pol = RateLimitPolicy::new(1, Duration::seconds(2));
// Create the APIKeys.
let api1 = APIKey::new("1", pol);
let api2 = APIKey::new("2", pol);
let api3 = APIKey::new("3", pol);
// Create the APIKeyPool.
let mut pool = APIKeyPool::new();
pool.add_key(api1).await;
pool.add_key(api2).await;
pool.add_key(api3).await;
// Simulate 20 requests.
let mut ctr = 0;
while ctr < 20 {
// Use the APIKey if available (according to its respective RateLimitPolicy) or sleep.
if let Some(key) = pool.poll_for_key().await {
println!("{}", key);
ctr += 1;
} else {
println!("Have to sleep.");
time::sleep(time::Duration::from_millis(500)).await;
}
}
}sourcepub async fn poll_for_key(&mut self) -> Option<String>
pub async fn poll_for_key(&mut self) -> Option<String>
Checks the API key pool for any available API keys, and returns the API key if available.
Examples found in repository?
examples/api-key-pool.rs (line 28)
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
async fn main() {
// Create a RateLimitPolicy to be applied to all API keys.
// Note: An APIPool can have APIKeys with different RateLimitPolicies.
// For the sake of simplicity, this example assumes identical policies.
let pol = RateLimitPolicy::new(1, Duration::seconds(2));
// Create the APIKeys.
let api1 = APIKey::new("1", pol);
let api2 = APIKey::new("2", pol);
let api3 = APIKey::new("3", pol);
// Create the APIKeyPool.
let mut pool = APIKeyPool::new();
pool.add_key(api1).await;
pool.add_key(api2).await;
pool.add_key(api3).await;
// Simulate 20 requests.
let mut ctr = 0;
while ctr < 20 {
// Use the APIKey if available (according to its respective RateLimitPolicy) or sleep.
if let Some(key) = pool.poll_for_key().await {
println!("{}", key);
ctr += 1;
} else {
println!("Have to sleep.");
time::sleep(time::Duration::from_millis(500)).await;
}
}
}Trait Implementations§
source§impl Default for APIKeyPool
impl Default for APIKeyPool
source§fn default() -> APIKeyPool
fn default() -> APIKeyPool
Returns the “default value” for a type. Read more
Auto Trait Implementations§
impl !RefUnwindSafe for APIKeyPool
impl Send for APIKeyPool
impl Sync for APIKeyPool
impl Unpin for APIKeyPool
impl !UnwindSafe for APIKeyPool
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more