Skip to content

Commit

Permalink
corrections in create siteAlert and protections from XSS
Browse files Browse the repository at this point in the history
  • Loading branch information
dhakalaashish committed Aug 17, 2023
1 parent 63b1006 commit 1847b83
Show file tree
Hide file tree
Showing 4 changed files with 32 additions and 19 deletions.
5 changes: 3 additions & 2 deletions apps/server/src/server/api/routers/alert.ts
Original file line number Diff line number Diff line change
Expand Up @@ -236,11 +236,12 @@ export const alertRouter = createTRPCRouter({
// Create checksum
const hasher = await createXXHash3();
hasher.init(); // Reset the hasher
const eventDate = inputEventDate ? inputEventDate : new Date()
const eventDate = inputEventDate ? inputEventDate : new Date();
const eventDayIsoString = eventDate.toISOString().split('T')[0]; // Extracting the date portion (YYYY-MM-DD);
const checksum = hasher.update(
latitude.toString() +
longitude.toString() +
eventDate.toISOString() +
eventDayIsoString +
type +
geoEventProviderClientId
).digest('hex');
Expand Down
12 changes: 3 additions & 9 deletions apps/server/src/server/api/routers/geoEvent.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,13 +55,6 @@ export const geoEventRouter = createTRPCRouter({
clientApiKey: geoEventProviderClientApiKey,
},
});
// If provider exists, and provider's clientApiKey is not equal to the apiKey from headers
if (provider && provider.clientApiKey !== geoEventProviderClientApiKey) {
throw new TRPCError({
code: "FORBIDDEN",
message: "Client API Key does not match",
});
}
} else if (ctx.user?.id) {
// Find provider where clientId and userId
provider = await ctx.prisma.geoEventProvider.findFirst({
Expand All @@ -87,11 +80,12 @@ export const geoEventRouter = createTRPCRouter({
// Create checksum
const hasher = await createXXHash3();
hasher.init(); // Reset the hasher
const eventDate = inputEventDate ? inputEventDate : new Date()
const eventDate = inputEventDate ? inputEventDate : new Date();
const eventDayIsoString = eventDate.toISOString().split('T')[0]; // Extracting the date portion (YYYY-MM-DD);
const checksum = hasher.update(
latitude.toString() +
longitude.toString() +
eventDate.toISOString() +
eventDayIsoString +
type +
geoEventProviderClientId
).digest('hex');
Expand Down
15 changes: 12 additions & 3 deletions apps/server/src/server/api/zodSchemas/alert.schema.ts
Original file line number Diff line number Diff line change
@@ -1,19 +1,28 @@
import {z} from 'zod';
import validator from 'validator';

export const detectedBySchema = z.string().min(5, { message: "DetectedBy must be 5 or more characters long" }).max(100, { message: "DetectedBy be 100 or less characters long" }).refine(value => {
const sanitized = validator.escape(value);
return sanitized === value;
}, {
message: 'DetectedBy contains invalid characters',
});

export const queryAlertSchema = z.object({
id: z.string().cuid({ message: "Invalid CUID" }),
})

export const createAlertSchema = z.object({
siteId: z.string(),
siteId: z.string().cuid({ message: "Invalid CUID" }),
type: z.enum(["fire"]),
latitude: z.number(),
longitude: z.number(),
eventDate: z.date().optional(),
detectedBy: z.string(),
detectedBy: detectedBySchema,
confidence: z.enum(["medium", "low", "high"]),
distance: z.number().optional(),
data: z.record(z.unknown()).optional(),
// TODO: Do we need the data field here? This could lead to security vulnerabilities
// data: z.record(z.unknown()).optional(),
});


Expand Down
19 changes: 14 additions & 5 deletions apps/server/src/server/api/zodSchemas/geoEventProvider.schema.ts
Original file line number Diff line number Diff line change
@@ -1,22 +1,31 @@
import { z } from "zod";
import { nameSchema } from "./user.schema";
import validator from 'validator';

export const descriptionSchema = z.string().min(5, { message: "Description must be 5 or more characters long" }).max(1000, { message: "Description be 1000 or less characters long" }).refine(value => {
const sanitized = validator.escape(value);
return sanitized === value;
}, {
message: 'Description contains invalid characters',
});

// Zod Schema for createGeoEventProvider
export const createGeoEventProviderSchema = z.object({
isActive: z.boolean().optional(),
name: z.string(),
description: z.string().optional(),
name: nameSchema,
description: descriptionSchema.optional(),
});

// Zod Schema for updateGeoEventProvider body
const UpdateGeoEventProviderBodySchema = z.object({
isActive: z.boolean(),
name: z.string(),
description: z.string(),
name: nameSchema,
description: descriptionSchema,
}).partial();

// Zod Schema for updateGeoEventProvider params
export const geoEventProviderParamsSchema = z.object({
id: z.string(),
id: z.string().cuid({ message: "Invalid CUID" }),
});

// Zod Schema for updateGeoEventProvider
Expand Down

0 comments on commit 1847b83

Please sign in to comment.