File: ProxyHeaders.php

package info (click to toggle)
matomo 5.8.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 95,068 kB
  • sloc: php: 289,425; xml: 127,249; javascript: 112,130; python: 202; sh: 178; makefile: 20; sql: 10
file content (102 lines) | stat: -rw-r--r-- 2,436 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
<?php

/**
 * Matomo - free/libre analytics platform
 *
 * @link    https://matomo.org
 * @license https://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
 */

namespace Piwik;

/**
 * Proxy headers
 *
 */
class ProxyHeaders
{
    /**
     * Get protocol information, with the exception of HTTPS
     *
     * @return ?string protocol information
     */
    public static function getProtocolInformation(): ?string
    {
        if (isset($_SERVER['SERVER_PORT']) && $_SERVER['SERVER_PORT'] == 443) {
            return 'SERVER_PORT=443';
        }

        if (isset($_SERVER['HTTP_X_FORWARDED_PROTO']) && strtolower($_SERVER['HTTP_X_FORWARDED_PROTO']) == 'https') {
            return 'X-Forwarded-Proto';
        }

        if (isset($_SERVER['HTTP_X_FORWARDED_SCHEME']) && strtolower($_SERVER['HTTP_X_FORWARDED_SCHEME']) == 'https') {
            return 'X-Forwarded-Scheme';
        }

        if (isset($_SERVER['HTTP_X_URL_SCHEME']) && strtolower($_SERVER['HTTP_X_URL_SCHEME']) == 'https') {
            return 'X-Url-Scheme';
        }

        return null;
    }

    /**
     * Get headers present in the HTTP request
     *
     * @param string[] $recognizedHeaders
     * @return string[] HTTP headers
     */
    private static function getHeaders(array $recognizedHeaders): array
    {
        $headers = [];

        foreach ($recognizedHeaders as $header) {
            if (isset($_SERVER[$header])) {
                $headers[] = $header;
            }
        }

        return $headers;
    }

    /**
     * Detect proxy client headers
     *
     * @return string[] Proxy client HTTP headers
     */
    public static function getProxyClientHeaders(): array
    {
        return self::getHeaders([
            'HTTP_CF_CONNECTING_IP',
            'HTTP_CLIENT_IP',
            'HTTP_X_FORWARDED_FOR',
        ]);
    }

    /**
     * Detect proxy host headers
     *
     * @return string[] Proxy host HTTP headers
     */
    public static function getProxyHostHeaders(): array
    {
        return self::getHeaders([
            'HTTP_X_FORWARDED_HOST',
        ]);
    }

    /**
     * Detect proxy scheme headers
     *
     * @return string[] Proxy scheme HTTP headers
     */
    public static function getProxySchemeHeaders(): array
    {
        return self::getHeaders([
            'HTTP_X_FORWARDED_PROTO',
            'HTTP_X_FORWARDED_SCHEME',
            'HTTP_X_URL_SCHEME',
        ]);
    }
}