feat: HMAC-signed finalist confirmation token

This commit is contained in:
Matt
2026-04-28 17:50:17 +02:00
parent dff18b17f7
commit 53a1e62614
2 changed files with 78 additions and 0 deletions

View File

@@ -0,0 +1,33 @@
import { describe, it, expect, beforeAll } from 'vitest'
import { signFinalistToken, verifyFinalistToken } from '../../src/lib/finalist-token'
beforeAll(() => {
process.env.NEXTAUTH_SECRET = 'test-secret-for-finalist-tokens'
})
describe('finalist token', () => {
it('round-trips a payload', () => {
const exp = Math.floor(Date.now() / 1000) + 86400
const token = signFinalistToken({ confirmationId: 'cmf_test', exp })
const verified = verifyFinalistToken(token)
expect(verified.confirmationId).toBe('cmf_test')
expect(verified.exp).toBe(exp)
})
it('rejects tampered tokens', () => {
const exp = Math.floor(Date.now() / 1000) + 86400
const token = signFinalistToken({ confirmationId: 'cmf_test', exp })
const tampered = token.slice(0, -2) + 'xx'
expect(() => verifyFinalistToken(tampered)).toThrow(/signature/i)
})
it('rejects expired tokens', () => {
const exp = Math.floor(Date.now() / 1000) - 1
const token = signFinalistToken({ confirmationId: 'cmf_test', exp })
expect(() => verifyFinalistToken(token)).toThrow(/expired/i)
})
it('rejects malformed tokens', () => {
expect(() => verifyFinalistToken('not-a-token')).toThrow(/malformed/i)
})
})