Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
100.00% |
1 / 1 |
|
100.00% |
1 / 1 |
CRAP | |
100.00% |
5 / 5 |
Module | |
100.00% |
1 / 1 |
|
100.00% |
1 / 1 |
4 | |
100.00% |
5 / 5 |
__construct | n/a |
0 / 0 |
2 | n/a |
0 / 0 |
|||||
__set_state | |
100.00% |
1 / 1 |
2 | |
100.00% |
5 / 5 |
1 | <?php |
2 | |
3 | // {{{ License |
4 | // This file is part of GNU social - https://www.gnu.org/software/social |
5 | // |
6 | // GNU social is free software: you can redistribute it and/or modify |
7 | // it under the terms of the GNU Affero General Public License as published by |
8 | // the Free Software Foundation, either version 3 of the License, or |
9 | // (at your option) any later version. |
10 | // |
11 | // GNU social 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 License |
17 | // along with GNU social. If not, see <http://www.gnu.org/licenses/>. |
18 | // }}} |
19 | |
20 | namespace App\Core\Modules; |
21 | |
22 | use App\Util\Common; |
23 | |
24 | /** |
25 | * Base class for all GNU social modules (plugins and components) |
26 | */ |
27 | abstract class Module |
28 | { |
29 | /** |
30 | * TODO Handle configuration |
31 | * |
32 | * @codeCoverageIgnore |
33 | */ |
34 | public function __construct() |
35 | { |
36 | // Load Module settings |
37 | foreach (Common::config(static::class) as $aname => $avalue) { |
38 | $this->{$aname} = $avalue; |
39 | } |
40 | } |
41 | |
42 | /** |
43 | * Serialize the class to store in the cache |
44 | * |
45 | * @param mixed $state |
46 | */ |
47 | public static function __set_state($state) |
48 | { |
49 | $class = get_called_class(); |
50 | $obj = new $class(); |
51 | foreach ($state as $k => $v) { |
52 | $obj->{$k} = $v; |
53 | } |
54 | return $obj; |
55 | } |
56 | } |