diff options
| author | Fuwn <[email protected]> | 2026-03-03 09:10:14 -0800 |
|---|---|---|
| committer | Fuwn <[email protected]> | 2026-03-03 09:10:18 -0800 |
| commit | b3ac58a43e5c604a460e7cfcd6100a6d644f15c6 (patch) | |
| tree | ac7cdcf7f68d623eeb56d05b9f63cbfb5722ca41 /src/lib/Effect/json.ts | |
| parent | refactor(effect): add request body schema decoders to api routes (diff) | |
| download | due.moe-b3ac58a43e5c604a460e7cfcd6100a6d644f15c6.tar.xz due.moe-b3ac58a43e5c604a460e7cfcd6100a6d644f15c6.zip | |
refactor(effect): harden settings and media cache json parsing
Diffstat (limited to 'src/lib/Effect/json.ts')
| -rw-r--r-- | src/lib/Effect/json.ts | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/lib/Effect/json.ts b/src/lib/Effect/json.ts new file mode 100644 index 00000000..b905cc41 --- /dev/null +++ b/src/lib/Effect/json.ts @@ -0,0 +1,28 @@ +import { Effect, Result } from "effect"; + +export const parseJsonStringEffect = (value: string) => + Effect.try({ + try: () => JSON.parse(value) as unknown, + catch: (cause) => new Error("Invalid JSON payload", { cause }), + }); + +export const parseJsonStringEither = (value: string) => + Result.try({ + try: () => Effect.runSync(parseJsonStringEffect(value)), + catch: (cause) => + cause instanceof Error + ? cause + : new Error("Failed to parse JSON payload", { cause }), + }); + +export const parseJsonStringOrThrow = <T = unknown>(value: string): T => + Result.getOrThrow(parseJsonStringEither(value)) as T; + +export const parseJsonStringOrDefault = <T>(value: string, fallback: T): T => { + const parsed = parseJsonStringEither(value); + + return Result.match(parsed, { + onSuccess: (decoded) => decoded as T, + onFailure: () => fallback, + }); +}; |