-
Notifications
You must be signed in to change notification settings - Fork 10
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* Update online example * Fix string name * Make linter happy * Update examples and add cookie examples * Run cargo fmt * Implement feedback * Run cargo fmt
- Loading branch information
1 parent
402dddb
commit 2b1bd59
Showing
4 changed files
with
185 additions
and
25 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,39 @@ | ||
use reqwest::cookie::CookieStore; | ||
use reqwest::header::HeaderValue; | ||
use std::str::FromStr; | ||
use std::sync::Arc; | ||
pub use vrchatapi::apis; | ||
use vrchatapi::models::EitherUserOrTwoFactor; | ||
|
||
#[tokio::main] | ||
async fn main() { | ||
let mut config = apis::configuration::Configuration::default(); | ||
config.basic_auth = Some((String::from("username"), Some(String::from("password")))); | ||
config.user_agent = Some(String::from("ProjectName/0.0.1 [email protected]")); | ||
|
||
let mut jar = reqwest::cookie::Jar::default(); | ||
jar.set_cookies( | ||
&mut [HeaderValue::from_str( | ||
&"auth=[AUTH_COOKIE_HERE], twoFactorAuth=[TWO_FACTOR_AUTH_COOKIE_HERE]", | ||
) | ||
.expect("Cookie not okay")] | ||
.iter(), | ||
&url::Url::from_str("https://api.vrchat.cloud").expect("Url not okay"), | ||
); | ||
let jar = Arc::new(jar); | ||
|
||
config.client = reqwest::Client::builder() | ||
.cookie_store(true) | ||
.cookie_provider(jar) | ||
.build() | ||
.unwrap(); | ||
|
||
let user = apis::authentication_api::get_current_user(&config) | ||
.await | ||
.unwrap(); | ||
|
||
match user { | ||
EitherUserOrTwoFactor::CurrentUser(user) => println!("Current user: {}", user.display_name), | ||
EitherUserOrTwoFactor::RequiresTwoFactorAuth(_) => println!("cookie invalid"), | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,83 @@ | ||
use reqwest::cookie::CookieStore; | ||
use std::io::{self, Write}; | ||
use std::str::FromStr; | ||
use url::Url; | ||
pub use vrchatapi::apis; | ||
use vrchatapi::models::{EitherUserOrTwoFactor, TwoFactorAuthCode, TwoFactorEmailCode}; | ||
|
||
#[tokio::main] | ||
async fn main() { | ||
let mut config = apis::configuration::Configuration::default(); | ||
config.basic_auth = Some((String::from("username"), Some(String::from("password")))); | ||
config.user_agent = Some(String::from("ProjectName/0.0.1 [email protected]")); | ||
|
||
let cookie_store = std::sync::Arc::new(reqwest::cookie::Jar::default()); | ||
config.client = reqwest::Client::builder() | ||
.cookie_store(true) | ||
.cookie_provider(cookie_store.clone()) | ||
.build() | ||
.unwrap(); | ||
|
||
match apis::authentication_api::get_current_user(&config) | ||
.await | ||
.unwrap() | ||
{ | ||
vrchatapi::models::EitherUserOrTwoFactor::CurrentUser(me) => { | ||
println!("Username: {}", me.username.unwrap()) | ||
} | ||
vrchatapi::models::EitherUserOrTwoFactor::RequiresTwoFactorAuth(requires_auth) => { | ||
if requires_auth | ||
.requires_two_factor_auth | ||
.contains(&String::from("emailOtp")) | ||
{ | ||
let code = read_user_input("Please enter your Email 2fa code: "); | ||
if let Err(err) = apis::authentication_api::verify2_fa_email_code( | ||
&config, | ||
TwoFactorEmailCode::new(code), | ||
) | ||
.await | ||
{ | ||
eprintln!("Error verifying 2FA email code: {}", err); | ||
} | ||
} else { | ||
let code = read_user_input("Please enter your Authenticator 2fa code: "); | ||
if let Err(err) = | ||
apis::authentication_api::verify2_fa(&config, TwoFactorAuthCode::new(code)) | ||
.await | ||
{ | ||
eprintln!("Error verifying 2FA auth code: {}", err); | ||
} | ||
} | ||
} | ||
} | ||
|
||
let user = apis::authentication_api::get_current_user(&config) | ||
.await | ||
.unwrap(); | ||
|
||
match user { | ||
EitherUserOrTwoFactor::CurrentUser(user) => println!("Current user: {}", user.display_name), | ||
EitherUserOrTwoFactor::RequiresTwoFactorAuth(_) => println!("cookie invalid"), | ||
} | ||
|
||
println!( | ||
"Cookie:{}", | ||
cookie_store | ||
.cookies(&Url::from_str("https://api.vrchat.cloud").expect("Url not okay")) | ||
.expect("Cookies not found") | ||
.to_str() | ||
.expect("Cookies not valid string") | ||
); | ||
} | ||
|
||
fn read_user_input(prompt: &str) -> String { | ||
print!("{}", prompt); | ||
io::stdout().flush().expect("Failed to flush stdout"); | ||
|
||
let mut input = String::new(); | ||
io::stdin() | ||
.read_line(&mut input) | ||
.expect("Failed to read line"); | ||
|
||
input.trim().to_string() | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,63 @@ | ||
use std::io::{self, Write}; | ||
pub use vrchatapi::apis; | ||
use vrchatapi::models::{EitherUserOrTwoFactor, TwoFactorAuthCode, TwoFactorEmailCode}; | ||
|
||
#[tokio::main] | ||
async fn main() { | ||
let mut config = apis::configuration::Configuration::default(); | ||
config.basic_auth = Some((String::from("username"), Some(String::from("password")))); | ||
config.user_agent = Some(String::from("ProjectName/0.0.1 [email protected]")); | ||
match apis::authentication_api::get_current_user(&config) | ||
.await | ||
.unwrap() | ||
{ | ||
vrchatapi::models::EitherUserOrTwoFactor::CurrentUser(me) => { | ||
println!("Username: {}", me.username.unwrap()) | ||
} | ||
vrchatapi::models::EitherUserOrTwoFactor::RequiresTwoFactorAuth(requires_auth) => { | ||
if requires_auth | ||
.requires_two_factor_auth | ||
.contains(&String::from("emailOtp")) | ||
{ | ||
let code = read_user_input("Please enter your Email 2fa code: "); | ||
if let Err(err) = apis::authentication_api::verify2_fa_email_code( | ||
&config, | ||
TwoFactorEmailCode::new(code), | ||
) | ||
.await | ||
{ | ||
eprintln!("Error verifying 2FA email code: {}", err); | ||
} | ||
} else { | ||
let code = read_user_input("Please enter your Authenticator 2fa code: "); | ||
if let Err(err) = | ||
apis::authentication_api::verify2_fa(&config, TwoFactorAuthCode::new(code)) | ||
.await | ||
{ | ||
eprintln!("Error verifying 2FA auth code: {}", err); | ||
} | ||
} | ||
} | ||
} | ||
|
||
let user = apis::authentication_api::get_current_user(&config) | ||
.await | ||
.unwrap(); | ||
|
||
match user { | ||
EitherUserOrTwoFactor::CurrentUser(user) => println!("Current user: {}", user.display_name), | ||
EitherUserOrTwoFactor::RequiresTwoFactorAuth(_) => println!("cookie invalid"), | ||
} | ||
} | ||
|
||
fn read_user_input(prompt: &str) -> String { | ||
print!("{}", prompt); | ||
io::stdout().flush().expect("Failed to flush stdout"); | ||
|
||
let mut input = String::new(); | ||
io::stdin() | ||
.read_line(&mut input) | ||
.expect("Failed to read line"); | ||
|
||
input.trim().to_string() | ||
} |
This file was deleted.
Oops, something went wrong.