From 059a0ac68272aac02f60dda43ba65140ceb6252b Mon Sep 17 00:00:00 2001 From: Mariano Goldman Date: Sat, 27 Jan 2024 09:58:52 -0300 Subject: [PATCH] fix: check in ACL handler (#264) --- src/controllers/handlers/acl-handlers.ts | 4 +++ test/integration/acl-handlers.spec.ts | 42 ++++++++++++++++++++++++ 2 files changed, 46 insertions(+) diff --git a/src/controllers/handlers/acl-handlers.ts b/src/controllers/handlers/acl-handlers.ts index 87f6574a..74c500dd 100644 --- a/src/controllers/handlers/acl-handlers.ts +++ b/src/controllers/handlers/acl-handlers.ts @@ -3,6 +3,7 @@ import { AccessControlList, HandlerContextWithPath, PermissionType } from '../.. import { AuthChain, EthAddress } from '@dcl/schemas' import { defaultPermissions } from '../../logic/permissions-checker' import { InvalidRequestError } from '@dcl/platform-server-commons' +import { Authenticator } from '@dcl/crypto' export async function getAclHandler( ctx: HandlerContextWithPath<'worldsManager', '/acl/:world_name'> @@ -35,6 +36,9 @@ export async function postAclHandler( if (!AuthChain.validate(authChain)) { throw new InvalidRequestError('Invalid payload received. Need to be a valid AuthChain.') } + if (!Authenticator.isValidAuthChain(authChain)) { + throw new InvalidRequestError('Invalid payload received. Need to be a valid AuthChain.') + } const permission = await namePermissionChecker.checkPermission(authChain[0].payload, worldName) if (!permission) { diff --git a/test/integration/acl-handlers.spec.ts b/test/integration/acl-handlers.spec.ts index d07d5bbd..93f7c942 100644 --- a/test/integration/acl-handlers.spec.ts +++ b/test/integration/acl-handlers.spec.ts @@ -336,5 +336,47 @@ test('acl handlers', function ({ components, stubComponents }) { message: `Timestamp is not recent. Please sign a new ACL change request.` }) }) + + it('fails when the auth chain is invalid', async () => { + const delegatedIdentity = await getIdentity() + + const timestamp = new Date().toISOString() + const payload = { + resource: worldName, + allowed: [delegatedIdentity.realAccount.address], + timestamp + } + + const invalidAuthChain = [ + { type: 'SIGNER', payload: ownerIdentity.realAccount.address }, + { type: 'SIGNER', payload: JSON.stringify(payload) } // Auth Chain node is invalid + ] + + const r = await localFetch.fetch(`/acl/${worldName}`, { + body: JSON.stringify(invalidAuthChain), + method: 'POST' + }) + + expect(r.status).toEqual(400) + expect(await r.json()).toEqual({ + error: 'Bad request', + message: `Invalid payload received. Need to be a valid AuthChain.` + }) + + const stored = await worldsManager.getMetadataForWorld(worldName) + expect(stored).toMatchObject({ + permissions: { + ...defaultPermissions(), + deployment: { + type: PermissionType.AllowList, + wallets: [] + }, + streaming: { + type: PermissionType.AllowList, + wallets: [] + } + } + }) + }) }) })