GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Pull Request — master (#19)
by
unknown
02:55
created

Helpers   A

Complexity

Total Complexity 10

Size/Duplication

Total Lines 86
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 0

Test Coverage

Coverage 35.14%

Importance

Changes 0
Metric Value
wmc 10
lcom 0
cbo 0
dl 0
loc 86
ccs 13
cts 37
cp 0.3514
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A trimNewlines() 0 7 1
A cssStringToArray() 0 19 4
A cssArrayToString() 0 8 2
A getBodyNodeFromHtmlFragment() 0 19 3
1
<?php
2
namespace Wa72\HtmlPageDom;
3
4
/**
5
 * Static helper functions for HtmlPageDom
6
 *
7
 * @package Wa72\HtmlPageDom
8
 */
9
class Helpers {
10
11
    /**
12
     * remove newlines from string and minimize whitespace (multiple whitespace characters replaced by one space)
13
     * useful for cleaning up text retrieved by HtmlPageCrawler::text() (nodeValue of a DOMNode)
14
     *
15
     * @param string $string
16
     * @return string
17
     */
18
    public static function trimNewlines($string)
19
    {
20
        $string = str_replace("\n", ' ', $string);
21
        $string = str_replace("\r", ' ', $string);
22
        $string = preg_replace('/\s+/', ' ', $string);
23
        return trim($string);
24
    }
25
26
    /**
27
     * Convert CSS string to array
28
     *
29
     * @param string $css list of CSS properties separated by ;
30
     * @return array name=>value pairs of CSS properties
31
     */
32
    public static function cssStringToArray($css)
33
    {
34
        $statements = explode(';', preg_replace('/\s+/s', ' ', $css));
35
        $styles = array();
36
        foreach ($statements as $statement) {
37
            $statement = trim($statement);
38
            if ('' === $statement) {
39
                continue;
40
            }
41
            $p = strpos($statement, ':');
42
            if ($p <= 0) {
43
                continue;
44
            } // invalid statement, just ignore it
45
            $key = trim(substr($statement, 0, $p));
46
            $value = trim(substr($statement, $p + 1));
47
            $styles[$key] = $value;
48
        }
49
        return $styles;
50
    }
51
52
    /**
53
     * Convert CSS name->value array to string
54
     *
55
     * @param array $array name=>value pairs of CSS properties
56
     * @return string list of CSS properties separated by ;
57
     */
58
    public static function cssArrayToString($array)
59
    {
60
        $styles = '';
61
        foreach ($array as $key => $value) {
62
            $styles .= $key . ': ' . $value . ';';
63
        }
64
        return $styles;
65
    }
66
67
    /**
68
     * Helper function for getting a body element
69
     * from an HTML fragment
70
     *
71
     * @param string $html A fragment of HTML code
72
     * @param string $charset
73
     * @return \DOMNode The body node containing child nodes created from the HTML fragment
74
     */
75 10
    public static function getBodyNodeFromHtmlFragment($html, $charset = 'UTF-8')
76
    {
77 10
        $html = '<html><body>' . $html . '</body></html>';
78 10
        $current = libxml_use_internal_errors(true);
79 10
        $disableEntities = libxml_disable_entity_loader(true);
80 10
        $d = new \DOMDocument('1.0', $charset);
81 10
        $d->validateOnParse = true;
82 10
        if (function_exists('mb_convert_encoding') && in_array(
83
                strtolower($charset),
84 10
                array_map('strtolower', mb_list_encodings())
85
            )
86
        ) {
87 10
            $html = mb_convert_encoding($html, 'HTML-ENTITIES', $charset);
88
        }
89 10
        @$d->loadHTML($html);
0 ignored issues
show
Security Best Practice introduced by
It seems like you do not handle an error condition here. This can introduce security issues, and is generally not recommended.

If you suppress an error, we recommend checking for the error condition explicitly:

// For example instead of
@mkdir($dir);

// Better use
if (@mkdir($dir) === false) {
    throw new \RuntimeException('The directory '.$dir.' could not be created.');
}
Loading history...
90 10
        libxml_use_internal_errors($current);
91 10
        libxml_disable_entity_loader($disableEntities);
92 10
        return $d->getElementsByTagName('body')->item(0);
93
    }
94
}
95