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
08:19 queued 06:36
created

Helpers::cssStringToArray()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 19
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 20

Importance

Changes 0
Metric Value
dl 0
loc 19
ccs 0
cts 14
cp 0
rs 9.2
c 0
b 0
f 0
cc 4
eloc 14
nc 4
nop 1
crap 20
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