# Twitch API | Rust library for talking with the new Twitch API aka. "Helix", EventSub and more! [![github]](https://github.com/twitch-rs/twitch_api) [![crates-io]](https://crates.io/crates/twitch_api) [![docs-rs-big]](https://docs.rs/twitch_api/0.7.0-rc.7/twitch_api/) [![discord]](https://discord.gg/7APWQeEmnK) [github]: https://img.shields.io/badge/github-twitch--rs/twitch__api-8da0cb?style=for-the-badge&labelColor=555555&logo=github [crates-io]: https://img.shields.io/crates/v/twitch_api.svg?style=for-the-badge&color=fc8d62&logo=rust [docs-rs-big]: https://img.shields.io/badge/docs.rs-twitch__api2-66c2a5?style=for-the-badge&labelColor=555555&logoColor=white&logo= [discord]: https://img.shields.io/discord/325552783787032576?logo=discord&style=for-the-badge See [documentation](https://docs.rs/twitch_api) for more info. You can see current unpublished docs for the main branch here: [![local-docs]](https://twitch-rs.github.io/twitch_api/twitch_api) See [examples](./examples) for examples. If you want to run them locally, make sure you [get the git submodules](./CONTRIBUTING.md#fetching-the-git-submodules) first. [local-docs]: https://img.shields.io/github/actions/workflow/status/twitch-rs/twitch_api/gh-pages.yml?label=dev%20docs&style=flat-square&event=push ```rust ,no_run use twitch_api::helix::HelixClient; use twitch_api::twitch_oauth2::{AccessToken, UserToken}; #[tokio::main] async fn main() -> Result<(), Box> { // Create the HelixClient, which is used to make requests to the Twitch API let client: HelixClient = HelixClient::default(); // Create a UserToken, which is used to authenticate requests let token = UserToken::from_token(&client, AccessToken::from("mytoken")).await?; println!( "Channel: {:?}", client.get_channel_from_login("twitchdev", &token).await? ); Ok(()) } ``` ## Notes This crate was previously available as `twitch_api2` and has since been renamed to `twitch_api` ## Goals This crate aims to target - [Helix](https://dev.twitch.tv/docs/api/reference) - See [implemented endpoints](https://github.com/twitch-rs/twitch_api/wiki/Implemented-Features#helix) - [EventSub](https://dev.twitch.tv/docs/eventsub/eventsub-reference) - See [implemented eventsub Helix endpoints](https://github.com/twitch-rs/twitch_api/wiki/Implemented-Features#eventsub) - [PubSub](https://dev.twitch.tv/docs/pubsub) (without a client) - See [implemented topics](https://github.com/twitch-rs/twitch_api/wiki/Implemented-Features#pubsub) - PubSub is planned to be deprecated, with a EventSub websocket implementation - [Extensions](https://dev.twitch.tv/docs/extensions/reference) - No functionality implemented yet This crate should also be able to be used for There are no current plans to support - [GraphQL](https://github.com/mauricew/twitch-graphql-api) - [Drops](https://dev.twitch.tv/docs/drops) (except what is in Helix) - [Twitch IRC Chat](https://dev.twitch.tv/docs/irc), use [museun/twitch_message](https://github.com/museun/twitch_message) or [robotty/twitch-irc](https://github.com/robotty/twitch-irc-rs/) - [Authentication](https://dev.twitch.tv/docs/authentication), use [twitch-rs/twitch_oauth2](https://github.com/twitch-rs/twitch_oauth2) - Undocumented Helix endpoints, i.e endpoints mobile Twitch app uses. Including [working "hidden" endpoints](https://thomassen.sh/twitch-api-endpoints/)
License
Licensed under either of Apache License, Version 2.0 or MIT license at your option.
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in this crate by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.