Cutelyst
3.5.0
Cutelyst
Plugins
Utils
Validator
validatorrequired.cpp
1
/*
2
* SPDX-FileCopyrightText: (C) 2017-2022 Matthias Fehring <mf@huessenbergnetz.de>
3
* SPDX-License-Identifier: BSD-3-Clause
4
*/
5
6
#include "validatorrequired_p.h"
7
8
using namespace
Cutelyst
;
9
10
ValidatorRequired::ValidatorRequired
(
const
QString
&field,
const
Cutelyst::ValidatorMessages
&messages) :
11
ValidatorRule
(*new ValidatorRequiredPrivate(field, messages))
12
{
13
}
14
15
ValidatorRequired::~ValidatorRequired
()
16
{
17
}
18
19
ValidatorReturnType
ValidatorRequired::validate
(
Cutelyst::Context
*c,
const
Cutelyst::ParamsMultiMap
¶ms)
const
20
{
21
ValidatorReturnType
result;
22
23
const
QString
v =
value
(params);
24
if
(Q_LIKELY(!v.
isEmpty
())) {
25
result.
value
.
setValue
(v);
26
}
else
{
27
result.
errorMessage
=
validationError
(c);
28
}
29
30
return
result;
31
}
32
33
QString
ValidatorRequired::genericValidationError
(
Cutelyst::Context
*c,
const
QVariant
&errorData)
const
34
{
35
QString
error;
36
Q_UNUSED(errorData)
37
const
QString
_label =
label
(c);
38
if
(_label.
isEmpty
()) {
39
error = c->
translate
(
"Cutelyst::ValidatorRequired"
,
"This is required."
);
40
}
else
{
41
//: %1 will be replaced by the field label
42
error = c->
translate
(
"Cutelyst::ValidatorRequired"
,
"The “%1” field is required."
).
arg
(_label);
43
}
44
return
error;
45
}
Cutelyst::ValidatorRequired::genericValidationError
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
Returns a generic error message.
Definition:
validatorrequired.cpp:33
Cutelyst::ValidatorRule::validationError
QString validationError(Context *c, const QVariant &errorData=QVariant()) const
Returns a descriptive error message if validation failed.
Definition:
validatorrule.cpp:59
Cutelyst::ValidatorRequired::validate
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
Performs the validation and returns the result.
Definition:
validatorrequired.cpp:19
Cutelyst::ValidatorMessages
Stores custom error messages and the input field label.
Definition:
validatorrule.h:131
Cutelyst::Context
The Cutelyst Context.
Definition:
context.h:38
Cutelyst::ValidatorReturnType::value
QVariant value
Definition:
validatorrule.h:51
QString::isEmpty
bool isEmpty() const const
Cutelyst::ValidatorRequired::~ValidatorRequired
~ValidatorRequired() override
Deconstructs the required validator.
Definition:
validatorrequired.cpp:15
Cutelyst::Context::translate
QString translate(const char *context, const char *sourceText, const char *disambiguation=nullptr, int n=-1) const
Definition:
context.cpp:471
Cutelyst
The Cutelyst namespace holds all public Cutelyst API.
Definition:
Mainpage.dox:7
QString
Cutelyst::ValidatorRule
Base class for all validator rules.
Definition:
validatorrule.h:279
Cutelyst::ValidatorRule::label
QString label(Context *c) const
Returns the human readable field label used for generic error messages.
Definition:
validatorrule.cpp:45
Cutelyst::ValidatorRequired::ValidatorRequired
ValidatorRequired(const QString &field, const ValidatorMessages &messages=ValidatorMessages())
Constructs a new required validator.
Definition:
validatorrequired.cpp:10
QVariant::setValue
void setValue(const T &value)
Cutelyst::ValidatorReturnType::errorMessage
QString errorMessage
Definition:
validatorrule.h:50
Cutelyst::ValidatorRule::value
QString value(const ParamsMultiMap ¶ms) const
Returns the value of the field from the input params.
Definition:
validatorrule.cpp:28
Cutelyst::ValidatorReturnType
Contains the result of a single input parameter validation.
Definition:
validatorrule.h:49
QMultiMap
QString::arg
QString arg(qlonglong a, int fieldWidth, int base, QChar fillChar) const const
QVariant
Generated by
1.8.14