6#include "validatorurl_p.h"
13 Constraints constraints,
14 const QStringList &schemes,
16 const QString &defValKey)
17 :
ValidatorRule(*new ValidatorUrlPrivate(
field, constraints, schemes, messages, defValKey))
31 const QString v =
value(params);
37 QUrl::ParsingMode parsingMode = QUrl::TolerantMode;
39 parsingMode = QUrl::StrictMode;
42 QUrl url(v, parsingMode);
43 if (!url.isValid() || url.isEmpty()) {
60 const QStringList schemeList =
62 ? QStringList({QStringLiteral(
"http"), QStringLiteral(
"https")})
76 if (!schemeList.empty()) {
79 bool foundScheme =
false;
80 for (
const QString &s : schemeList) {
81 const QString sl = s.toLower();
82 if (url.scheme() == sl) {
97 "ValidatorUrl: Validation failed for field %s at %s::%s: not a valid URL",
99 qPrintable(c->controllerName()),
100 qPrintable(c->actionName()));
102 result.
value.setValue(url);
115 const QString _label =
label(c);
116 if (_label.isEmpty()) {
117 error = c->
translate(
"Cutelyst::ValidatorUrl",
"Not a valid URL.");
120 error = c->
translate(
"Cutelyst::ValidatorUrl",
121 "The value in the “%1” field is not a valid URL.")
QString translate(const char *context, const char *sourceText, const char *disambiguation=nullptr, int n=-1) const
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 ...
ValidatorRule(const QString &field, const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey=QString())
Constructs a new ValidatorRule with the given parameters.
QString value(const ParamsMultiMap ¶ms) const
Returns the value of the field from the input params.
QString validationError(Context *c, const QVariant &errorData=QVariant()) const
Returns a descriptive error message if validation failed.
~ValidatorUrl() override
Deconstructs the validator.
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
Returns a generic error message if validation failed.
ValidatorUrl(const QString &field, Constraints constraints=NoConstraint, const QStringList &schemes=QStringList(), const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey=QString())
Constructs a new url validator.
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
Performs the validation and returns the result.
The Cutelyst namespace holds all public Cutelyst API.
QMultiMap< QString, QString > ParamsMultiMap
Stores custom error messages and the input field label.
Contains the result of a single input parameter validation.