Skip to content

Commit

Permalink
support setting server URL on either platform
Browse files Browse the repository at this point in the history
  • Loading branch information
gbj committed Jan 13, 2024
1 parent 30f3d67 commit d7755eb
Show file tree
Hide file tree
Showing 3 changed files with 38 additions and 22 deletions.
16 changes: 15 additions & 1 deletion server_fn/src/client.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,19 @@
use crate::{error::ServerFnError, request::ClientReq, response::ClientRes};
use std::future::Future;
use std::{future::Future, sync::OnceLock};

static ROOT_URL: OnceLock<&'static str> = OnceLock::new();

/// Set the root server URL that all server function paths are relative to for the client.
///
/// If this is not set, it defaults to the origin.
pub fn set_server_url(url: &'static str) {
ROOT_URL.set(url).unwrap();
}

/// Returns the root server URL for all server functions.
pub fn get_server_url() -> &'static str {
ROOT_URL.get().copied().unwrap_or("")
}

/// A client defines a pair of request/response types and the logic to send
/// and receive them.
Expand Down
27 changes: 22 additions & 5 deletions server_fn/src/request/browser.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
use super::ClientReq;
use crate::error::ServerFnError;
use crate::{client::get_server_url, error::ServerFnError};
use bytes::Bytes;
pub use gloo_net::http::Request;
use js_sys::Uint8Array;
Expand Down Expand Up @@ -35,7 +35,12 @@ impl<CustErr> ClientReq<CustErr> for BrowserRequest {
content_type: &str,
query: &str,
) -> Result<Self, ServerFnError<CustErr>> {
let mut url = path.to_owned();
let server_url = get_server_url();
let mut url = String::with_capacity(
server_url.len() + path.len() + 1 + query.len(),
);
url.push_str(server_url);
url.push_str(path);
url.push('?');
url.push_str(query);
Ok(Self(SendWrapper::new(
Expand All @@ -53,8 +58,12 @@ impl<CustErr> ClientReq<CustErr> for BrowserRequest {
content_type: &str,
body: String,
) -> Result<Self, ServerFnError<CustErr>> {
let server_url = get_server_url();
let mut url = String::with_capacity(server_url.len() + path.len());
url.push_str(server_url);
url.push_str(path);
Ok(Self(SendWrapper::new(
Request::post(path)
Request::post(&url)
.header("Content-Type", content_type)
.header("Accept", accepts)
.body(body)
Expand All @@ -68,10 +77,14 @@ impl<CustErr> ClientReq<CustErr> for BrowserRequest {
content_type: &str,
body: Bytes,
) -> Result<Self, ServerFnError<CustErr>> {
let server_url = get_server_url();
let mut url = String::with_capacity(server_url.len() + path.len());
url.push_str(server_url);
url.push_str(path);
let body: &[u8] = &body;
let body = Uint8Array::from(body).buffer();
Ok(Self(SendWrapper::new(
Request::post(path)
Request::post(&url)
.header("Content-Type", content_type)
.header("Accept", accepts)
.body(body)
Expand All @@ -84,8 +97,12 @@ impl<CustErr> ClientReq<CustErr> for BrowserRequest {
accepts: &str,
body: Self::FormData,
) -> Result<Self, ServerFnError<CustErr>> {
let server_url = get_server_url();
let mut url = String::with_capacity(server_url.len() + path.len());
url.push_str(server_url);
url.push_str(path);
Ok(Self(SendWrapper::new(
Request::post(path)
Request::post(&url)
.header("Accept", accepts)
.body(body.0.take())
.map_err(|e| ServerFnError::Request(e.to_string()))?,
Expand Down
17 changes: 1 addition & 16 deletions server_fn/src/request/reqwest.rs
Original file line number Diff line number Diff line change
@@ -1,26 +1,11 @@
use super::ClientReq;
use crate::error::ServerFnError;
use crate::{client::get_server_url, error::ServerFnError};
use bytes::Bytes;
use once_cell::sync::Lazy;
use reqwest::header::{ACCEPT, CONTENT_TYPE};
pub use reqwest::{multipart::Form, Client, Method, Request, Url};
use std::sync::OnceLock;

pub(crate) static CLIENT: Lazy<Client> = Lazy::new(Client::new);
static ROOT_URL: OnceLock<&'static str> = OnceLock::new();

/// Set the root server url that all server function paths are relative to for the client.
///
/// If this is not set, it defaults to the origin.
pub fn set_server_url(url: &'static str) {
ROOT_URL.set(url).unwrap();
}

fn get_server_url() -> &'static str {
ROOT_URL
.get()
.expect("Call `set_root_url` before calling a server function.")
}

impl<CustErr> ClientReq<CustErr> for Request {
type FormData = Form;
Expand Down

0 comments on commit d7755eb

Please sign in to comment.