summaryrefslogtreecommitdiff
path: root/cli/auth_tokens.rs
diff options
context:
space:
mode:
authorLuca Casonato <hello@lcas.dev>2024-08-22 15:14:50 +0200
committerGitHub <noreply@github.com>2024-08-22 15:14:50 +0200
commite7026c5ee8ac6780391b2169e338ca5fb5bbac70 (patch)
treefdb4ab1ae3a8a8aa3f96b0edb19c9189c96e2b77 /cli/auth_tokens.rs
parent9bc7de9b135cf92c7c4f041ad7901e9c3ba12004 (diff)
fix: trim space around DENO_AUTH_TOKENS (#25147)
Diffstat (limited to 'cli/auth_tokens.rs')
-rw-r--r--cli/auth_tokens.rs50
1 files changed, 42 insertions, 8 deletions
diff --git a/cli/auth_tokens.rs b/cli/auth_tokens.rs
index 42009ef27..ef9f9d074 100644
--- a/cli/auth_tokens.rs
+++ b/cli/auth_tokens.rs
@@ -123,19 +123,19 @@ impl AuthTokens {
pub fn new(maybe_tokens_str: Option<String>) -> Self {
let mut tokens = Vec::new();
if let Some(tokens_str) = maybe_tokens_str {
- for token_str in tokens_str.split(';') {
+ for token_str in tokens_str.trim().split(';') {
if token_str.contains('@') {
- let pair: Vec<&str> = token_str.rsplitn(2, '@').collect();
- let token = pair[1];
- let host = AuthDomain::from(pair[0]);
+ let mut iter = token_str.rsplitn(2, '@');
+ let host = AuthDomain::from(iter.next().unwrap());
+ let token = iter.next().unwrap();
if token.contains(':') {
- let pair: Vec<&str> = token.rsplitn(2, ':').collect();
- let username = pair[1].to_string();
- let password = pair[0].to_string();
+ let mut iter = token.rsplitn(2, ':');
+ let password = iter.next().unwrap().to_owned();
+ let username = iter.next().unwrap().to_owned();
tokens.push(AuthToken {
host,
token: AuthTokenData::Basic { username, password },
- })
+ });
} else {
tokens.push(AuthToken {
host,
@@ -212,6 +212,40 @@ mod tests {
}
#[test]
+ fn test_auth_tokens_space() {
+ let auth_tokens = AuthTokens::new(Some(
+ " abc123@deno.land;def456@example.com\t".to_string(),
+ ));
+ let fixture = resolve_url("https://deno.land/x/mod.ts").unwrap();
+ assert_eq!(
+ auth_tokens.get(&fixture).unwrap().to_string(),
+ "Bearer abc123".to_string()
+ );
+ let fixture = resolve_url("http://example.com/a/file.ts").unwrap();
+ assert_eq!(
+ auth_tokens.get(&fixture).unwrap().to_string(),
+ "Bearer def456".to_string()
+ );
+ }
+
+ #[test]
+ fn test_auth_tokens_newline() {
+ let auth_tokens = AuthTokens::new(Some(
+ "\nabc123@deno.land;def456@example.com\n".to_string(),
+ ));
+ let fixture = resolve_url("https://deno.land/x/mod.ts").unwrap();
+ assert_eq!(
+ auth_tokens.get(&fixture).unwrap().to_string(),
+ "Bearer abc123".to_string()
+ );
+ let fixture = resolve_url("http://example.com/a/file.ts").unwrap();
+ assert_eq!(
+ auth_tokens.get(&fixture).unwrap().to_string(),
+ "Bearer def456".to_string()
+ );
+ }
+
+ #[test]
fn test_auth_tokens_port() {
let auth_tokens =
AuthTokens::new(Some("abc123@deno.land:8080".to_string()));