favicon here hometagsblogmicrobio cvtech cvgpg keys

Part 5: So I am building a fullstack project

#mercado-series #rust #typescript #deno #fresh #fullstack

Soc Virnyl Estela | 2026-03-15T07:07:34Z | reading time: ~3min

So I made some various experimentations with Fresh and Preact.

Nothing really big but just some surface-level crap that I've been doing.

What the Hell Even Are Signals?§

I was trying to experiment with Tailwind CSS built into the frontend template like for empty input or a status code that isn't 201 or 200, specifically for the register and login modals.

From my understanding, Signals looks similar to React's useState.

The usage is similar as well, but I am not sure what the differences are.

Preact describes signals as an efficient way to update UI states.

In Preact, when a signal is passed down through a tree as props or context, we're only passing around references to the signal.

This means that signals are efficient because they avoid reinitialisation and only update the value to the reference of the signal.

This means we can also do some minor optimisations like avoiding rerendering of the DOM.

At first, I didn't get it because it was an entirely new thing to me. After a bit of reading, I think I get the idea now if combined with useComputed. To localise the state into only a component, Preact suggests to use useComputed with useSignal.

For example, prior to the use of useComputed, I would access a value inside a JSX/TSX and compare it to another value to render a JSX/TSX element.

    <div>
     {statuscode.value !== 200 && (
      <a
        class="text-center rounded-md bg-white hover:bg-gray-100 text-black py-2 focus:outline-2 focus:outline-offset-2 focus:outline-white-500 "
        href="/signup"
      >
        Create Account
      </a>}
      </div>

After I knew about useComputed, I just put it inside a useComputed declaration

  const showSignup = useComputed(() =>
    statuscode.value !== 200 && (
      <a
        class="text-center rounded-md bg-white hover:bg-gray-100 text-black py-2 focus:outline-2 focus:outline-offset-2 focus:outline-white-500 "
        href="/signup"
      >
        Create Account
      </a>
    )
  );

I won't claim that it actually does optimisations but this is what Preact said when accessing a signal's value inside a JSX.

In Preact, accessing a signal's .value property from within a component automatically re-renders the component when that signal's value changes.

Accessing the signal's value in an event handler does not cause a re-render.

Once the value changes, only that part of the component updates, and not the whole component itself.

Here is an ASMR of the login and register. Of course I will use the template's background gradient 🤣

How About the Backend?§

I have to adjust some changes to the backend when experimenting the frontend.

I noticed that I have to handle empty inputs as well which sends a 422 UNPROCESSABLE ENTITY (looks like it's called UNPROCESSABLE CONTENT in the https://httpwg.org/specs/rfc9110.html#rfc.section.15.5.21 hmmmm).

Other errors or status codes returned are 401 UNAUTHORIZED, 500 INTERNAL SERVER ERROR, 409 CONFLICT and 400 BAD REQUEST.

I also made an API endpoint /api/auth/profile to check if the session token is still valid or not with the following code below.

pub async fn profile(
    jar: CookieJar,
) -> anyhow::Result<(StatusCode, Json<UserInfoResponse>), StatusCode> {
    tracing::info!(?jar);
    let Some(token) = jar
        .get("session_token")
        .map(|cookie| cookie.value().to_owned())
    else {
        return Err(StatusCode::UNAUTHORIZED);
    };
    let jwt_service = JwtService::new("some-secret", None);
    let claims = jwt_service
        .verify(&token, None, None, None, None)
        .map_err(|err| {
            tracing::error!(%err);
            StatusCode::UNAUTHORIZED
        })?;

    let Some(id) = claims.sub else {
        return Err(StatusCode::UNAUTHORIZED);
    };
    let Some(email) = claims.iss else {
        return Err(StatusCode::UNAUTHORIZED);
    };

    let mut user_info = UserInfoResponse {
        id,
        email,
        roles: Vec::new(),
        first_name: None,
        last_name: None,
    };

    if let Some(extras) = &claims.extras {
        let first_name = extras.get("first_name");
        let last_name = extras.get("last_name");
        let roles_s = extras.get("roles");

        user_info.first_name = first_name.cloned();
        user_info.last_name = last_name.cloned();

        if let Some(roles) = roles_s {
            let role_str: Vec<&str> = roles.split(',').collect();
            let roles: Vec<i32> = role_str
                .iter()
                .map(|x| x.parse::<i32>())
                .collect::<Result<Vec<i32>, ParseIntError>>()
                .map_err(|err| {
                    tracing::error!(%err);
                    StatusCode::UNAUTHORIZED
                })?;
            user_info.roles = roles;
        }
    };
    tracing::info!("Passed validation âś…");

    Ok((StatusCode::OK, Json(user_info)))
}

I am pretty sure the logic can be reused as middleware for handling routes that require a valid session token.

Security-wise, I would probably ask an expert or do research because I believe if someone has the token string taken from the cookie, it would be so problematic. The only protection it has is the signature verification of which I am unsure if it is very protective enough.

That's all. I'll continue building the database crate again for the products schema.

Articles from blogs I follow around the net

Addressing the harassment

Kiwi Farms is a web forum that facilitates the discussion and harassment of online figures and communities. Their targets are often subject to organized group trolling and stalking, as well as doxing and real-life harassment. Kiwi Farms has been tied to th…

via Drew DeVault's blogApril 21, 2026

Odin's Fiasco with Wikipedia

Recently, Brodie Robertson produced a video on the Bizarre World of Wikipedia Deleting Programming Pages. I highly recommend watching the video.I thank Brodie for covering the Wikipedia fiasco for Odin. We don;t particularly care if Odin is on Wikipedia or…

via gingerBill - ArticlesApril 20, 2026

[WFD 42] Atlas: structural code-intelligence for LLM agents (an empirical evaluation)

2,239-trial benchmark across 8 OSS repos: Atlas beats a text-search baseline by +0.223 deterministic, +0.127 LLM-judge, at 42% fewer tokens.

via Ryana May Que — Writings for DiscussionApril 19, 2026

Eleventy

When I started this blog in 2011, I built it using Jekyll. Jekyll served me well for fifteen years. It was fast enough, and though it would take me an hour or two to get the system reinstalled when I switched laptops, it mostly just worked. But late last y…

via macwright.comApril 17, 2026

How to create a slick CSS animation from Star Wars

I will make a CSS animation of the iconic opening title sequence for the movie Star Wars. I focus on the text crawl portion of the sequence, which introduces the general plot. I will make it responsive.

via Rob O'Leary | BlogApril 16, 2026

Hybrid Constructions: The Post-Quantum Safety Blanket

The funny thing about safety blankets is they can double as stage curtains for security theater. “When will a cryptography-relevant quantum computer exist?” is a question many technologists are pondering as they stare into crystal balls or entrails. Two pe…

via Dhole MomentsApril 13, 2026

Bucklog’s Machine: Inside a Kubernetes Scanning Fleet

Most scanning infrastructure is boring. A VPS, a cron job, maybe a cheap proxy rotation service if the operator has ambitions. What we’re looking at with AS211590 (Bucklog SARL / FBW Networks SAS) is something else entirely – a purpose-built, Kubernetes-or…

via GreyNoise LabsMarch 23, 2026

Status update, February 2026

Hi all! Lars has contributed an implementation independent test suite for the scfg configuration file format. This is quite nice for implementors, they get a base test suite for free. I’ve added support for it for libscfg, the C implementation. I’ve spent …

via emersionFebruary 21, 2026

Investigating the SuperNote Notebook Format

I'm a big fan of eink tablets. I read a lot, I write a lot, I prefer handwritten notes, it's a match made in heaven. I've been using a Kindle Scribe for the past several years - I probably used it as much or more than my phone. Recently, I upgraded to a Su…

via Cracking the ShellFebruary 20, 2026

Luxe, ocaml et volupté

Luxe, ocaml et volupté by Clément Delafargue on February 16, 2026 Tagged as: ocaml. After a couple years using rust as my primary language, I’ve got a new job where I’m using a variety of languages (including rust and typescript), but mostly go 1. So…

via Clément Delafargue - RSS feedFebruary 16, 2026

How To Add DRM To Your Backend (easy) [2026 WORKING]

How KineMaster stopped some modded clients from accessing their asset market

via maia blogFebruary 14, 2026

Push comes to shove tools

Your tools are extensions of your skills

via Ishan WritesFebruary 09, 2026

2025 in review

Come along with me as I review the past year. Heh, I often start these kinds of posts right at the start of the year, but it takes a few weeks longer than I ever expect to think them through.1 Two years of being independent After a second year of operati…

via seanmonstarJanuary 27, 2026

The Birthday Paradox, simulated

I'm a fan of simulating counterintuitive statistics. I recently did this with the Monty Hall problem and I really enjoyed how it turned out. A similarly interesting statistical puzzle is the birthday paradox: you only need to get 23 people in a room a room…

via pcloadletterJanuary 23, 2026

Merry Christmas, Ya Filthy Animals (2025)

It’s my last day of writing for the year, so I’m going to try keep this one quick – it was knocked out over three hours, so I hope you can forgive me if it’s a bit clumsier than my usual writing. For some strange reason, one of the few clear memories I hav…

via LudicityDecember 27, 2025

Yep, Passkeys Still Have Problems

It's now late into 2025, and just over a year since I wrote my last post on Passkeys. The prevailing dialogue that I see from thought leaders is "addressing common misconceptions" around Passkeys, the implication being that "you just don't understand it co…

via Firstyear's blog-a-logDecember 17, 2025

Hacking the World Poker Tour: Inside ClubWPT Gold’s Back Office

In June, 2025, Shubs Shah and I discovered a vulnerability in the online poker website ClubWPT Gold which would have allowed an attacker to fully access the core back office application that is used for all administrative site functionality.

via Blog | Sam CurryOctober 12, 2025

Testing multiple versions of Python in parallel

Daniel Roy Greenfeld wrote about how to test your code for multiple versions of Python using `uv`. I follow up with a small improvement to the Makefile.

via Technically PersonalJuly 21, 2025

Generated by openring-rs

favicon here hometagsblogmicrobio cvtech cvgpg keys