From 1a76702ccd4fde6701117e6616dfabd2e7033f44 Mon Sep 17 00:00:00 2001
From: Max <53796487+dyedwiper@users.noreply.github.com>
Date: Fri, 15 Mar 2024 12:26:08 +0100
Subject: [PATCH] PSW-22 Sanitize names on account patch (#4821)
---
.../controller/api-test/account.api.spec.ts | 18 ++++++++++++++++++
.../controller/dto/patch-my-account.params.ts | 4 +++-
2 files changed, 21 insertions(+), 1 deletion(-)
diff --git a/apps/server/src/modules/account/controller/api-test/account.api.spec.ts b/apps/server/src/modules/account/controller/api-test/account.api.spec.ts
index f921104e9d2..d544a8590f9 100644
--- a/apps/server/src/modules/account/controller/api-test/account.api.spec.ts
+++ b/apps/server/src/modules/account/controller/api-test/account.api.spec.ts
@@ -155,6 +155,24 @@ describe('Account Controller (API)', () => {
.send(params)
.expect(400);
});
+
+ it('should strip HTML off of firstName and lastName', async () => {
+ currentUser = mapUserToCurrentUser(teacherUser, teacherAccount);
+ const params: PatchMyAccountParams = {
+ passwordOld: defaultPassword,
+ firstName: 'Jane',
+ lastName: 'Doe',
+ };
+
+ await request(app.getHttpServer()) //
+ .patch(`${basePath}/me`)
+ .send(params)
+ .expect(200);
+
+ const updatedUser = await em.findOneOrFail(User, teacherUser.id);
+ expect(updatedUser.firstName).toEqual('Jane');
+ expect(updatedUser.lastName).toEqual('Doe');
+ });
});
describe('[GET]', () => {
diff --git a/apps/server/src/modules/account/controller/dto/patch-my-account.params.ts b/apps/server/src/modules/account/controller/dto/patch-my-account.params.ts
index 28874bb255a..083a75b4545 100644
--- a/apps/server/src/modules/account/controller/dto/patch-my-account.params.ts
+++ b/apps/server/src/modules/account/controller/dto/patch-my-account.params.ts
@@ -1,5 +1,5 @@
import { ApiProperty } from '@nestjs/swagger';
-import { PrivacyProtect } from '@shared/controller';
+import { PrivacyProtect, SanitizeHtml } from '@shared/controller';
import { IsEmail, IsOptional, IsString, Matches } from 'class-validator';
import { passwordPattern } from './password-pattern';
@@ -34,6 +34,7 @@ export class PatchMyAccountParams {
@IsString()
@IsOptional()
+ @SanitizeHtml()
@ApiProperty({
description: 'The new first name for the current user.',
required: false,
@@ -43,6 +44,7 @@ export class PatchMyAccountParams {
@IsString()
@IsOptional()
+ @SanitizeHtml()
@ApiProperty({
description: 'The new last name for the current user.',
required: false,