mirror of
https://github.com/github/codeql.git
synced 2025-12-21 19:26:31 +01:00
51 lines
1.4 KiB
TypeScript
51 lines
1.4 KiB
TypeScript
import { Get, Injectable, PipeTransform, Query, UsePipes } from '@nestjs/common';
|
|
|
|
@Injectable()
|
|
export class CustomSanitizingPipe implements PipeTransform {
|
|
transform(value: string): number | undefined {
|
|
if (value == null) return undefined;
|
|
return Number(value);
|
|
}
|
|
}
|
|
|
|
@Injectable()
|
|
export class CustomPropagatingPipe implements PipeTransform {
|
|
transform(value: string): string {
|
|
return value.toUpperCase() + '!';
|
|
}
|
|
}
|
|
|
|
export class Controller {
|
|
@Get()
|
|
sanitizingPipe1(@Query('x', CustomSanitizingPipe) sanitized: number): string {
|
|
return '' + sanitized; // OK
|
|
}
|
|
|
|
@Get()
|
|
sanitizingPipe2(@Query('x', new CustomSanitizingPipe()) sanitized: number): string {
|
|
return '' + sanitized; // OK
|
|
}
|
|
|
|
@Get()
|
|
@UsePipes(CustomSanitizingPipe)
|
|
sanitizingPipe3(@Query('x') sanitized: number): string {
|
|
return '' + sanitized; // OK
|
|
}
|
|
|
|
@Get()
|
|
propagatingPipe1(@Query('x', CustomPropagatingPipe) unsanitized: string): string {
|
|
return '' + unsanitized; // NOT OK
|
|
}
|
|
|
|
@Get()
|
|
propagatingPipe2(@Query('x', new CustomPropagatingPipe()) unsanitized: string): string {
|
|
return '' + unsanitized; // NOT OK
|
|
}
|
|
|
|
@Get()
|
|
@UsePipes(CustomPropagatingPipe)
|
|
propagatingPipe3(@Query('x') unsanitized: string): string {
|
|
return '' + unsanitized; // NOT OK
|
|
}
|
|
}
|