blob: b77e8d045e7a6d0c07e124c17cfb1be978eae891 [file] [log] [blame]
Copybara botbe50d492023-11-30 00:16:42 +01001<?php
Adrià Vilanova Martínez5af86512023-12-02 20:44:16 +01002/*
3 * hores
4 * Copyright (c) 2023 Adrià Vilanova Martínez
5 *
6 * This program is free software: you can redistribute it and/or modify
7 * it under the terms of the GNU Affero General Public License as
8 * published by the Free Software Foundation, either version 3 of the
9 * License, or (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU Affero General Public License for more details.
15 *
16 * You should have received a copy of the GNU Affero General Public
17 * License along with this program.
18 * If not, see http://www.gnu.org/licenses/.
19 */
20
Copybara botbe50d492023-11-30 00:16:42 +010021require_once("core.php");
22security::checkType(security::WORKER, security::METHOD_NOTFOUND);
23security::checkWorkerUIEnabled();
24secondFactor::checkAvailability();
25
26if (secondFactor::isEnabled()) {
27 security::notFound();
28}
29
30if (!security::checkParams("POST", [
31 ["secret", security::PARAM_ISSET],
32 ["code", security::PARAM_ISINT]
33])) {
34 security::go("security.php?msg=empty");
35}
36
37$secret = (string)$_POST["secret"];
38$code = (string)$_POST["code"];
39
40if (!secondFactor::checkCode($secret, $code)) {
41 security::go("security.php?msg=wrongcode");
42}
43
44if (secondFactor::enable($secret)) {
45 security::go("security.php?msg=enabledsecondfactor");
46} else {
47 security::go("security.php?msg=unexpected");
48}