first commit

This commit is contained in:
2026-04-14 19:44:21 -05:00
commit 068576cf4b
36 changed files with 13680 additions and 0 deletions

View File

@@ -0,0 +1,3 @@
import loginHandler from '../../api/auth/login.post'
export default loginHandler

View File

@@ -0,0 +1,3 @@
import refreshHandler from '../../api/auth/refresh.post'
export default refreshHandler

View File

@@ -0,0 +1,30 @@
import { createError, getRequestHeader } from 'h3'
import { requireAuthContext } from '../utils/require-auth'
/**
* Exemplo de orquestração A -> B.
* Reaproveita o mesmo Authorization para chamar `/profile/me`.
*/
export default defineEventHandler(async (event) => {
const auth = requireAuthContext(event)
const authorization = getRequestHeader(event, 'authorization')
if (!authorization) {
throw createError({ statusCode: 401, statusMessage: 'Missing Authorization header' })
}
const profileFromService = await $fetch('/profile/me', {
headers: {
Authorization: authorization
}
})
return {
sub_from_api_a: auth.id,
sub_from_api_b: profileFromService.id,
same_subject: profileFromService.id === auth.id,
profile: profileFromService
}
})

View File

@@ -0,0 +1,32 @@
import { createError } from 'h3'
import { prisma } from '../../utils/prisma'
import { requireAuthContext } from '../../utils/require-auth'
/**
* Retorna os dados do usuário autenticado com base no `sub` do JWT.
*/
export default defineEventHandler(async (event) => {
const auth = requireAuthContext(event)
const user = await prisma.user.findUnique({
where: { id: auth.id },
select: {
id: true,
email: true,
createdAt: true,
updatedAt: true
}
})
if (!user) {
throw createError({ statusCode: 404, statusMessage: 'Authenticated user not found' })
}
return {
id: user.id,
email: user.email,
created_at: user.createdAt.toISOString(),
updated_at: user.updatedAt.toISOString()
}
})