mirror of https://github.com/MingweiSamuel/Riven
first request made :)
parent
d8d2492c93
commit
ee75f75e0c
|
@ -16,3 +16,4 @@ async-std = "0.99"
|
||||||
parking_lot = { version = "0.9", features = [ "nightly" ] }
|
parking_lot = { version = "0.9", features = [ "nightly" ] }
|
||||||
reqwest = { version = "0.10.0-alpha.1", features = [ "gzip", "json" ] }
|
reqwest = { version = "0.10.0-alpha.1", features = [ "gzip", "json" ] }
|
||||||
serde = "^1.0"
|
serde = "^1.0"
|
||||||
|
tokio = "0.2.0-alpha.6"
|
||||||
|
|
|
@ -11,7 +11,7 @@ macro_rules! regions {
|
||||||
)*
|
)*
|
||||||
) => {
|
) => {
|
||||||
$(
|
$(
|
||||||
const $key: &'static Region<'static> = &Region {
|
pub const $key: &'static Region<'static> = &Region {
|
||||||
key: stringify!($key),
|
key: stringify!($key),
|
||||||
platform: $plat,
|
platform: $plat,
|
||||||
};
|
};
|
||||||
|
|
22
src/lib.rs
22
src/lib.rs
|
@ -2,14 +2,32 @@
|
||||||
|
|
||||||
pub mod consts;
|
pub mod consts;
|
||||||
|
|
||||||
|
mod riot_api_config;
|
||||||
|
pub use riot_api_config::*;
|
||||||
|
|
||||||
|
mod riot_api;
|
||||||
|
pub use riot_api::*;
|
||||||
|
|
||||||
mod req;
|
mod req;
|
||||||
mod util;
|
mod util;
|
||||||
mod riot_api_config;
|
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
|
use tokio::runtime::Runtime;
|
||||||
|
use super::*;
|
||||||
|
|
||||||
|
const api_key: &'static str = "RGAPI-nothinghereowo";
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn it_works() {
|
fn it_works() {
|
||||||
assert_eq!(2 + 2, 4);
|
let rt = Runtime::new().unwrap();
|
||||||
|
let riot_api = RiotApi::with_key(api_key);
|
||||||
|
|
||||||
|
// https://na1.api.riotgames.com/lol/champion-mastery/v4/scores/by-summoner/SBM8Ubipo4ge2yj7bhEzL7yvV0C9Oc1XA2l6v5okGMA_nCw
|
||||||
|
let my_future = riot_api.get::<u32>("asdf", consts::Region::NA,
|
||||||
|
"/lol/champion-mastery/v4/scores/by-summoner/SBM8Ubipo4ge2yj7bhEzL7yvV0C9Oc1XA2l6v5okGMA_nCw",
|
||||||
|
&[]);
|
||||||
|
let val = rt.block_on(my_future).unwrap();
|
||||||
|
println!("VAL: {}", val.unwrap());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -69,7 +69,8 @@ impl RateLimit {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn on_response(&self, _response: &reqwest::Response) {
|
pub fn on_response(&self, _response: &reqwest::Response) {
|
||||||
unimplemented!();
|
return;
|
||||||
|
// TODO!!!!!!!!!!
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
use std::collections::HashMap;
|
use std::collections::HashMap;
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
|
||||||
use reqwest::{
|
use reqwest::Client;
|
||||||
Client,
|
|
||||||
};
|
|
||||||
|
|
||||||
use crate::riot_api_config::RiotApiConfig;
|
use crate::riot_api_config::RiotApiConfig;
|
||||||
use crate::consts::Region;
|
use crate::consts::Region;
|
||||||
|
@ -13,16 +11,18 @@ use super::RegionalRequester;
|
||||||
|
|
||||||
pub struct RequesterManager<'a> {
|
pub struct RequesterManager<'a> {
|
||||||
/// Configuration settings.
|
/// Configuration settings.
|
||||||
riot_api_config: &'a RiotApiConfig<'a>,
|
riot_api_config: RiotApiConfig<'a>,
|
||||||
/// Client for making requests.
|
/// Client for making requests.
|
||||||
client: &'a Client,
|
client: Client,
|
||||||
|
|
||||||
/// Per-region requesters.
|
/// Per-region requesters.
|
||||||
regional_requesters: InsertOnlyCHashMap<&'a Region<'a>, RegionalRequester<'a>>,
|
regional_requesters: InsertOnlyCHashMap<&'a Region<'a>, RegionalRequester<'a>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl<'a> RequesterManager<'a> {
|
impl<'a> RequesterManager<'a> {
|
||||||
pub fn new(riot_api_config: &'a RiotApiConfig<'a>, client: &'a Client) -> Self {
|
pub fn new(riot_api_config: RiotApiConfig<'a>) -> Self {
|
||||||
|
// TODO client.
|
||||||
|
let client = Client::new();
|
||||||
Self {
|
Self {
|
||||||
riot_api_config: riot_api_config,
|
riot_api_config: riot_api_config,
|
||||||
client: client,
|
client: client,
|
||||||
|
@ -31,11 +31,12 @@ impl<'a> RequesterManager<'a> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub async fn get<T: serde::de::DeserializeOwned>(
|
pub async fn get<T: serde::de::DeserializeOwned>(
|
||||||
&mut self, method_id: &'a str, region: &'a Region<'a>, relative_url: &'_ str,
|
&'a self, method_id: &'a str, region: &'a Region<'a>, relative_url: &'_ str,
|
||||||
query: &[(&'_ str, &'_ str)]) -> Result<Option<T>, reqwest::Error>
|
query: &[(&'_ str, &'_ str)]) -> Result<Option<T>, reqwest::Error>
|
||||||
{
|
{
|
||||||
|
// TODO: max concurrent requests?
|
||||||
let regional_requester = self.regional_requesters
|
let regional_requester = self.regional_requesters
|
||||||
.get_or_insert_with(region, || RegionalRequester::new(self.riot_api_config, self.client));
|
.get_or_insert_with(region, || RegionalRequester::new(&self.riot_api_config, &self.client));
|
||||||
regional_requester.get(method_id, region, relative_url, query).await
|
regional_requester.get(method_id, region, relative_url, query).await
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
use crate::RiotApiConfig;
|
||||||
|
use crate::consts::Region;
|
||||||
|
use crate::req::RequesterManager;
|
||||||
|
|
||||||
|
pub struct RiotApi<'a> {
|
||||||
|
requester_manager: RequesterManager<'a>,
|
||||||
|
}
|
||||||
|
|
||||||
|
impl<'a> RiotApi<'a> {
|
||||||
|
pub fn with_config(config: RiotApiConfig<'a>) -> Self {
|
||||||
|
Self {
|
||||||
|
requester_manager: RequesterManager::new(config),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn with_key(api_key: &'a str) -> Self {
|
||||||
|
Self::with_config(RiotApiConfig::with_key(api_key))
|
||||||
|
}
|
||||||
|
|
||||||
|
pub async fn get<T: serde::de::DeserializeOwned>(
|
||||||
|
&'a self, method_id: &'a str, region: &'a Region<'a>, relative_url: &'_ str,
|
||||||
|
query: &[(&'_ str, &'_ str)]) -> Result<Option<T>, reqwest::Error>
|
||||||
|
{
|
||||||
|
self.requester_manager.get(method_id, region, relative_url, query).await
|
||||||
|
}
|
||||||
|
}
|
|
@ -2,3 +2,12 @@ pub struct RiotApiConfig<'a> {
|
||||||
pub api_key: &'a str,
|
pub api_key: &'a str,
|
||||||
pub retries: u8,
|
pub retries: u8,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl<'a> RiotApiConfig<'a> {
|
||||||
|
pub fn with_key(api_key: &'a str) -> Self {
|
||||||
|
Self {
|
||||||
|
api_key: api_key,
|
||||||
|
retries: 3 // TODO defaults.
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue