| Server IP : 213.186.33.4 / Your IP : 216.73.216.193 Web Server : Apache System : Linux webm006.cluster103.gra.hosting.ovh.net 5.15.206-ovh-vps-grsec-zfs-classid #1 SMP Fri May 15 02:41:25 UTC 2026 x86_64 User : awebpaca ( 35430) PHP Version : 8.5.0 Disable Function : _dyuweyrj4,_dyuweyrj4r,dl MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/awebpaca/piwik/plugins/TwoFactorAuth/config/ |
Upload File : |
<?php
return array(
'Piwik\Plugins\TwoFactorAuth\Dao\TwoFaSecretRandomGenerator' => DI\autowire('Piwik\Plugins\TwoFactorAuth\Dao\TwoFaSecretStaticGenerator'),
'Piwik\Plugins\TwoFactorAuth\Dao\RecoveryCodeRandomGenerator' => DI\autowire('Piwik\Plugins\TwoFactorAuth\Dao\RecoveryCodeStaticGenerator'),
'Piwik\Plugins\TwoFactorAuth\TwoFactorAuthentication' => DI\decorate(function ($previous) {
/** @var Piwik\Plugins\TwoFactorAuth\TwoFactorAuthentication $previous */
if (!\Piwik\SettingsPiwik::isMatomoInstalled()) {
return $previous;
}
$fakeCorrectAuthCode = \Piwik\Container\StaticContainer::get('test.vars.fakeCorrectAuthCode');
if (!empty($fakeCorrectAuthCode) && !\Piwik\Common::isPhpCliMode()) {
$staticSecret = new \Piwik\Plugins\TwoFactorAuth\Dao\TwoFaSecretStaticGenerator();
$secret = $staticSecret->generateSecret();
require_once PIWIK_DOCUMENT_ROOT . '/libs/Authenticator/TwoFactorAuthenticator.php';
$authenticator = new \TwoFactorAuthenticator();
$_GET['authcode'] = $authenticator->getCode($secret);
$_GET['authCode'] = $_GET['authcode'];
$_POST['authCode'] = $_GET['authcode'];
$_POST['authcode'] = $_GET['authcode'];
$_REQUEST['authcode'] = $_GET['authcode'];
$_REQUEST['authCode'] = $_GET['authcode'];
}
return $previous;
}),
'Piwik\Plugins\TwoFactorAuth\Dao\RecoveryCodeDao' => DI\decorate(function ($previous) {
/** @var Piwik\Plugins\TwoFactorAuth\Dao\RecoveryCodeDao $previous */
if (!\Piwik\SettingsPiwik::isMatomoInstalled()) {
return $previous;
}
$restoreCodes = \Piwik\Container\StaticContainer::get('test.vars.restoreRecoveryCodes');
if (!empty($restoreCodes)) {
// we ensure this recovery code always works for those users
foreach (array('with2FA', 'with2FADisable') as $user) {
$previous->useRecoveryCode($user, '123456'); // we are using it first to make sure there is no duplicate
$previous->insertRecoveryCode($user, '123456');
\Piwik\Option::deleteLike(\Piwik\Plugins\TwoFactorAuth\TwoFactorAuthentication::OPTION_PREFIX_TWO_FA_CODE_USED . '%');
}
}
return $previous;
}),
'Piwik\Plugins\TwoFactorAuth\SystemSettings' => DI\decorate(function ($previous) {
/** @var Piwik\Plugins\TwoFactorAuth\SystemSettings $previous */
if (!\Piwik\SettingsPiwik::isMatomoInstalled()) {
return $previous;
}
Piwik\Access::doAsSuperUser(function () use ($previous) {
$requireTwoFa = \Piwik\Container\StaticContainer::get('test.vars.requireTwoFa');
if (!empty($requireTwoFa)) {
$previous->twoFactorAuthRequired->setValue(1);
} else {
try {
$previous->twoFactorAuthRequired->setValue(0);
} catch (Exception $e) {
// may fail when matomo is trying to update or so
}
}
});
return $previous;
})
);