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))
29 const QString v =
value(params);
35 QUrl::ParsingMode parsingMode = QUrl::TolerantMode;
37 parsingMode = QUrl::StrictMode;
40 QUrl url(v, parsingMode);
41 if (!url.isValid() || url.isEmpty()) {
58 const QStringList schemeList =
60 ? QStringList({QStringLiteral(
"http"), QStringLiteral(
"https")})
74 if (!schemeList.empty()) {
77 bool foundScheme =
false;
78 for (
const QString &s : schemeList) {
79 const QString sl = s.toLower();
80 if (url.scheme() == sl) {
94 qCDebug(C_VALIDATOR).noquote() <<
debugString(c) <<
"Not a valid URL";
96 result.
value.setValue(url);
108 const QString _label =
label(c);
109 if (_label.isEmpty()) {
111 return c->
qtTrId(
"cutelyst-valurl-genvalerr");
115 return c->
qtTrId(
"cutelyst-valurl-genvalerr-label").arg(_label);
QString qtTrId(const char *id, int n=-1) const
QString field() const noexcept
QString validationError(Context *c, const QVariant &errorData={}) const
QString label(Context *c) const
ValidatorRule(const QString &field, const ValidatorMessages &messages={}, const QString &defValKey={}, QByteArrayView validatorName=nullptr)
void defaultValue(Context *c, ValidatorReturnType *result) const
QString value(const ParamsMultiMap ¶ms) const
QString debugString(Context *c) const
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
ValidatorUrl(const QString &field, Constraints constraints=NoConstraint, const QStringList &schemes=QStringList(), const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey=QString())
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
QMultiMap< QString, QString > ParamsMultiMap
The Cutelyst namespace holds all public Cutelyst API.
Stores custom error messages and the input field label.
Contains the result of a single input parameter validation.