From 96715ceb58b24ee7220d98e421701daa550f44db Mon Sep 17 00:00:00 2001 From: David Blajda Date: Sun, 3 Feb 2019 22:30:15 +0000 Subject: Add Helix and Kraken scopes. Client Config and allow injecting of responses --- src/kraken/mod.rs | 26 +++++++++++++++++++++++--- 1 file changed, 23 insertions(+), 3 deletions(-) (limited to 'src/kraken/mod.rs') diff --git a/src/kraken/mod.rs b/src/kraken/mod.rs index fbec045..4046377 100644 --- a/src/kraken/mod.rs +++ b/src/kraken/mod.rs @@ -1,7 +1,10 @@ use crate::client::Client as GenericClient; -use crate::client::Version; +use crate::client::{Version, ClientConfig}; +use crate::client::ClientTrait; pub use super::types; +use crate::client::{KrakenScope, Scope}; + mod namespaces; pub mod models; @@ -12,17 +15,34 @@ pub struct Client { impl Client { pub fn new(id: &str) -> Client { + let config = ClientConfig::default(); + Client { + inner: GenericClient::new(id, config, Version::Kraken) + } + } + + pub fn new_with_config(id: &str, config: ClientConfig) -> Client { Client { - inner: GenericClient::new(id, Version::Kraken) + inner: GenericClient::new(id, config, Version::Kraken) } } pub fn authenticate(self, secret: &str) -> AuthClientBuilder { AuthClientBuilder::new(self, secret) } + + pub fn id<'a>(&'a self) -> &'a str { &self.inner.id() } + pub fn domain<'a>(&'a self) -> &'a str { &self.inner.domain() } + pub fn auth_domain<'a>(&'a self) -> &'a str { &self.inner.auth_domain() } + pub fn authenticated(&self) -> bool { self.inner.authenticated() } + + pub fn scopes(&self) -> Vec { + self.inner.scopes().into_iter().filter_map(|item| { + if let Scope::Kraken(scope) = item { Some(scope) } else { None } + }).collect() + } } -use crate::client::Scope; use crate::client::AuthClientBuilder as GenericAuthClientBuilder; pub struct AuthClientBuilder { -- cgit v1.2.3