Skip to content

Commit

Permalink
Merge branch 'master' into bartek/remove-websockets
Browse files Browse the repository at this point in the history
  • Loading branch information
p-sad authored Jul 10, 2024
2 parents 76fd68d + 98e074d commit d72b5bf
Show file tree
Hide file tree
Showing 3 changed files with 36 additions and 8 deletions.
2 changes: 1 addition & 1 deletion packages/frontend/.eslintrc.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ module.exports = {
'plugin:@typescript-eslint/recommended',
],
rules: {
'no-console': 'error',
'no-console': 'off', // error -> off
'@typescript-eslint/no-unused-vars': [
'error',
{
Expand Down
13 changes: 13 additions & 0 deletions packages/frontend/src/pages/api/voucher/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -42,10 +42,12 @@ async function getVoucherWithJwt(req: NextApiRequest, res: NextApiResponse) {
return
}

console.log('Verify voucher JWT')
const { payload } = await jose.jwtVerify(voucherCodeJwt, environment.authSecret, {
requiredClaims: ['chainId', 'address'],
})

console.log('Get Winner index..', payload.chainId, payload.address)
const winnerIndex = await getWinnerIndex(payload.chainId as number, payload.address as `0x${string}`)

if (winnerIndex === -1) {
Expand All @@ -64,6 +66,8 @@ async function getVoucherWithJwt(req: NextApiRequest, res: NextApiResponse) {
} satisfies GetVoucherResponse)
return
}

console.log('Get Voucher for winner index', winnerIndex)
const voucherCode = voucherCodes[winnerIndex]
if (!voucherCode) {
res.status(500).json({
Expand All @@ -87,8 +91,11 @@ async function getVoucherWithSig(req: NextApiRequest, res: NextApiResponse) {
}

const { chainId, userAddress, signature, nonce } = reqParseResult.data
console.log('Get voucher with signature', chainId, userAddress, signature, nonce)

// Check & spend nonce
if (!nonceStore.delete(nonce)) {
console.error(`Unknown nonce: ${nonce}`)
res.status(403).json({
error: `Unknown nonce: ${nonce}`,
} satisfies GetVoucherResponse)
Expand All @@ -101,6 +108,7 @@ async function getVoucherWithSig(req: NextApiRequest, res: NextApiResponse) {
message: buildVoucherClaimMessage(chainId, userAddress, nonce),
})
if (!isValid) {
console.error('Invalid signature')
res.status(403).json({
error: 'Invalid signature',
} satisfies GetVoucherResponse)
Expand All @@ -115,8 +123,10 @@ async function getVoucherWithSig(req: NextApiRequest, res: NextApiResponse) {
return
}

console.log('Get Winner index..', chainId, userAddress)
const winnerIndex = await getWinnerIndex(chainId, userAddress)
if (winnerIndex === -1) {
console.error(`${chainId}:${userAddress} is not qualified for a voucher code.`)
res.status(403).json({
error: `${chainId}:${userAddress} is not qualified for a voucher code.`,
} satisfies GetVoucherResponse)
Expand All @@ -128,13 +138,15 @@ async function getVoucherWithSig(req: NextApiRequest, res: NextApiResponse) {
voucherCodes = await getVoucherCodes()
} catch (err) {
log.error(err)
console.error(`Voucher not available for winner index ${winnerIndex}`)
res.status(500).json({
error: `Voucher not available for winner index ${winnerIndex}`,
} satisfies GetVoucherResponse)
return
}
const voucherCode = voucherCodes[winnerIndex]
if (!voucherCode) {
console.error(`Voucher not available for winner index ${winnerIndex}`)
res.status(500).json({
error: `Voucher not available for winner index ${winnerIndex}`,
} satisfies GetVoucherResponse)
Expand All @@ -143,6 +155,7 @@ async function getVoucherWithSig(req: NextApiRequest, res: NextApiResponse) {

// All good
// Send back JWT for future requests
console.log('All good. Send back JWT')
const jwt = await new jose.SignJWT({ chainId, address: userAddress })
.setProtectedHeader({ alg: 'HS256' })
.setIssuedAt()
Expand Down
29 changes: 22 additions & 7 deletions packages/frontend/src/utils/getVoucherCodes.ts
Original file line number Diff line number Diff line change
@@ -1,12 +1,16 @@
import * as jose from 'jose'
import { environment } from '@/config/environment'
import { readFile } from 'node:fs/promises'

const encryptedVoucherCodes = 'eyJhbGciOiJkaXIiLCJlbmMiOiJBMjU2R0NNIn0..vc4YkbIz7dKpzRjp.o9NWVDtMl4z734BqRE0UCFSBbAXNGQvu_-MbJ4LQL8VISKFlnqA7173gItkeHEnsU45nGQSYOLXnoZaWqNg4KNbJHK8eVpR1jN8-fDQ4ejdA_ipRWfCP2ginBJDwHRjpsaDbp6bigZRe4SCq3K_b8IUYSDtEK6SjaqWUEYIiu3OEMUVVNs0HLAz0K-FusQT9_ntJyBNuT7L5l0vmoTORSUt4VhlgHeqdWKxmwCRh4I3JD9jnDdvfblAyQV9KxjVyMBuYXu0Pgf4yrdduoEp8t3ab6YBCgJRstwdBmcKUPVopf5PEBhPeYQ48US2YGf2HO7Xs_oFkMkRgKJRIl2o7S-H3NcpVL_XAq-_LheHrd_rxxdiJYZFZThbAfrtMx2gLZdd649aa8sNBtohJlPhJdWZmo6iIApP1BrTlzk9bVbYFPz_Ozu8GM7vvbucbVcRcbUnawDzbZxeXC5aYpys5jmc7S_4oJW1zHshNUWqNzCp88Bi7ge3z0nt935_dw3ky6Q1O-8d7QPJnbAF46RA12dXiP7cwKmr_4ZowpxiUNRSCu-Ku-Soh2pOK4TtedQNIbiCwsP8peFeeKlTFB-irAIToOM8zrxJxCLISD6nQXhoMdRerXndPx3xyi3ahQNDfaKOz9W5Jdws78ZXeH0cxoDlvpOYRbb4KBxbMvDWK-n23nvdNN_xi12ygrwjmVmOsIN4VMwpaObq5IvwzhoZw7aNyj3IFKZV7mwaS8MYGwmnSc3Zo8xWUg8Vys7oAU8ZAKY5kkMrihIr3-GpQbY-L4zD4awnOhZMsvMEdtzXBwfn6HJPtWXKnfn9XFYDrk2aHqMy7BmnLPWwBGXBOBzuLBdVp-PAsx11ke4U17vfAvC7x7S-iI7_p-rSEkRDs9X0zZbGbJJBuJoQaOvCAwPeOSB7v-M1rfajpfcpHJQLOzeBoYsuZxneVxYdFMciRroFbD8PAnWs13Z4F813V_TvkvWveOeocrsn-J7p8UlA_ybKYDYT8kLMifrd6pMTHqjpIdolVe1sAj9hX39QDMxoAXSqTTDmS1I4OIAB3qmPtgyMzoaJ4g8oJ4yxDhvorjG5KiOOMdX-4GQPk0BiGyw6ga4iLO-0yk0w3tA7pmf6_7qnsX3VZgG5eisMrziO538ChsWiL9EUeU_x1faw-Amt-9oCuYR92uJe7-0iC-v6xwWNrTgg1WlFfgK_TGDTU_dkOHKJl5hLPRlbfbaNm2XRIMBCalGnZ1M8jQdf7J87hvwdhDfl-iMQzqMvO-HvMgIure7YW8jmRLGIWbzl3hZYWyCEWFtMfDYLrDleA9CmPcLAyxtJppSklPU8mRU5OzLB2wJ8djNL8_tG_LfumkCr3yrFTNJrjRZRH5EUoFMGQunzXoKRmb4nY6TwW4TPXpCpJ5h0TxHApwTGEVHehHa_CDmhpZeoNsGxa4OEcXfeRFPfv8_buZ2go_noOGGbu3ahd4qHG-LqCxtgQvj6gyZ9okwvIGEM08mGSJuCOuZUjM08xnSr5qy-Z7A5RqgQqnMB8vGsMP-WMVMo4L5Eh4ec_PIcW9ALXWpowwZyLGwhPXrP0PySYikoPCiewa7si1N6TpH0ja53cmH3jvjNb-0LXR-QEbTLU9bZ_VHtOUk3gjGADC0nOzCINFxMRkIN40sOGpUHKB3dbgcjrHa_3s2v_HoaU502qNs6s7TlwY6tgPDusa3jbIZTC_jjgJO6CA3yz6C8J-EBe7F_PrU3bCqbQApN8Vm3e0lHZNHy7Dj_EZ66R1aX95nzOH3_UXKIDfEhfUn_I3hqmP4IL3gUQnm_yjeWfRX4afe06J-59twYob50oYFCxZCXZtHJkLQMMC9McNi906CF-8CQX25rt_TqvWWkMX68_AzxKUIyTjVMBDBAiRkM9_F1ZfIR7-zJ3kabMNgDwnRjxOJijpnDA52grQ6kV-iX3hXs-XBtd8BIR1Q7rrBKWC8lfog7h8gA9boy3lDm6DPzcV0Cs_OpOSwnstNSZc2iBLWzbrvA33_RF7LO-k8-dFxQSmaN3BDpothY5pXbIh4GYaP3tdJSyY0b6_-Cd33S9RjHZP2Gef4yPIBEWlqw7YbdRhnTKxz1yJuwVmMKsiIYqQXuWz75MKSCx0qtFIrP-IX_Kew7a1whN4uKirw3apha0K0LyjDMJcyjmyQV73ZSB7FiDEFz5Cbf9E6nt4iST5qwpSHmUFF8aL4LtNH0g7H8I5dIdmUWaQjtYLi4yEsBB8_hMGHx7SXhdA_Q-Yz5xSQDYBUGRXAAFNaPNKiZE3KbXdRCaY7-GsMOsBQ-gwgUPOHaM3VLBaBaDfynGREk9SJU2uk8702wKfWbI_TzFKqGUsff1Cav2uTzhc10Me4r5zBaNR-7We8y_JqFAvkTuyVEkw0Hd0mS7pzN2PrUIcvV-1ybURRbwKO5ZClny2mGA6C4TsOqvaPFwUHnDcli-t44lxHRYQvjZJI1HH4YLX0MWoRcNoINTm8YZ8fIjcCHZXogNzbF_ne39Y1XImhSxJjGgxMW149Ztq40RDmk0R_ymVHc-F56r8VGGbq-DdpvB2_vgl7RXg32LlD4pVcvjJpZKpmI-TZ0S_cV_DtHBTzIYGmX2gj04FdlcKfXfH3FOlWI-qvh3uQvQZKyB7v4WTdqb_J1Ul5TW-mEM9n4gAM_0-Uk8j5Qa7jj2GJ_4Qtzl3PJywEFKLvXGKdZRKuN3TmQwW6GlpbKcXaFR9vuU230kjeL-N0s6iaNUAkVxq_6kGbi0K5dDKLNZYmPXHdLLpn1y3Q3A9CenZRUOUp9D4nwSq7de0PWlt2GYpzSH2HE-8A-TMmpQss-V5b5x1D2tpNf2DBNs_bTf-BST5HrG_FepZiExG2xGIc6IBBIrRMqeJ_hyW6rP-a82EbybKKXj2KIncy8gQH6Rdms0vXXm8EKDP0H0XYdGdFfy4ou1_8KkRdR0RA9AHaqnIETuF6RauyEyB6N1sGJxb62Ahr8EK37U86bN_SKs63BdYF9B1--kXo-WDcb19TOJFk5yTzuwSF8shfiuzI0xRbbhKbP_xHAz7MWpqg35cxfcQ3W0Ya8xUv8wJ0lcioSlDoX-zJfhAwvgzP1y7pbcrEzLk3O0zNiD_IUGyQ393RxRsca4X0rIeVs9wEp3OomzE-o_1w0Sqr-G5TjIrAxgU35WiMAGIVEMaknbNhikxQ4vjiigLam9hqbX3e-4skm-OgBwVSJ_TQq6XF-87xFQBy6aUGcJKpdBbZFGOjr1D0u9Ppoc60awuJSvgzu7BUEmkSE5fucsqTvyOmE9U9P0WGtRTjnsAEtkmEMDpD3nSd1oJIEA0eUA7uu5hxrGckDX-jN47NrfEsvmMMiG3jHuYFQp1xO0kBCYrPC_EB8rAcKqE7GhaSe5mv87rUxRQW9bUdgvi3CWg2gDozfMaNseX_-SmDF734y7aoZShnAkH-TfAV6HOzAeVx_cXsEg9mHvCFDE_nuM9rfnf9pglrUQFW6jf2dZsbDUKgGDOl1u12x8gDRvDU97b4-myffq2RhyB4lSosQiYSogx42sKJtoFMuuoaAEcQcQbZca4vbbMeMPuIfhMbk-gVhVez0DG3bJ8E0XOKn225F8jz1acriS0GPo7D1dbz0QKy7iJLQPLCwV5nlJPZXFcxnrcegY7I15FRuQLA8QC5SoBMxr9Yvts0dbfbx3rPPX5Hpxi2RNqFdxWEQZqvkY0gKsSvbFqIT9RFiGuVNglj-vZzPzn3Qx90ka-QAyqEXPCAL0AR7oJjGiX66OL-r1P55SMKudLfmEUKR3aVk912BZOJiXEjamR6YS7zfBcJXo8W38uCWa6YG32lEBMSmop2KI4F3r4yorLY3hoUJ_A6DWI0VHKKKxYN_TlDNTG8Pk4ZNXyWHqwlqEesDecy9lepNPLufg9IuppmMzqhqg3JMeFogG1k4eOq9acn6JGNyutW3IfP831S7iZ_ZKOTySsiI8Kd1LsBIm0dhsjB-PFY80Zxk5qaVKBBuasKggGEwXLNQlgyKicHvMjn8cNjTLh9Jl9_kESvKwao03wFdN2CNrELkK2yiPIAD6t7gojiog07TNDnrOeewBRgEigiXhvAcQSkheDmKAWLPAqtwjknbCOqsGRM5HXomXcAIf6j5bP2jL2qs2njKWET2sRgBM2swhnSXXvW5a9dXql_Uwyp6qO5077qtM9-XfE2A7Zamwt1TOWBL8sdyh5BaYyEvQ8xNvgbrgUwZPCg3BVXtQSDYAMBNceuR1jnq0XbV9GLb4jZ5uyN7tCzg-ioSgy7Eg4iw3C8-djJwHpVRkyZxPrA95OuNDAlihAXCBR4hW8CGCJj3UM3hRX01BeNo80JNmL9VfmctaWZmWdb7BF6HXnPfp2C5byD4Iz4yxbRNWbfi-0OhUE5Yaqvy0BN0w0IYGAAehW-yCuY44Mfn8RHDThe09coqTbPbGAj-AxD48VvhJlhgiX_8feVxRwWEDlaQ0neNHiqTZMUUGlS7rE1C0_GuZHU0KvB-RHMl5E0i1rE6hfCVeXEYzN1f9pGa96eF50jd7MkDaT_sOqKFpPbwd50Wva2-0eBs2Dbpqnz_Td3E3jbf0DqbQMGkljUceqbj2LwF7pYir3h8XpDRqOSvdcv7SPnhZClmL8FSw8hK3UZTsb4QQ3o7CBwJrwJTknRDxXwkHQ-401h08G5kvgaFVliM-b6YWfaYSzkafsM4RE3eE9g2Z9T1PQyhwWvtSG0aW5XjiobBGOlWtSH0CxG4kTWrTpbplX7akS9vYFNaPkKgOXv6FMreP7zcwjDv4DpaGAhSDa3wUegRjvXoo5G9tDIa9KvCj7WSLGrcFItjyllyl6dYNpHD0ee5lQEClycHtr5iR0EvBorMA7EdVTNgR3ZWZ_-NYYoDBjqA9-GVfwShUhCD6qAC70P2TAMlJWxgDwji2JytFOB1iewu4dVVVLidxNmYcuR7JYG7A2xgUmDbjYjq5HYiyQQRqP03Qv3tv2BGPntD9iBac3TQWeLG9NFk1uYEW9ECi_q9Ojvmi63LfE-VenWZ-3WYUWA2arnNt7w9tvWoqevnbcPdqzIAJr2l8Mh6wme7x-9cXXUptyyFW0Ax27brFKifdpLIBCcveclj_cm7lr7JTVXmzud5hks_ktC6pO0Lb3aU9ApgFyAFBoFxFhBC6DmxE4HDuk5GrJwWjONgjFLO5S7sF_MWtrWkIXEoyCIRNGMb2f-Bn1XInwyotVxY5d3aP6vQkmPU_Tovo6LKm0-ndhibDRGVogGRbzKKCMR7jmFIvDwvMo-PkPS7zmMN_39njVK-dnYcq1vmAHrFNT4RLcBlOH8Vq83GPn2DZakFRnF_7NV3DiCxpnkugHua46XfK62oZlj-cV1mSvH-gWTpFBtrfIs5QAUHBNqPJSgg3vVBMPJxArHChD8vzCn6a17XKBZGLzubMiDGFklozT72FH7AS3R49e7vK-8aAnIFcN2meDxF29A70MfIt2sVET-M1yCgQGwS_iTjY3N5znHBRdXqEY--5nEpHZybkHK6Dqf9WFELWRziMM0D4M8281cJUSdLMmD2o7cGFrAycpDTtkMlWb9pHjgwvxZFGZyONOO_lCCI4ZLrHltsszXYruDi2RjH22L3E5--0FYIRWR8oI50Z4uHo6L1KvRRIhs5fJ7T5r5wvr0V3CaWlZMgeDaseRSzNUbIeYLxkYW9HZOFqclDu1Z62P9xfjsq6qs-kWs4_5DGW_R3wYqSyG5akTWf2mZcq8_xzR68X6w-Vv1Wqwnn3uS65YlY2ilsERphgzV98fodvFwXJ5eFU16HsNW3ToEnx4IPmEzsuxWyq6hgO_99vJxWRCg4PgOGsgpAElCEqqnKq-VO9ZhDzM0SxzmbvXVG0a9iTqtzbD2tqeg55UudhsakZQFumHpTsTx3d28zrHdhMQE95GRIvmMN0PzrICm8TFyD6-oeejjMi6wWA_tRvG63FGZpb8hE87X_BU4UPPkq27tyEHOKCRKijy-zZsTsZI3SC-ZgSc7E4bfGRQcA2hhdgnprgTAYrOwT09aENy1baRKcMBeT_JLoHX93Qh-7QqOTHh3VvfDyT1CAfK2KnAk6b0ajNukY1TI5LuRRDR-6IoQCsHX2ZQNkweoPVsmPyyJmEHdDO3pYW-RiGC18wlwp9rPkLS-dKxxckDM092-A905VficCyH209Xz-uNnXOMw_rxN25oHSWH9Z5GcGGn8H4MvaDdSNxVpWDpyzIH14.lwfAyNWYLwpK7DNpZ8tB2Q'

export async function getVoucherCodes() {
const encryptedVoucherCodes = await readFile(process.cwd() + `/src/voucherCodes.${process.env.NODE_ENV}`, {
encoding: 'utf-8',
})
return decryptVoucherCodes(encryptedVoucherCodes, environment.authSecret)
console.log('Get voucher codes for', process.env.NODE_ENV)
try {
return decryptVoucherCodes(encryptedVoucherCodes, environment.authSecret)
} catch (e) {
console.error('Error getting voucher codes', e)
return []
}
}

/**
Expand All @@ -18,6 +22,17 @@ export async function getVoucherCodes() {
* @returns Array of voucher codes
*/
export async function decryptVoucherCodes(encryptedVoucherCodes: string, secretKey: Uint8Array) {
const { plaintext } = await jose.compactDecrypt(encryptedVoucherCodes, secretKey.slice(0, 32))
return new TextDecoder().decode(plaintext).split(',')
console.log('Decrypting file..')

try {
const { plaintext } = await jose.compactDecrypt(encryptedVoucherCodes, secretKey.slice(0, 32))
console.log('File decrypted..')

const vouchers = new TextDecoder().decode(plaintext).split(',')
console.log('# of vouchers:', vouchers.length)
return vouchers
} catch (e) {
console.error('Error decrypting voucher codes', e)
return []
}
}

0 comments on commit d72b5bf

Please sign in to comment.