1 | <?php |
||
41 | class UserHooks implements IHook { |
||
42 | /** |
||
43 | * @var KeyManager |
||
44 | */ |
||
45 | private $keyManager; |
||
46 | /** |
||
47 | * @var IUserManager |
||
48 | */ |
||
49 | private $userManager; |
||
50 | /** |
||
51 | * @var ILogger |
||
52 | */ |
||
53 | private $logger; |
||
54 | /** |
||
55 | * @var Setup |
||
56 | */ |
||
57 | private $userSetup; |
||
58 | /** |
||
59 | * @var IUserSession |
||
60 | */ |
||
61 | private $user; |
||
62 | /** |
||
63 | * @var Util |
||
64 | */ |
||
65 | private $util; |
||
66 | /** |
||
67 | * @var Session |
||
68 | */ |
||
69 | private $session; |
||
70 | /** |
||
71 | * @var Recovery |
||
72 | */ |
||
73 | private $recovery; |
||
74 | /** |
||
75 | * @var Crypt |
||
76 | */ |
||
77 | private $crypt; |
||
78 | |||
79 | /** |
||
80 | * UserHooks constructor. |
||
81 | * |
||
82 | * @param KeyManager $keyManager |
||
83 | * @param IUserManager $userManager |
||
84 | * @param ILogger $logger |
||
85 | * @param Setup $userSetup |
||
86 | * @param IUserSession $user |
||
87 | * @param Util $util |
||
88 | * @param Session $session |
||
89 | * @param Crypt $crypt |
||
90 | * @param Recovery $recovery |
||
91 | */ |
||
92 | 9 | public function __construct(KeyManager $keyManager, |
|
93 | IUserManager $userManager, |
||
94 | ILogger $logger, |
||
95 | Setup $userSetup, |
||
96 | IUserSession $user, |
||
97 | Util $util, |
||
98 | Session $session, |
||
99 | Crypt $crypt, |
||
100 | Recovery $recovery) { |
||
101 | |||
102 | 9 | $this->keyManager = $keyManager; |
|
103 | 9 | $this->userManager = $userManager; |
|
104 | 9 | $this->logger = $logger; |
|
105 | 9 | $this->userSetup = $userSetup; |
|
106 | 9 | $this->user = $user; |
|
107 | 9 | $this->util = $util; |
|
108 | 9 | $this->session = $session; |
|
109 | 9 | $this->recovery = $recovery; |
|
110 | 9 | $this->crypt = $crypt; |
|
111 | 9 | } |
|
112 | |||
113 | /** |
||
114 | * Connects Hooks |
||
115 | * |
||
116 | * @return null |
||
117 | */ |
||
118 | public function addHooks() { |
||
119 | OCUtil::connectHook('OC_User', 'post_login', $this, 'login'); |
||
120 | OCUtil::connectHook('OC_User', 'logout', $this, 'logout'); |
||
121 | OCUtil::connectHook('OC_User', |
||
122 | 'post_setPassword', |
||
123 | $this, |
||
124 | 'setPassphrase'); |
||
125 | OCUtil::connectHook('OC_User', |
||
126 | 'pre_setPassword', |
||
127 | $this, |
||
128 | 'preSetPassphrase'); |
||
129 | OCUtil::connectHook('OC_User', |
||
130 | 'post_createUser', |
||
131 | $this, |
||
132 | 'postCreateUser'); |
||
133 | OCUtil::connectHook('OC_User', |
||
134 | 'post_deleteUser', |
||
135 | $this, |
||
136 | 'postDeleteUser'); |
||
137 | } |
||
138 | |||
139 | |||
140 | /** |
||
141 | * Startup encryption backend upon user login |
||
142 | * |
||
143 | * @note This method should never be called for users using client side encryption |
||
144 | * @param array $params |
||
145 | * @return bool |
||
146 | */ |
||
147 | 1 | public function login($params) { |
|
165 | |||
166 | /** |
||
167 | * remove keys from session during logout |
||
168 | */ |
||
169 | 1 | public function logout() { |
|
172 | |||
173 | /** |
||
174 | * setup encryption backend upon user created |
||
175 | * |
||
176 | * @note This method should never be called for users using client side encryption |
||
177 | * @param array $params |
||
178 | */ |
||
179 | 1 | public function postCreateUser($params) { |
|
180 | |||
181 | 1 | if (App::isEnabled('encryption')) { |
|
182 | 1 | $this->userSetup->setupUser($params['uid'], $params['password']); |
|
183 | 1 | } |
|
184 | 1 | } |
|
185 | |||
186 | /** |
||
187 | * cleanup encryption backend upon user deleted |
||
188 | * |
||
189 | * @param array $params : uid, password |
||
190 | * @note This method should never be called for users using client side encryption |
||
191 | */ |
||
192 | 1 | public function postDeleteUser($params) { |
|
193 | |||
194 | 1 | if (App::isEnabled('encryption')) { |
|
195 | 1 | $this->keyManager->deletePublicKey($params['uid']); |
|
196 | 1 | } |
|
197 | 1 | } |
|
198 | |||
199 | /** |
||
200 | * If the password can't be changed within ownCloud, than update the key password in advance. |
||
201 | * |
||
202 | * @param array $params : uid, password |
||
203 | * @return bool |
||
204 | */ |
||
205 | 2 | public function preSetPassphrase($params) { |
|
215 | |||
216 | /** |
||
217 | * Change a user's encryption passphrase |
||
218 | * |
||
219 | * @param array $params keys: uid, password |
||
220 | * @return bool |
||
221 | */ |
||
222 | 2 | public function setPassphrase($params) { |
|
287 | |||
288 | /** |
||
289 | * init mount points for given user |
||
290 | * |
||
291 | * @param string $user |
||
292 | * @throws \OC\User\NoUserException |
||
293 | */ |
||
294 | protected function initMountPoints($user) { |
||
297 | |||
298 | |||
299 | /** |
||
300 | * after password reset we create a new key pair for the user |
||
301 | * |
||
302 | * @param array $params |
||
303 | */ |
||
304 | 1 | public function postPasswordReset($params) { |
|
310 | } |
||
311 |
In PHP, under loose comparison (like
==
, or!=
, orswitch
conditions), values of different types might be equal.For
string
values, the empty string''
is a special case, in particular the following results might be unexpected: