-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAMPRequest.php
85 lines (73 loc) · 2.64 KB
/
AMPRequest.php
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
<?php
class AMPRequest
{
public static function setCORSHeader($AMPCacheSubdomain, $optExposeHeaders = array())
{
$unauthorized = 'Unauthorized Request';
$origin = '';
$allowedSourceOrigin = 'https://' . $_SERVER['HTTP_HOST'];
$allowedOrigins = array(
$allowedSourceOrigin,
"https://$AMPCacheSubdomain.cdn.ampproject.org",
"$allowedSourceOrigin.amp.cloudflare.com",
"https://cdn.ampproject.org"
);
$sourceOrigin = urlencode( self::getRequestQuery('__amp_source_origin') );
if( self::getRequestHeader('AMP-Same-Origin') == 'true' )
{
$origin = $sourceOrigin;
}
elseif( in_array( self::getRequestHeader('Origin'), $allowedOrigins)
&& $sourceOrigin == $allowedSourceOrigin)
{
$origin = self::getRequestHeader('Origin');
}
else
{
http_response_code(401);
echo "{'message':'$unauthorized'";
throw new Exception($unauthorized);
}
$origin = urldecode( $origin );
$sourceOrigin = urldecode( $sourceOrigin );
header('Access-Control-Allow-Credentials: true');
header("Access-Control-Allow-Origin: $origin");
header('Access-Control-Expose-Headers: AMP-Access-Control-Allow-Source-Origin'
. join(', ', $optExposeHeaders) );
header("AMP-Access-Control-Allow-Source-Origin: $sourceOrigin");
}
private static function getRequestQuery($query)
{
if( isset( $_GET[$query] ) )
return $_GET[$query];
return '';
}
private static function getRequestHeader($header)
{
$requestHeaders
= function_exists('getallheaders')
? getallheaders()
: self::getAllHeadersPolyfill();
foreach ($requestHeaders as $key => $value)
if( self::isInRequestHeaders($header, $key) )
return $value;
return '';
}
private static function getAllHeadersPolyfill()
{
$headers = [];
foreach ($_SERVER as $name => $value)
if (substr($name, 0, 5) == 'HTTP_')
$headers[str_replace(' ', '-', ucwords(strtolower(str_replace('_', ' ', substr($name, 5)))))] = $value;
return $headers;
}
private static function isInRequestHeaders($searchHeader, $requestHeader)
{
return preg_match("/$searchHeader/i", $requestHeader) ? true : false;
}
private static function logData($data)
{
file_put_contents(__DIR__ . "/data.log", "$data\n", FILE_APPEND | LOCK_EX);
}
}
?>