Code Coverage
 
Classes and Traits
Functions and Methods
Lines
Total
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
CRAP
100.00% covered (success)
100.00%
5 / 5
Module
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
4
100.00% covered (success)
100.00%
5 / 5
 __construct
n/a
0 / 0
2
n/a
0 / 0
 __set_state
100.00% covered (success)
100.00%
1 / 1
2
100.00% covered (success)
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
20namespace App\Core\Modules;
21
22use App\Util\Common;
23
24/**
25 * Base class for all GNU social modules (plugins and components)
26 */
27abstract 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}