Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
0.00% covered (danger)
0.00%
0 / 17
0.00% covered (danger)
0.00%
0 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
Context
0.00% covered (danger)
0.00%
0 / 17
0.00% covered (danger)
0.00%
0 / 2
72
0.00% covered (danger)
0.00%
0 / 1
 getSupportedParameters
0.00% covered (danger)
0.00%
0 / 5
0.00% covered (danger)
0.00%
0 / 1
2
 validateParameter
0.00% covered (danger)
0.00%
0 / 12
0.00% covered (danger)
0.00%
0 / 1
56
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2021 (original work) Open Assessment Technologies SA;
19 */
20
21declare(strict_types=1);
22
23namespace oat\tao\model\accessControl;
24
25use oat\oatbox\user\User;
26use InvalidArgumentException;
27use oat\tao\model\Context\AbstractContext;
28
29class Context extends AbstractContext
30{
31    public const PARAM_CONTROLLER = 'controller';
32    public const PARAM_ACTION = 'action';
33    public const PARAM_USER = 'user';
34
35    protected function getSupportedParameters(): array
36    {
37        return [
38            self::PARAM_CONTROLLER,
39            self::PARAM_ACTION,
40            self::PARAM_USER,
41        ];
42    }
43
44    protected function validateParameter(string $parameter, $parameterValue): void
45    {
46        if (
47            in_array($parameter, [self::PARAM_CONTROLLER, self::PARAM_ACTION], true)
48            && ($parameterValue === null || is_string($parameterValue))
49        ) {
50            return;
51        }
52
53        if (
54            $parameter === self::PARAM_USER
55            && ($parameterValue === null || $parameterValue instanceof User)
56        ) {
57            return;
58        }
59
60        throw new InvalidArgumentException(
61            sprintf(
62                'Context parameter %s is not valid.',
63                $parameter
64            )
65        );
66    }
67}