bug65538_003.phpt 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. --TEST--
  2. Bug #65538: SSL context "cafile" supports phar wrapper
  3. --EXTENSIONS--
  4. openssl
  5. phar
  6. --SKIPIF--
  7. <?php
  8. if (!function_exists("proc_open")) die("skip no proc_open");
  9. ?>
  10. --INI--
  11. phar.readonly=0
  12. --FILE--
  13. <?php
  14. $certFile = __DIR__ . DIRECTORY_SEPARATOR . 'bug65538_003.pem.tmp';
  15. $cacertFile = 'bug65538_003-ca.pem';
  16. $cacertPhar = __DIR__ . DIRECTORY_SEPARATOR . 'bug65538_003-ca.phar.tmp';
  17. $serverCode = <<<'CODE'
  18. $serverUri = "ssl://127.0.0.1:64321";
  19. $serverFlags = STREAM_SERVER_BIND | STREAM_SERVER_LISTEN;
  20. $serverCtx = stream_context_create(['ssl' => [
  21. 'local_cert' => '%s',
  22. ]]);
  23. $server = stream_socket_server($serverUri, $errno, $errstr, $serverFlags, $serverCtx);
  24. phpt_notify();
  25. $client = @stream_socket_accept($server);
  26. if ($client) {
  27. $in = '';
  28. while (!preg_match('/\r?\n\r?\n/', $in)) {
  29. $in .= fread($client, 2048);
  30. }
  31. $response = "HTTP/1.0 200 OK\r\n"
  32. . "Content-Type: text/plain\r\n"
  33. . "Content-Length: 12\r\n"
  34. . "Connection: close\r\n"
  35. . "\r\n"
  36. . "Hello World!";
  37. fwrite($client, $response);
  38. fclose($client);
  39. }
  40. CODE;
  41. $serverCode = sprintf($serverCode, $certFile);
  42. $peerName = 'bug65538_003';
  43. $clientCode = <<<'CODE'
  44. $serverUri = "https://127.0.0.1:64321/";
  45. $clientCtx = stream_context_create(['ssl' => [
  46. 'cafile' => 'phar://%s/%s',
  47. 'peer_name' => '%s',
  48. ]]);
  49. phpt_wait();
  50. $html = file_get_contents($serverUri, false, $clientCtx);
  51. var_dump($html);
  52. CODE;
  53. $clientCode = sprintf($clientCode, $cacertPhar, $cacertFile, $peerName);
  54. include 'CertificateGenerator.inc';
  55. $certificateGenerator = new CertificateGenerator();
  56. $certificateGenerator->saveNewCertAsFileWithKey($peerName, $certFile);
  57. $phar = new Phar($cacertPhar);
  58. $phar->addFromString($cacertFile, $certificateGenerator->getCaCert());
  59. include 'ServerClientTestCase.inc';
  60. ServerClientTestCase::getInstance()->run($clientCode, $serverCode);
  61. ?>
  62. --CLEAN--
  63. <?php
  64. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'bug65538_003.pem.tmp');
  65. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'bug65538_003-ca.phar.tmp');
  66. ?>
  67. --EXPECT--
  68. string(12) "Hello World!"