8#include <Cutelyst/Controller>
9#include <Cutelyst/Dispatcher>
10#include <Cutelyst/Plugins/Authentication/authentication.h>
130 return AroundExecute;
136 Q_UNUSED(application)
138 const auto attributes = args.value(QLatin1String(
"attributes")).value<
ParamsMultiMap>();
139 d->actionReverse = args.value(QLatin1String(
"reverse")).toString();
141 if (!attributes.contains(QLatin1String(
"RequiresRole")) &&
142 !attributes.contains(QLatin1String(
"AllowedRole"))) {
143 qFatal(
"RoleACL: Action %s requires at least one RequiresRole or AllowedRole attribute",
144 qPrintable(d->actionReverse));
146 const QStringList required = attributes.values(QLatin1String(
"RequiresRole"));
147 for (
const QString &role : required) {
148 d->requiresRole.append(role);
151 const QStringList allowed = attributes.values(QLatin1String(
"AllowedRole"));
152 for (
const QString &role : allowed) {
153 d->allowedRole.append(role);
157 auto it = attributes.constFind(QLatin1String(
"ACLDetachTo"));
158 if (it == attributes.constEnd() || it.value().isEmpty()) {
159 qFatal(
"RoleACL: Action %s requires the ACLDetachTo(<action>) attribute",
160 qPrintable(d->actionReverse));
162 d->aclDetachTo = it.value();
184 const QStringList user_has =
187 const QStringList required = d->requiresRole;
188 const QStringList allowed = d->allowedRole;
190 if (!required.isEmpty() && !allowed.isEmpty()) {
191 for (
const QString &role : required) {
192 if (!user_has.contains(role)) {
197 for (
const QString &role : allowed) {
198 if (user_has.contains(role)) {
202 }
else if (!required.isEmpty()) {
203 for (
const QString &role : required) {
204 if (!user_has.contains(role)) {
209 }
else if (!allowed.isEmpty()) {
210 for (
const QString &role : allowed) {
211 if (user_has.contains(role)) {
225 d->detachTo = controller->
actionFor(d->aclDetachTo);
230 "RoleACL: Action '%s' requires a valid action set on the ACLDetachTo(%s) attribute",
231 qPrintable(d->actionReverse),
232 qPrintable(d->aclDetachTo));
239#include "moc_roleacl.cpp"
The Cutelyst application.
QVariant value(const QString &key, const QVariant &defaultValue=QVariant()) const
static AuthenticationUser user(Context *c)
Component(QObject *parent=nullptr)
virtual bool aroundExecute(Context *c, QStack< Component * > stack)
void detach(Action *action=nullptr)
Cutelyst Controller base class.
Action * actionFor(QStringView name) const
Action * getActionByPath(QStringView path) const
bool canVisit(Context *c) const
bool init(Application *application, const QVariantHash &args) override
RoleACL(QObject *parent=nullptr)
bool aroundExecute(Context *c, QStack< Component * > stack) override
Modifiers modifiers() const override
bool dispatcherReady(const Dispatcher *dispatcher, Controller *controller) override
QMultiMap< QString, QString > ParamsMultiMap
The Cutelyst namespace holds all public Cutelyst API.