feat(WEB-127): add trpc to handle requests both serverside and clientside
This commit is contained in:
5
server/routers/user/index.ts
Normal file
5
server/routers/user/index.ts
Normal file
@@ -0,0 +1,5 @@
|
||||
import { mergeRouters } from "@/server/trpc"
|
||||
|
||||
import { userQueryRouter } from "./query"
|
||||
|
||||
export const userRouter = mergeRouters(userQueryRouter)
|
||||
3
server/routers/user/input.ts
Normal file
3
server/routers/user/input.ts
Normal file
@@ -0,0 +1,3 @@
|
||||
/**
|
||||
* Add route inputs (both query & mutation)
|
||||
*/
|
||||
3
server/routers/user/mutation.ts
Normal file
3
server/routers/user/mutation.ts
Normal file
@@ -0,0 +1,3 @@
|
||||
/**
|
||||
* Add User mutations
|
||||
*/
|
||||
27
server/routers/user/output.ts
Normal file
27
server/routers/user/output.ts
Normal file
@@ -0,0 +1,27 @@
|
||||
import { z } from "zod"
|
||||
|
||||
/**
|
||||
* Return value from jsonplaceholder.com/users/1
|
||||
* Add proper user object expectation when fetching
|
||||
* from Scandic API
|
||||
*/
|
||||
export const getUserSchema = z.object({
|
||||
address: z.object({
|
||||
city: z.string(),
|
||||
geo: z.object({}),
|
||||
street: z.string(),
|
||||
suite: z.string(),
|
||||
zipcode: z.string(),
|
||||
}),
|
||||
company: z.object({
|
||||
bs: z.string(),
|
||||
catchPhrase: z.string(),
|
||||
name: z.string(),
|
||||
}),
|
||||
email: z.string().email(),
|
||||
id: z.number(),
|
||||
name: z.string(),
|
||||
phone: z.string(),
|
||||
username: z.string(),
|
||||
website: z.string(),
|
||||
})
|
||||
25
server/routers/user/query.ts
Normal file
25
server/routers/user/query.ts
Normal file
@@ -0,0 +1,25 @@
|
||||
import { badRequestError, internalServerError } from "@/server/errors"
|
||||
import { protectedProcedure, router } from "@/server/trpc"
|
||||
import { getUserSchema } from "./output"
|
||||
|
||||
export const userQueryRouter = router({
|
||||
get: protectedProcedure.query(async function (opts) {
|
||||
// TODO: Make request to get user data from Scandic API
|
||||
const response = await fetch(
|
||||
"https://jsonplaceholder.typicode.com/users/1",
|
||||
{
|
||||
cache: "no-store",
|
||||
}
|
||||
)
|
||||
|
||||
if (!response.ok) {
|
||||
throw internalServerError()
|
||||
}
|
||||
const json = await response.json()
|
||||
const validJson = getUserSchema.parse(json)
|
||||
if (!validJson) {
|
||||
throw badRequestError()
|
||||
}
|
||||
return validJson
|
||||
}),
|
||||
})
|
||||
Reference in New Issue
Block a user