Skip to content

Commit

Permalink
docs(bl): added more docs to bl crate
Browse files Browse the repository at this point in the history
  • Loading branch information
johnbchron committed Apr 4, 2024
1 parent ca4ae65 commit 20a195b
Show file tree
Hide file tree
Showing 6 changed files with 67 additions and 5 deletions.
13 changes: 13 additions & 0 deletions crates/bl/src/fetch.rs
Original file line number Diff line number Diff line change
@@ -1,6 +1,13 @@
//! Fetcher logic.
//!
//! This module is used mostly for first-party fetchers. If you need to fetch
//! something from the database, it should go here.
use core_types::{PhotoGroup, PhotoThumbnailDisplayParams};
use leptos::{server, server_fn::codec::Json, ServerFnError};

/// Fetches all the [`PhotoGroup`]s owned by a
/// [`User`](core_types::UserRecordId).
#[server(
input = Json,
output = Json,
Expand Down Expand Up @@ -35,6 +42,8 @@ pub async fn fetch_user_owned_photo_groups(
.map_err(|e: Report| crate::handle_error(e, "fetch user owned photo groups"))
}

/// Fetches a [`PhotoGroup`] given its
/// [`PhotoGroupRecordId`](core_types::PhotoGroupRecordId).
#[server(
input = Json,
output = Json,
Expand All @@ -61,6 +70,8 @@ pub async fn fetch_photo_group(
.map_err(|e: Report| crate::handle_error(e, "fetch photo group"))
}

/// Fetches a [`PublicUser`](core_types::PublicUser) given its
/// [`UserRecordId`](core_types::UserRecordId).
#[server(
input = Json,
output = Json,
Expand All @@ -86,6 +97,8 @@ pub async fn fetch_user(
.map_err(|e: Report| crate::handle_error(e, "fetch user"))
}

/// Fetches a photo thumbnail ([`PhotoThumbnailDisplayParams`]) given its
/// [`PhotoRecordId`](core_types::PhotoRecordId).
#[server(
input = Json,
output = Json,
Expand Down
29 changes: 28 additions & 1 deletion crates/bl/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,25 @@
#![warn(missing_docs)]

//! The `bl` crate is for business logic. Any arbitrary code that needs to run
//! on the server should be in the `bl` crate. Modules are based on semantic
//! divisions between functionality.
//!
//! ## Server Functions
//! Most of the logic here exists in the form of a server function. For this
//! reason, like other crates in picturepro, this crate has `hydrate` and `ssr`
//! features. If you add a dependency, 90% it should only exist under the `ssr`
//! feature. Only if you really need to pass a type through the API boundary
//! (over HTTP), or the crate is mostly/all macros (like [`thiserror`]), should
//! you add your dependency under the `hydrate` feature as well.
//!
//! ## Errors
//! This crate provides a [`handle_error`] method that consumes an
//! [`eyre::Report`](color_eyre::eyre::Report), properly handles it, and returns
//! a [`ServerFnError`]. It's best used by enclosing the main logic in an async
//! block (in which you use the `?` sugar), immediately awaiting the async
//! block, and then using `.map_err(|e| crate::handle_error(e, "generate
//! qr-code"))`.
pub mod fetch;
#[cfg(feature = "ssr")]
pub mod model_ext;
Expand All @@ -8,11 +30,16 @@ pub mod upload;
#[cfg(feature = "ssr")]
use leptos::ServerFnError;

