6 #include "validator_p.h"
7 #include <Cutelyst/context.h>
8 #include <Cutelyst/request.h>
9 #include <Cutelyst/application.h>
10 #include <QLoggingCategory>
14 Q_LOGGING_CATEGORY(C_VALIDATOR,
"cutelyst.utils.validator", QtWarningMsg)
17 d_ptr(new ValidatorPrivate(translationContext))
21 #ifdef Q_COMPILER_INITIALIZER_LISTS
22 Validator::Validator(std::initializer_list<ValidatorRule *> validators, QLatin1String translationContext) :
23 d_ptr(new ValidatorPrivate(validators, translationContext))
36 if (!d->validators.empty()) {
37 qDeleteAll(d->validators.begin(), d->validators.end());
38 d->validators.clear();
70 if (d->validators.empty()) {
71 qCWarning(C_VALIDATOR) <<
"Validation started with empty validator list.";
76 qCWarning(C_VALIDATOR) <<
"Validation started with empty parameters.";
80 const bool noTrimming = flags.testFlag(
NoTrimming);
85 v->setTrimBefore(
false);
90 if (singleResult.
extra.isValid()) {
98 if (stopOnFirstError) {
106 c->
setStash(QStringLiteral(
"validationErrors"), QVariant::fromValue(result.
errors()));
108 if (!params.isEmpty()) {
109 auto i = params.constBegin();
110 while (i != params.constEnd()) {
111 if (!i.key().contains(QStringLiteral(
"password"), Qt::CaseInsensitive)) {
125 v->setTranslationContext(d->translationContext);
126 d->validators.push_back(v);
The Cutelyst Application.
void loadTranslations(const QString &filename, const QString &directory=QString(), const QString &prefix=QString(), const QString &suffix=QString())
void setStash(const QString &key, const QVariant &value)
ParamsMultiMap bodyParameters() const
ParamsMultiMap queryParameters() const
Provides information about performed validations.
void addExtra(const QString &field, const QVariant &extra)
Adds new extra data that came up when validating the input field.
void addValue(const QString &field, const QVariant &value)
Adds a new value extracted from the specified input field.
QHash< QString, QStringList > errors() const
Returns a dictionary containing fields with errors.
void addError(const QString &field, const QString &message)
Adds new error information to the internal QHash.
QStringList errorStrings() const
Returns a list of all error messages.
Base class for all validator rules.
QString field() const
Returns the name of the field to validate.
virtual ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const =0
Starts the validation and returns the result.
Validation processor for input data.
ValidatorResult validate(Context *c, ValidatorFlags flags=NoSpecialBehavior) const
Starts the validation process on Context c and returns a ValidatorResult.
~Validator()
Desconstructs the Validator and all added ValidatorRule objects.
Validator(QLatin1String translationContext=QLatin1String())
Constructs a new Validator.
void addValidator(ValidatorRule *v)
Adds a new validator to the list of validators.
static void loadTranslations(Application *app)
Loads the translations for the plugin.
void clear()
Clears all internal data.
The Cutelyst namespace holds all public Cutelyst API.
QMultiMap< QString, QString > ParamsMultiMap
Contains the result of a single input parameter validation.