Attribute Macro leptos_macro::server
source · #[server]Expand description
Declares that a function is a server function.
This means that its body will only run on the server, i.e., when the ssr feature is enabled.
If you call a server function from the client (i.e., when the csr or hydrate features
are enabled), it will instead make a network request to the server.
You can specify one, two, or three arguments to the server function:
- Required: A type name that will be used to identify and register the server function
(e.g.,
MyServerFn). - Optional: A URL prefix at which the function will be mounted when it’s registered
(e.g.,
"/api"). Defaults to"/". - Optional: either
"Cbor"(specifying that it should use the binarycborformat for serialization) or"Url"(specifying that it should be use a URL-encoded form-data string). Defaults to"Url". If you want to use this server function to power a<form>that will work without WebAssembly, the encoding must be"Url".
The server function itself can take any number of arguments, each of which should be serializable
and deserializable with serde. Optionally, its first argument can be a Leptos
Scope,
which will be injected on the server side. This can be used to inject the raw HTTP request or other
server-side context into the server function.
ⓘ
#[server(ReadPosts, "/api")]
pub async fn read_posts(how_many: u8, query: String) -> Result<Vec<Post>, ServerFnError> {
// do some work on the server to access the database
todo!()
}Note the following:
- You must register the server function by calling
T::register()somewhere in your main function. - Server functions must be
async. Even if the work being done inside the function body can run synchronously on the server, from the client’s perspective it involves an asynchronous function call. - Server functions must return
Result<T, ServerFnError>. Even if the work being done inside the function body can’t fail, the processes of serialization/deserialization and the network call are fallible. - Return types must be Serializable. This should be fairly obvious: we have to serialize arguments to send them to the server, and we need to deserialize the result to return it to the client.
- Arguments must be implement
SerializeandDeserializeOwned. They are serialized as anapplication/x-www-form-urlencodedform data usingserde_urlencodedor asapplication/cborusingcbor. - The
Scopecomes from the server. Optionally, the first argument of a server function can be a LeptosScope. This scope can be used to inject dependencies like the HTTP request or response or other server-only dependencies, but it does not have access to reactive state that exists in the client.