Marketplace móvil para negocios locales mexicanos. Estructura inicial: - apps/backend (NestJS API) - apps/frontend (React Web) - apps/mobile (Expo/React Native) - apps/mcp-server (Claude MCP Server) - apps/whatsapp-service (WhatsApp Business API) - database/ (PostgreSQL DDL) - docs/ (Documentación) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
24 lines
1.3 KiB
JavaScript
24 lines
1.3 KiB
JavaScript
import { compactDecrypt } from '../jwe/compact/decrypt.js';
|
|
import { validateClaimsSet } from '../lib/jwt_claims_set.js';
|
|
import { JWTClaimValidationFailed } from '../util/errors.js';
|
|
export async function jwtDecrypt(jwt, key, options) {
|
|
const decrypted = await compactDecrypt(jwt, key, options);
|
|
const payload = validateClaimsSet(decrypted.protectedHeader, decrypted.plaintext, options);
|
|
const { protectedHeader } = decrypted;
|
|
if (protectedHeader.iss !== undefined && protectedHeader.iss !== payload.iss) {
|
|
throw new JWTClaimValidationFailed('replicated "iss" claim header parameter mismatch', payload, 'iss', 'mismatch');
|
|
}
|
|
if (protectedHeader.sub !== undefined && protectedHeader.sub !== payload.sub) {
|
|
throw new JWTClaimValidationFailed('replicated "sub" claim header parameter mismatch', payload, 'sub', 'mismatch');
|
|
}
|
|
if (protectedHeader.aud !== undefined &&
|
|
JSON.stringify(protectedHeader.aud) !== JSON.stringify(payload.aud)) {
|
|
throw new JWTClaimValidationFailed('replicated "aud" claim header parameter mismatch', payload, 'aud', 'mismatch');
|
|
}
|
|
const result = { payload, protectedHeader };
|
|
if (typeof key === 'function') {
|
|
return { ...result, key: decrypted.key };
|
|
}
|
|
return result;
|
|
}
|