cutelyst
5.0.1
A C++ Web Framework built on top of Qt, using the simple approach of Catalyst (Perl) framework.
validatorsame.cpp
1
/*
2
* SPDX-FileCopyrightText: (C) 2017-2025 Matthias Fehring <mf@huessenbergnetz.de>
3
* SPDX-License-Identifier: BSD-3-Clause
4
*/
5
6
#include "validatorsame_p.h"
7
8
using namespace
Cutelyst
;
9
10
ValidatorSame::ValidatorSame
(
const
QString &field,
11
const
QString &otherField,
12
const
char
*otherLabel,
13
const
Cutelyst::ValidatorMessages
&messages,
14
const
QString &defValKey)
15
:
ValidatorRule
(*new ValidatorSamePrivate(field, otherField, otherLabel, messages, defValKey))
16
{
17
}
18
19
ValidatorSame::~ValidatorSame
() =
default
;
20
21
ValidatorReturnType
ValidatorSame::validate
(
Context
*c,
const
ParamsMultiMap
¶ms)
const
22
{
23
ValidatorReturnType
result;
24
25
Q_D(
const
ValidatorSame
);
26
27
const
QString v =
value
(params);
28
29
if
(!v.isEmpty()) {
30
const
QString ov =
31
trimBefore
() ? params.value(d->otherField).trimmed() : params.value(d->otherField);
32
if
(v != ov) {
33
result.
errorMessage
=
validationError
(c);
34
qCDebug(C_VALIDATOR).noquote().nospace()
35
<<
debugString
(c) <<
" The value in \""
<< d->otherField
36
<<
"\" is not the same: "
<< v <<
" != "
<< ov;
37
}
else
{
38
result.
value
.setValue(v);
39
}
40
}
else
{
41
defaultValue
(c, &result);
42
}
43
44
return
result;
45
}
46
47
void
ValidatorSame::validateCb
(
Context
*c,
const
ParamsMultiMap
¶ms,
ValidatorRtFn
cb)
const
48
{
49
cb(
validate
(c, params));
50
}
51
52
QString
ValidatorSame::genericValidationError
(
Context
*c,
const
QVariant &errorData)
const
53
{
54
Q_D(
const
ValidatorSame
);
55
Q_UNUSED(errorData)
56
const
QString _label =
label
(c);
57
QString _olabel;
58
if
(d->otherLabel) {
59
_olabel = d->translationContext ? c->
translate
(d->translationContext, d->otherLabel)
60
: c->
qtTrId
(d->otherLabel);
61
}
else
{
62
_olabel = d->otherField;
63
}
64
65
if
(_label.isEmpty()) {
66
//: %1 will be replaced by the label of the other field
67
//% "Must be the same as in the “%1” field."
68
return
c->
qtTrId
(
"cutelyst-valsame-genvalerr"
).arg(_olabel);
69
}
else
{
70
//: %1 will be replaced by the field label, %2 will be replaced by the label
71
//: of the other field
72
//% "The “%1” field must have the same value as the “%2” field."
73
return
c->
qtTrId
(
"cutelyst-valsame-genvalerr-label"
).arg(_label, _olabel);
74
}
75
}
Cutelyst::Context
The Cutelyst Context.
Definition
context.h:42
Cutelyst::Context::translate
QString translate(const char *context, const char *sourceText, const char *disambiguation=nullptr, int n=-1) const
Definition
context.cpp:485
Cutelyst::Context::qtTrId
QString qtTrId(const char *id, int n=-1) const
Definition
context.h:657
Cutelyst::ValidatorRule
Base class for all validator rules.
Definition
validatorrule.h:354
Cutelyst::ValidatorRule::validationError
QString validationError(Context *c, const QVariant &errorData={}) const
Definition
validatorrule.cpp:73
Cutelyst::ValidatorRule::label
QString label(const Context *c) const
Definition
validatorrule.cpp:49
Cutelyst::ValidatorRule::trimBefore
bool trimBefore() const noexcept
Definition
validatorrule.cpp:192
Cutelyst::ValidatorRule::debugString
QString debugString(const Context *c) const
Definition
validatorrule.cpp:184
Cutelyst::ValidatorRule::ValidatorRtFn
std::function< void(ValidatorReturnType &&result)> ValidatorRtFn
Void callback function for validator rules that processes the ValidatorReturnType.
Definition
validatorrule.h:82
Cutelyst::ValidatorRule::defaultValue
void defaultValue(Context *c, ValidatorReturnType *result) const
Definition
validatorrule.cpp:156
Cutelyst::ValidatorRule::value
QString value(const ParamsMultiMap ¶ms) const
Definition
validatorrule.cpp:34
Cutelyst::ValidatorSame
The given field must match the field under validation.
Definition
validatorsame.h:47
Cutelyst::ValidatorSame::~ValidatorSame
~ValidatorSame() override
Cutelyst::ValidatorSame::ValidatorSame
ValidatorSame(const QString &field, const QString &otherField, const char *otherLabel=nullptr, const ValidatorMessages &messages=ValidatorMessages(), const QString &defValKey={})
Definition
validatorsame.cpp:10
Cutelyst::ValidatorSame::validateCb
void validateCb(Context *c, const ParamsMultiMap ¶ms, ValidatorRtFn cb) const override
Definition
validatorsame.cpp:47
Cutelyst::ValidatorSame::validate
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
Definition
validatorsame.cpp:21
Cutelyst::ValidatorSame::genericValidationError
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
Definition
validatorsame.cpp:52
Cutelyst::ParamsMultiMap
QMultiMap< QString, QString > ParamsMultiMap
Definition
paramsmultimap.h:23
Cutelyst
The Cutelyst namespace holds all public Cutelyst API.
Definition
group-core-actions.dox:1
Cutelyst::ValidatorMessages
Stores custom error messages and the input field label.
Definition
validatorrule.h:153
Cutelyst::ValidatorReturnType
Contains the result of a single input parameter validation.
Definition
validatorrule.h:52
Cutelyst::ValidatorReturnType::value
QVariant value
Definition
validatorrule.h:57
Cutelyst::ValidatorReturnType::errorMessage
QString errorMessage
Definition
validatorrule.h:53
Cutelyst
Plugins
Utils
Validator
validatorsame.cpp
Generated by
1.12.0