6#include "validatordigitsbetween_p.h"
15 :
ValidatorRule(*new ValidatorDigitsBetweenPrivate(field, min, max, messages, defValKey))
33 int _min = d->extractInt(c, params, d->min, &ok);
38 "ValidatorDigitsBetween: Invalid minimum validation length for field %s at %s::%s.",
40 qPrintable(c->controllerName()),
41 qPrintable(c->actionName()));
44 _max = d->extractInt(c, params, d->max, &ok);
49 "ValidatorDigitsBetween: Invalid maximum validation length for field %s at %s::%s.",
51 qPrintable(c->controllerName()),
52 qPrintable(c->actionName()));
59 qCWarning(C_VALIDATOR,
60 "ValidatorDigitsBetween: Minimum length %i is larger than maximum length %i for "
65 qPrintable(c->controllerName()),
66 qPrintable(c->actionName()));
77 "ValidatorDigitsBetween: Validation failed for value \"%s\" in field %s at "
78 "%s::%s: length not between %i and %i and/or non-digit characters.",
81 qPrintable(c->controllerName()),
82 qPrintable(c->actionName()),
99 const ushort &uc = ch.unicode();
100 if (!((uc > 47) && (uc < 58))) {
117 const QVariantList list = errorData.
toList();
118 const QString min = list.
at(0).toString();
119 const QString max = list.
at(1).toString();
123 error = c->
translate(
"Cutelyst::ValidatorDigitsBetween",
124 "Must contain between %1 and %2 digits.")
128 error = c->
translate(
"Cutelyst::ValidatorDigitsBetween",
129 "The “%1” field must contain between %2 and %3 digits.")
130 .
arg(_label, min, max);
QString translate(const char *context, const char *sourceText, const char *disambiguation=nullptr, int n=-1) const
<Cutelyst/Plugins/Utils/validatordigitsbetween.h>
~ValidatorDigitsBetween() override
Deconstructs the digits between validator.
ValidatorDigitsBetween(const QString &field, const QVariant &min, const QVariant &max, const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey=QString())
Constructs a new digits between validator.
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
Returns a generic error if validation failed.
Base class for all validator rules.
QString label(Context *c) const
Returns the human readable field label used for generic error messages.
QString field() const
Returns the name of the field to validate.
void defaultValue(Context *c, ValidatorReturnType *result, const char *validatorName) const
I a defValKey has been set in the constructor, this will try to get the default value from the stash ...
QString value(const ParamsMultiMap ¶ms) const
Returns the value of the field from the input params.
QString validationDataError(Context *c, const QVariant &errorData=QVariant()) const
Returns an error message if any validation data is missing or invalid.
QString validationError(Context *c, const QVariant &errorData=QVariant()) const
Returns a descriptive error message if validation failed.
static bool validate(const QString &value, int min, int max)
Returns true if value only contains digits and has a length between min and max.
The Cutelyst namespace holds all public Cutelyst API.
QString arg(qlonglong a, int fieldWidth, int base, QChar fillChar) const const
const QChar at(int position) const const
bool isEmpty() const const
void setValue(const T &value)
QList< QVariant > toList() const const
Stores custom error messages and the input field label.
Contains the result of a single input parameter validation.