#oauth

twapi-reqwest

Twitter OAuth library used by reqwest

9 releases

0.3.0 Feb 28, 2023
0.2.3 Aug 16, 2022
0.2.2 Sep 14, 2021
0.2.0 Mar 26, 2021
0.1.2 Feb 2, 2020

#316 in Authentication

Download history 252/week @ 2024-07-26 255/week @ 2024-08-02 150/week @ 2024-08-09 261/week @ 2024-08-16 249/week @ 2024-08-23 216/week @ 2024-08-30 220/week @ 2024-09-06 74/week @ 2024-09-13 231/week @ 2024-09-20 229/week @ 2024-09-27 129/week @ 2024-10-04 5/week @ 2024-10-11 196/week @ 2024-10-18 197/week @ 2024-10-25 293/week @ 2024-11-01 464/week @ 2024-11-08

1,151 downloads per month
Used in twapi

MIT/Apache

31KB
737 lines

twapi-reqwest-rs

Twitter OAuth library used by reqwest.

Documentation

Features

  • Async/Await
  • Application Only Authentication
  • User Authentication
  • Oauth1.0 Authentication
  • Oauth2.0 Authentication
  • JSON support(ex. dm_event, welcome_message, media_metadata, etc.)
  • Multipart support(ex. post_media_upload)

Changes

v0.3.0 (2023/02/28)

  • add timeout setting

v0.2.3 (2022/08/16)

  • support feature reqwest rustls-tls

v0.2.2 (2021/09/14)

  • oauth parse_oauth_body check response is_success

v0.2.1 (2021/09/14)

  • oauth parse_oauth_body add original body to HashMap

v0.2.0 (2021/03/26)

  • updated reqwest 0.11
  • add struct Client

Example

use twapi_reqwest::*;
use std::env;
use std::io::{BufReader, Cursor, Read};

#[tokio::main]
async fn main() {
    // OAuth2.0 Authentication
    let consumer_key = env::var("CONSUMER_KEY").unwrap();
    let consumer_secret = env::var("CONSUMER_SECRET").unwrap();
    let bearer_token = oauth::get_bearer_token(&consumer_key, &consumer_secret).await.unwrap().unwrap();

    // search(Application Only Authentication)
    let res: serde_json::Value = v2::get(
        "https://api.twitter.com/1.1/search/tweets.json",
        &vec![("q", "東京&埼玉"), ("count", "2")],
        &bearer_token,
        None,
    )
    .await
    .unwrap()
    .json()
    .await
    .unwrap();
    println!("{:?}", res);

    // OAuth1.0 Authentication
    let consumer_key = env::var("CONSUMER_KEY").unwrap();
    let consumer_secret = env::var("CONSUMER_SECRET").unwrap();
    let access_key = env::var("ACCESS_KEY").unwrap();
    let access_secret = env::var("ACCESS_SECRET").unwrap();

    // home_timeline
    let url = "https://api.twitter.com/1.1/statuses/home_timeline.json";
    let query_options = vec![("count", "2")];
    let res: serde_json::Value = v1::get(
        url,
        &query_options,
        &consumer_key,
        &consumer_secret,
        &access_key,
        &access_secret,
        None,
    )
    .await
    .unwrap()
    .json()
    .await
    .unwrap();
    println!("{:?}", res);

    // statuses/update
    let url = "https://api.twitter.com/1.1/statuses/update.json";
    let form_options = vec![
        ("status", "!\"'#$%&\\()+,/:;<=>?@[\\]^`{|}~;-._* 全部"),
        ("in_reply_to_status_id", "1178811297455935488"),
    ];
    let res: serde_json::Value = v1::post(
        url,
        &vec![],
        &form_options,
        &consumer_key,
        &consumer_secret,
        &access_key,
        &access_secret,
        None,
    )
    .await
    .unwrap()
    .json()
    .await
    .unwrap();
    println!("{:?}", res);

    // direct_messages new(JSON support)
    let url = "https://api.twitter.com/1.1/direct_messages/events/new.json";
    let data = r#"{
                "event": {
                    "type": "message_create",
                    "message_create": {
                        "target": {
                            "recipient_id": "19522946"
                        },
                        "message_data": {
                            "text": "予定表〜①ハンカクだ!"
                        }
                    }
                }
            }"#;
    let data: serde_json::Value = serde_json::from_str(data).unwrap();
    let res: serde_json::Value = v1::json(
        url,
        &vec![],
        &data,
        &consumer_key,
        &consumer_secret,
        &access_key,
        &access_secret,
        None,
    )
    .await
    .unwrap()
    .json()
    .await
    .unwrap();
    println!("{:?}", res);

    // media/upload(Multipart support)
    let metadata = std::fs::metadata("test.jpg").unwrap();
    let file_size = metadata.len();
    let f = std::fs::File::open("test.jpg").unwrap();
    let mut cursor = Cursor::new(vec![0; file_size as usize]);
    let mut reader = BufReader::new(f);
    reader.read(cursor.get_mut()).unwrap();

    let part = reqwest::multipart::Part::bytes(cursor.into_inner());
    let data = reqwest::multipart::Form::new().part("media", part);
    let url = "https://upload.twitter.com/1.1/media/upload.json";
    let res: serde_json::Value = v1::multipart(
        url,
        &vec![],
        data,
        &consumer_key,
        &consumer_secret,
        &access_key,
        &access_secret,
        None,
    )
    .await
    .unwrap()
    .json()
    .await
    .unwrap();
    println!("{:?}", res);
}

Dependencies

~10–24MB
~352K SLoC