1
 2
 3
 4
 5
 6
 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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
#![allow(unknown_lints)] // remove once broken_intra_doc_links is on stable
#![deny(missing_docs, broken_intra_doc_links)]
#![doc(html_root_url = "https://docs.rs/twitch_api2/0.4.0")]
//! [![github]](https://github.com/emilgardis/twitch_utils) [![crates-io]](https://crates.io/crates/twitch_api2) [![docs-rs]](https://docs.rs/twitch_api2/0.4.0/twitch_api2)
//!
//! [github]: https://img.shields.io/badge/github-emilgardis/twitch__utils-8da0cb?style=for-the-badge&labelColor=555555&logo=github"
//! [crates-io]: https://img.shields.io/crates/v/twitch_api2.svg?style=for-the-badge&color=fc8d62&logo=rust"
//! [docs-rs]: https://img.shields.io/badge/docs.rs-twitch__api2-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo="
//!
//! <br>
//!
//! <h5>Rust library for talking with the new Twitch API aka. "Helix" and TMI. Use Twitch endpoints fearlessly!</h5>
//!
//! # Examples
//!
//! ```rust,no_run
//! use twitch_api2::{Client, helix::channels::GetChannelInformationRequest};
//! use twitch_oauth2::{AppAccessToken, Scope, TokenError, TwitchToken};
//!
//! # #[tokio::main]
//! # async fn main() -> Result<(), Box<dyn std::error::Error + 'static>> {
//! # let client_id = twitch_oauth2::ClientId::new("validclientid".to_string());
//! # let client_secret = twitch_oauth2::ClientSecret::new("validclientsecret".to_string());
//! let token =
//!     match AppAccessToken::get_app_access_token(client_id, client_secret, Scope::all()).await {
//!         Ok(t) => t,
//!         Err(TokenError::RequestError(e)) => panic!("got error: {:?}", e),
//!         Err(e) => panic!(e),
//!     };
//! let client = Client::new();
//! let req = GetChannelInformationRequest::builder()
//!     .broadcaster_id("27620241")
//!     .build();
//!
//! println!("{:?}", &client.helix.req_get(req, &token).await?.data[0].title);
//! # Ok(())
//! # }
//! ```

#[cfg(feature = "helix")]
#[doc(no_inline)]
pub use crate::helix::HelixClient;
#[cfg(feature = "tmi")]
#[doc(no_inline)]
pub use crate::tmi::TMIClient;

#[cfg(feature = "helix")]
#[doc(no_inline)]
pub use twitch_oauth2;

#[cfg(feature = "helix")]
pub mod helix;
#[cfg(feature = "tmi")]
pub mod tmi;

#[cfg(feature = "helix")]
static TWITCH_HELIX_URL: &str = "https://api.twitch.tv/helix/";
#[cfg(feature = "tmi")]
static TWITCH_TMI_URL: &str = "https://tmi.twitch.tv/";

/// Client for Twitch APIs.
#[derive(Clone, Default)]
#[non_exhaustive]
pub struct Client {
    /// Helix endpoint. See [helix]
    #[cfg(feature = "helix")]
    pub helix: HelixClient,
    /// TMI endpoint. See [tmi]
    #[cfg(feature = "tmi")]
    pub tmi: TMIClient,
}

impl Client {
    /// Create a new [Client]
    #[cfg(all(feature = "helix", feature = "tmi"))]
    pub fn new() -> Client {
        let helix = HelixClient::new();
        Client {
            tmi: TMIClient::with_client(helix.clone_client()),
            helix,
        }
    }
}