aboutsummaryrefslogtreecommitdiff
path: root/src/request.rs
diff options
context:
space:
mode:
Diffstat (limited to 'src/request.rs')
-rw-r--r--src/request.rs52
1 files changed, 8 insertions, 44 deletions
diff --git a/src/request.rs b/src/request.rs
index 97aa954..f1eb005 100644
--- a/src/request.rs
+++ b/src/request.rs
@@ -1,5 +1,5 @@
// This file is part of Germ <https://github.com/gemrest/germ>.
-// Copyright (C) 2022-2022 Fuwn <[email protected]>
+// Copyright (C) 2022-2023 Fuwn <[email protected]>
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
@@ -22,50 +22,14 @@ mod response;
mod status;
mod verifier;
-#[cfg(feature = "sync")] pub mod sync;
+#[cfg(feature = "blocking")]
+pub mod blocking;
+
+#[cfg(feature = "request")]
+pub mod non_blocking;
-use std::io::{Read, Write};
+#[cfg(feature = "request")]
+pub use non_blocking::request;
pub(crate) use verifier::GermVerifier;
pub use {response::Response, status::Status};
-
-/// Make a request to a Gemini server. The `url` **should** be prefixed with a
-/// scheme (e.g. "gemini://").
-///
-/// # Example
-///
-/// ```rust
-/// match germ::request::request(&url::Url::parse("gemini://fuwn.me").unwrap()) {
-/// Ok(response) => println!("{:?}", response),
-/// Err(_) => {}
-/// }
-/// ```
-///
-/// # Errors
-/// - May error if the URL is invalid
-/// - May error if the TLS write fails
-/// - May error if the TLS read fails
-pub fn request(url: &url::Url) -> anyhow::Result<Response> {
- let config = rustls::ClientConfig::builder()
- .with_safe_defaults()
- .with_custom_certificate_verifier(std::sync::Arc::new(GermVerifier::new()))
- .with_no_client_auth();
- let mut connection = rustls::ClientConnection::new(
- std::sync::Arc::new(config),
- url.domain().unwrap_or("").try_into()?,
- )?;
- let mut stream = std::net::TcpStream::connect(format!(
- "{}:{}",
- url.domain().unwrap_or(""),
- url.port().unwrap_or(1965)
- ))?;
- let mut tls = rustls::Stream::new(&mut connection, &mut stream);
-
- tls.write_all(format!("{url}\r\n").as_bytes())?;
-
- let mut plain_text = Vec::new();
-
- tls.read_to_end(&mut plain_text)?;
-
- Ok(Response::new(&plain_text, tls.conn.negotiated_cipher_suite()))
-}