From: joshuaruesweg Date: Sun, 22 Nov 2020 11:03:34 +0000 (+0100) Subject: Add usesMultifactor condition for user search in acp X-Git-Tag: 5.4.0_Alpha_1~555^2~34^2~1 X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=c6a588feb5661e4736026cb0870c9ce428a52356;p=GitHub%2FWoltLab%2FWCF.git Add usesMultifactor condition for user search in acp --- diff --git a/com.woltlab.wcf/objectType.xml b/com.woltlab.wcf/objectType.xml index 0a015a876e..2b70815363 100644 --- a/com.woltlab.wcf/objectType.xml +++ b/com.woltlab.wcf/objectType.xml @@ -1457,6 +1457,12 @@ wcf\system\condition\UserOptionsCondition userOptions + + com.woltlab.wcf.user.multifactor + com.woltlab.wcf.condition.userSearch + wcf\system\condition\UserMultifactorCondition + general + diff --git a/wcfsetup/install/files/lib/system/condition/UserMultifactorCondition.class.php b/wcfsetup/install/files/lib/system/condition/UserMultifactorCondition.class.php index cfec88c676..6276c2465c 100644 --- a/wcfsetup/install/files/lib/system/condition/UserMultifactorCondition.class.php +++ b/wcfsetup/install/files/lib/system/condition/UserMultifactorCondition.class.php @@ -1,6 +1,10 @@ usesMultifactor && WCF::getUser()->multifactorActive) || (!$condition->usesMultifactor && !WCF::getUser()->multifactorActive)); } + + /** + * @inheritDoc + */ + public function addObjectListCondition(DatabaseObjectList $objectList, array $conditionData) { + if (!($objectList instanceof UserList)) { + throw new InvalidObjectArgument($objectList, UserList::class, 'Object list'); + } + + if (isset($conditionData['usesMultifactor'])) { + $objectList->getConditionBuilder()->add('user_table.multifactorActive = ?', [$conditionData['usesMultifactor']]); + } + } + + /** + * @inheritDoc + */ + public function checkUser(Condition $condition, User $user) { + if ($condition->usesMultifactor !== null && $user->multifactorActive != $condition->usesMultifactor) { + return false; + } + + return true; + } }