fix: Add server-side validation of comment length

This commit is contained in:
Tom Moor
2023-06-29 22:41:57 -04:00
parent 4bec08ee05
commit 8957e86c12
4 changed files with 54 additions and 2 deletions

View File

@@ -0,0 +1,36 @@
import { size } from "lodash";
import { Node } from "prosemirror-model";
import { addAttributeOptions } from "sequelize-typescript";
import { ProsemirrorData } from "@shared/types";
import ProsemirrorHelper from "@shared/utils/ProsemirrorHelper";
import { schema } from "@server/editor";
/**
* A decorator that validates the size of the text within a prosemirror data
* object, taking into account unicode characters of variable lengths.
*/
export default function TextLength({
msg,
min = 0,
max,
}: {
msg?: string;
min?: number;
max: number;
}): (target: any, propertyName: string) => void {
return (target: any, propertyName: string) =>
addAttributeOptions(target, propertyName, {
validate: {
validLength(value: ProsemirrorData) {
const text = ProsemirrorHelper.toPlainText(
Node.fromJSON(schema, value),
schema
);
if (size(text) > max || size(text) < min) {
throw new Error(msg);
}
},
},
});
}