X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Fcustom-validators%2Fmisc.ts;h=89149b3e0a0cf91af9d589e0350aec2ddd7436d3;hb=0bc1b31d60ed0edf3999f51743b653068ef1816e;hp=f72513c1c643cc193baa4f463d22e718b4145fbc;hpb=345da516fae80f24c90c2196e96393b489af2243;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/custom-validators/misc.ts b/server/helpers/custom-validators/misc.ts index f72513c1c..89149b3e0 100644 --- a/server/helpers/custom-validators/misc.ts +++ b/server/helpers/custom-validators/misc.ts @@ -1,5 +1,5 @@ import 'multer' -import * as validator from 'validator' +import validator from 'validator' import { sep } from 'path' function exists (value: any) { @@ -9,7 +9,7 @@ function exists (value: any) { function isSafePath (p: string) { return exists(p) && (p + '').split(sep).every(part => { - return [ '', '.', '..' ].includes(part) === false + return [ '..' ].includes(part) === false }) } @@ -46,9 +46,21 @@ function isBooleanValid (value: any) { } function toIntOrNull (value: string) { - if (value === 'null') return null + const v = toValueOrNull(value) + + if (v === null || v === undefined) return v + if (typeof v === 'number') return v + + return validator.toInt('' + v) +} + +function toBooleanOrNull (value: any) { + const v = toValueOrNull(value) + + if (v === null || v === undefined) return v + if (typeof v === 'boolean') return v - return validator.toInt(value) + return validator.toBoolean('' + v) } function toValueOrNull (value: string) { @@ -110,6 +122,7 @@ export { isIdOrUUIDValid, isDateValid, toValueOrNull, + toBooleanOrNull, isBooleanValid, toIntOrNull, toArray,