Completed
Push — master ( 86d33c...02b092 )
by Blizzz
46:16 queued 28:50
created

PasswordConfirmationMiddleware::__construct()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 9
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 8
nc 1
nop 4
dl 0
loc 9
rs 9.6666
c 1
b 0
f 0
1
<?php
2
/**
3
 * @copyright 2018, Roeland Jago Douma <[email protected]>
4
 *
5
 * @author Roeland Jago Douma <[email protected]>
6
 *
7
 * @license GNU AGPL version 3 or any later version
8
 *
9
 * This program is free software: you can redistribute it and/or modify
10
 * it under the terms of the GNU Affero General Public License as
11
 * published by the Free Software Foundation, either version 3 of the
12
 * License, or (at your option) any later version.
13
 *
14
 * This program is distributed in the hope that it will be useful,
15
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
17
 * GNU Affero General Public License for more details.
18
 *
19
 * You should have received a copy of the GNU Affero General Public License
20
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
21
 *
22
 */
23
namespace OC\AppFramework\Middleware\Security;
24
25
use OC\AppFramework\Middleware\Security\Exceptions\NotConfirmedException;
26
use OC\AppFramework\Utility\ControllerMethodReflector;
27
use OCP\AppFramework\Controller;
28
use OCP\AppFramework\Middleware;
29
use OCP\AppFramework\Utility\ITimeFactory;
30
use OCP\ISession;
31
use OCP\IUserSession;
32
33
class PasswordConfirmationMiddleware extends Middleware {
34
	/** @var ControllerMethodReflector */
35
	private $reflector;
36
	/** @var ISession */
37
	private $session;
38
	/** @var IUserSession */
39
	private $userSession;
40
	/** @var ITimeFactory */
41
	private $timeFactory;
42
43
	/**
44
	 * PasswordConfirmationMiddleware constructor.
45
	 *
46
	 * @param ControllerMethodReflector $reflector
47
	 * @param ISession $session
48
	 * @param IUserSession $userSession
49
	 * @param ITimeFactory $timeFactory
50
	 */
51
	public function __construct(ControllerMethodReflector $reflector,
52
								ISession $session,
53
								IUserSession $userSession,
54
								ITimeFactory $timeFactory) {
55
		$this->reflector = $reflector;
56
		$this->session = $session;
57
		$this->userSession = $userSession;
58
		$this->timeFactory = $timeFactory;
59
	}
60
61
	/**
62
	 * @param Controller $controller
63
	 * @param string $methodName
64
	 * @throws NotConfirmedException
65
	 */
66
	public function beforeController($controller, $methodName) {
67
		if ($this->reflector->hasAnnotation('PasswordConfirmationRequired')) {
68
			$user = $this->userSession->getUser();
69
			$backendClassName = '';
70
			if ($user !== null) {
71
				$backendClassName = $user->getBackendClassName();
72
			}
73
74
			$lastConfirm = (int) $this->session->get('last-password-confirm');
75
			// we can't check the password against a SAML backend, so skip password confirmation in this case
76
			if ($backendClassName !== 'user_saml' && $lastConfirm < ($this->timeFactory->getTime() - (30 * 60 + 15))) { // allow 15 seconds delay
77
				throw new NotConfirmedException();
78
			}
79
		}
80
	}
81
}
82