Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
| Total | |
100.00% |
19 / 19 |
|
100.00% |
1 / 1 |
CRAP | |
100.00% |
1 / 1 |
| PassInfoFromRewriteToScriptThroughRequestHeaderTester | |
100.00% |
19 / 19 |
|
100.00% |
1 / 1 |
1 | |
100.00% |
1 / 1 |
| __construct | |
100.00% |
19 / 19 |
|
100.00% |
1 / 1 |
1 | |||
| 1 | <?php |
| 2 | |
| 3 | namespace HtaccessCapabilityTester\Testers; |
| 4 | |
| 5 | /** |
| 6 | * Say you have a rewrite rule that points to a PHP script and you would like to pass some information |
| 7 | * along to the PHP. Usually, you will just pass it in the query string. But this won't do if the information |
| 8 | * is sensitive. In that case, there are some tricks available. The trick being tested here sets tells the |
| 9 | * RewriteRule directive to set an environment variable which a RequestHeader directive picks up on and passes |
| 10 | * on to the script in a request header. |
| 11 | * |
| 12 | * @package HtaccessCapabilityTester |
| 13 | * @author Bjørn Rosell <it@rosell.dk> |
| 14 | * @since Class available since 0.7 |
| 15 | */ |
| 16 | class PassInfoFromRewriteToScriptThroughRequestHeaderTester extends CustomTester |
| 17 | { |
| 18 | |
| 19 | /** |
| 20 | * Constructor. |
| 21 | * |
| 22 | * @return void |
| 23 | */ |
| 24 | public function __construct() |
| 25 | { |
| 26 | $htaccessFile = <<<'EOD' |
| 27 | <IfModule mod_rewrite.c> |
| 28 | RewriteEngine On |
| 29 | # We pass document root, because that can easily be checked by the script |
| 30 | RewriteRule ^test\.php$ - [E=PASSTHROUGHHEADER:%{DOCUMENT_ROOT},L] |
| 31 | |
| 32 | <IfModule mod_headers.c> |
| 33 | RequestHeader set PASSTHROUGHHEADER "%{PASSTHROUGHHEADER}e" env=PASSTHROUGHHEADER |
| 34 | </IfModule> |
| 35 | |
| 36 | </IfModule> |
| 37 | EOD; |
| 38 | |
| 39 | $phpFile = <<<'EOD' |
| 40 | <?php |
| 41 | if (isset($_SERVER['HTTP_PASSTHROUGHHEADER'])) { |
| 42 | echo ($_SERVER['HTTP_PASSTHROUGHHEADER'] == $_SERVER['DOCUMENT_ROOT'] ? 1 : 0); |
| 43 | exit; |
| 44 | } |
| 45 | echo '0'; |
| 46 | EOD; |
| 47 | |
| 48 | $test = [ |
| 49 | 'subdir' => 'pass-info-from-rewrite-to-script-through-request-header', |
| 50 | 'files' => [ |
| 51 | ['.htaccess', $htaccessFile], |
| 52 | ['test.php', $phpFile], |
| 53 | ], |
| 54 | 'request' => 'test.php', |
| 55 | 'interpretation' => [ |
| 56 | ['success', 'body', 'equals', '1'], |
| 57 | ['failure', 'body', 'equals', '0'], |
| 58 | ['inconclusive', 'body', 'begins-with', '<' . '?php'], |
| 59 | ['inconclusive'] |
| 60 | ] |
| 61 | ]; |
| 62 | |
| 63 | parent::__construct($test); |
| 64 | } |
| 65 | } |