/// Consumes a [`eyre::Report`](color_eyre::eyre::Report), properly handles it,
/// and returns a [`ServerFnError`].
///
/// The `failed_action` parameter only used for identifying the error context in
/// logs, and it's interpolated as `"Failed to {failed_action}: {error:?}"`.
#[cfg(feature = "ssr")]
pub fn handle_error(
error: color_eyre::eyre::Report,
failed_action: &'static str,
) -> ServerFnError {
tracing::error!("Failed to {}: {:?}", failed_action, &error);
tracing::error!("Failed to {failed_action}: {error:?}");
ServerFnError::new(error)
}
17 changes: 13 additions & 4 deletions crates/bl/src/model_ext.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,16 @@
//! Provides [`ModelExt`], an extension of the [`CoreModel`] trait.
use clients::surreal::SurrealRootClient;
use color_eyre::eyre::{OptionExt, Result};
use core_types::{CoreId, CoreModel};

pub trait ModelExt: core_types::CoreModel {
/// Provides [`fetch`](ModelExt::fetch), [`create`](ModelExt::create), and
/// [`patch`](ModelExt::patch) methods for interfacing with Surreal for a given
/// model.
pub trait ModelExt: CoreModel {
/// Fetches the model from Surreal given its [`CoreModel::Id`].
fn fetch(
id: <Self as core_types::CoreModel>::Id,
id: <Self as CoreModel>::Id,
client: &SurrealRootClient,
) -> impl std::future::Future<Output = Result<Option<Self>>> + Send {
async move {
Expand All @@ -13,6 +19,7 @@ pub trait ModelExt: core_types::CoreModel {
}
}

/// Pushes a model instance to Surreal, and returns the pushed version.
fn create(
&self,
client: &SurrealRootClient,
Expand All @@ -31,8 +38,10 @@ pub trait ModelExt: core_types::CoreModel {
}
}

/// Patches a model in Surreal using its [`CoreModel::Id`] and a
/// [`PatchOp`](surrealdb::opt::PatchOp).
fn patch(
id: <Self as core_types::CoreModel>::Id,
id: <Self as CoreModel>::Id,
client: &SurrealRootClient,
patch: surrealdb::opt::PatchOp,
) -> impl std::future::Future<Output = Result<Self>> + Send {
Expand All @@ -43,4 +52,4 @@ pub trait ModelExt: core_types::CoreModel {
}
}

impl<T: core_types::CoreModel> ModelExt for T {}
impl<T: CoreModel> ModelExt for T {}
3 changes: 3 additions & 0 deletions crates/bl/src/qr_code.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//! QR-code logic.
use leptos::{server, server_fn::codec::Json, ServerFnError};

/// Generate a QR code from the given data. Returns base64 encoded PNG data.
Expand All @@ -21,6 +23,7 @@ pub fn generate_qr_code_inner(data: &str) -> color_eyre::eyre::Result<String> {
Ok(data)
}

/// Generates a QR-code from arbitrary data.
#[server(
input = Json,
output = Json,
Expand Down
2 changes: 2 additions & 0 deletions crates/bl/src/rmp_sfn.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//! A custom implementation of using messagepack as a leptos codec.
use http::Method;
use leptos::server_fn::{
codec::{Encoding, FromReq, FromRes, IntoReq, IntoRes},
Expand Down
8 changes: 8 additions & 0 deletions crates/bl/src/upload/mod.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
//! Photo upload logic.
#[cfg(feature = "ssr")]
mod exif_ops;
#[cfg(feature = "ssr")]
Expand Down Expand Up @@ -25,13 +27,19 @@ fn thumbnail_size(aspect_ratio: f32) -> (u32, u32) {
}
}

/// Structured error type for the [`upload_photo_group`] server function.
#[derive(Clone, Debug, EnumString, Display)]
pub enum PhotoUploadError {
/// The image could not be parsed by the [`image`] crate.
InvalidImage,
/// The request is unauthenticated.
Unauthenticated,
/// Something failed internally.
InternalError(String),
}

/// Creates and stores a [`PhotoGroup`](core_types::PhotoGroup) and its
/// [`Photo`](core_types::Photo)s built from the [`PhotoGroupUploadParams`].
#[server(
input = MessagePack,
custom = RmpEncoded,
Expand Down

0 comments on commit 20a195b

Please sign in to comment.