cutelyst
5.0.1
A C++ Web Framework built on top of Qt, using the simple approach of Catalyst (Perl) framework.
validatorpresent.cpp
1
/*
2
* SPDX-FileCopyrightText: (C) 2017-2025 Matthias Fehring <mf@huessenbergnetz.de>
3
* SPDX-License-Identifier: BSD-3-Clause
4
*/
5
6
#include "validatorpresent_p.h"
7
8
using namespace
Cutelyst
;
9
10
ValidatorPresent::ValidatorPresent
(
const
QString &field,
11
const
Cutelyst::ValidatorMessages
&messages)
12
:
ValidatorRule
(*new ValidatorPresentPrivate(field, messages))
13
{
14
}
15
16
ValidatorPresent::~ValidatorPresent
() =
default
;
17
18
ValidatorReturnType
ValidatorPresent::validate
(
Context
*c,
const
ParamsMultiMap
¶ms)
const
19
{
20
ValidatorReturnType
result;
21
22
if
(!params.contains(
field
())) {
23
result.
errorMessage
=
validationError
(c);
24
qCDebug(C_VALIDATOR).noquote() <<
debugString
(c) <<
"Field not found"
;
25
}
else
{
26
result.
value
.setValue<QString>(
value
(params));
27
}
28
29
return
result;
30
}
31
32
void
ValidatorPresent::validateCb
(
Context
*c,
const
ParamsMultiMap
¶ms,
ValidatorRtFn
cb)
const
33
{
34
cb(
validate
(c, params));
35
}
36
37
QString
ValidatorPresent::genericValidationError
(
Context
*c,
const
QVariant &errorData)
const
38
{
39
Q_UNUSED(errorData)
40
const
QString _label =
label
(c);
41
if
(_label.isEmpty()) {
42
//% "Has to be present in input data."
43
return
c->
qtTrId
(
"cutelyst-vapresent-genvalerr"
);
44
}
else
{
45
//: %1 will be replaced by the field label
46
//% "The “%1” field was not found in the input data."
47
return
c->
qtTrId
(
"cutelyst-vapresent-genvalerr-label"
).arg(_label);
48
}
49
}
Cutelyst::Context
The Cutelyst Context.
Definition
context.h:42
Cutelyst::Context::qtTrId
QString qtTrId(const char *id, int n=-1) const
Definition
context.h:657
Cutelyst::ValidatorPresent::validateCb
void validateCb(Context *c, const ParamsMultiMap ¶ms, ValidatorRtFn cb) const override
Definition
validatorpresent.cpp:32
Cutelyst::ValidatorPresent::~ValidatorPresent
~ValidatorPresent() override
Cutelyst::ValidatorPresent::genericValidationError
QString genericValidationError(Context *c, const QVariant &errorData=QVariant()) const override
Definition
validatorpresent.cpp:37
Cutelyst::ValidatorPresent::ValidatorPresent
ValidatorPresent(const QString &field, const ValidatorMessages &messages={})
Definition
validatorpresent.cpp:10
Cutelyst::ValidatorPresent::validate
ValidatorReturnType validate(Context *c, const ParamsMultiMap ¶ms) const override
Definition
validatorpresent.cpp:18
Cutelyst::ValidatorRule
Base class for all validator rules.
Definition
validatorrule.h:354
Cutelyst::ValidatorRule::field
QString field() const noexcept
Definition
validatorrule.cpp:28
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::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::value
QString value(const ParamsMultiMap ¶ms) const
Definition
validatorrule.cpp:34
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
validatorpresent.cpp
Generated by
1.12.0