From 5962880b5df601075d2d8e2cb5bbfcdd8dcc52a9 Mon Sep 17 00:00:00 2001 From: Adam Bardsley Date: Tue, 8 Oct 2024 15:52:04 +0100 Subject: [PATCH 1/4] trim email and ticket number in case --- app/api/preferences/route.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/app/api/preferences/route.ts b/app/api/preferences/route.ts index 83ffcd32..3e0c9804 100644 --- a/app/api/preferences/route.ts +++ b/app/api/preferences/route.ts @@ -12,8 +12,8 @@ export async function POST(request: Request) { console.log("courseInfo", courseInfo) console.log("Diet",dietChoices) const apiRequestBody = { - ticket_number: ticket.value, - email: email.value, + ticket_number: ticket.value.trim(), + email: email.value.trim(), preferences: { choices: courseInfo, dietary_requirements: { From 76b7722f51ba800f9dc9ce8d0ac552e1306a19a0 Mon Sep 17 00:00:00 2001 From: Connor Monaghan Date: Tue, 8 Oct 2024 22:04:51 +0200 Subject: [PATCH 2/4] Fix price scale on import (#192) --- functions/import_tickets/lambda_function.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/functions/import_tickets/lambda_function.py b/functions/import_tickets/lambda_function.py index 54df3c14..1047621d 100644 --- a/functions/import_tickets/lambda_function.py +++ b/functions/import_tickets/lambda_function.py @@ -77,7 +77,7 @@ def lambda_handler(event, context): options = data['options'] for attendee in attendees: - line_items = get_line_items(attendee['passes'], attendee['unit_amount']*100) + line_items = get_line_items(attendee['passes'], attendee['unit_amount']) ticket_number = str(attendee['ticket_number']) if attendee['ticket_number'] is not None else str(get_ticket_number(attendee['email'], attendee['student_ticket'])) purchased_at = int(time.mktime(datetime.strptime(attendee['purchased_at'], '%Y-%m-%dT%H:%M:%S.000Z').timetuple())) input = { From 39bae5422d441ba6c41cb77248d9b4950df9fe04 Mon Sep 17 00:00:00 2001 From: Adam Bardsley Date: Fri, 11 Oct 2024 11:58:14 +0100 Subject: [PATCH 3/4] Add event manager and allowing regex paths --- lib/authorise.ts | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) diff --git a/lib/authorise.ts b/lib/authorise.ts index 2f8599a9..14bdb493 100644 --- a/lib/authorise.ts +++ b/lib/authorise.ts @@ -1,17 +1,13 @@ const superuser = "superadmin" + +// These control access to various admin functionalities. Either direct path without querystring or regular expressions const grantUsage = { - "all-admins": ["/admin"], + "all-admins": ["/admin"], // Everyone gets this set "developer": ["#","/admin/users","/admin/stripe","/admin/import"], "content-manager": ['/admin/content'], "door-staff": ['/admin/ticketing','/admin/scan', '/admin/epos'], + "event-manager": ['/admin/ticketing.*'] // Everything under ticketing } -// const grantView = { -// "developer": { -// "thing": ["create","update","read","delete"], -// "otherthing": ["create","update","read","delete"] -// } -// } - export const authUsage = (user,path) => { // Check could ever be allowed to do anything @@ -21,10 +17,12 @@ export const authUsage = (user,path) => { const roles = user.publicMetadata.roles // Superuser gets set to true always if(roles.includes(superuser)) return true + // Check against all admins stuff + if(grantUsage['all-admins'].includes(pathWithoutQueryString)) return true // check through roles to see if any of them allow access to path return roles.some((role) => { if(!grantUsage[role]) return false // Roles doesn't exist in permissions - return grantUsage[role] && grantUsage[role].includes(pathWithoutQueryString) + return grantUsage[role] && grantUsage[role].some((pattern) => { return pathWithoutQueryString == pattern || new RegExp(`^${pattern}$`).test(pathWithoutQueryString)}) }) } From 8c8966f09a6579df4ba5f7228c337de61a919aa3 Mon Sep 17 00:00:00 2001 From: Adam Bardsley Date: Fri, 11 Oct 2024 12:02:19 +0100 Subject: [PATCH 4/4] Version bump --- package.json | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/package.json b/package.json index 1f0e42e4..08217896 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "congress-system", - "version": "0.3.1", + "version": "1.0.6", "private": true, "license": "Contact Adam & Connor for details", "scripts": {