stream_security_level.phpt 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. --TEST--
  2. security_level setting to prohibit cert
  3. --SKIPIF--
  4. <?php
  5. if (!extension_loaded("openssl")) die("skip openssl not loaded");
  6. if (OPENSSL_VERSION_NUMBER < 0x10100000) die("skip OpenSSL >= v1.1.0 required");
  7. if (!function_exists("proc_open")) die("skip no proc_open");
  8. ?>
  9. --FILE--
  10. <?php
  11. // https://www.openssl.org/docs/man1.1.0/ssl/SSL_CTX_get_security_level.html
  12. $securityLevel = 2;
  13. // Security level 2 refuses certs signed by keys with length of less than 2048 bits
  14. $keyLength = 1024;
  15. $certFile = __DIR__ . DIRECTORY_SEPARATOR . 'stream_security_level.pem.tmp';
  16. $cacertFile = __DIR__ . DIRECTORY_SEPARATOR . 'stream_security_level-ca.pem.tmp';
  17. $serverCode = <<<'CODE'
  18. $serverUri = "ssl://127.0.0.1:64322";
  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. @stream_socket_accept($server, 1);
  26. CODE;
  27. $serverCode = sprintf($serverCode, $certFile);
  28. $clientCode = <<<'CODE'
  29. $serverUri = "ssl://127.0.0.1:64322";
  30. $clientFlags = STREAM_CLIENT_CONNECT;
  31. $clientCtx = stream_context_create(['ssl' => [
  32. 'security_level' => %d,
  33. 'verify_peer' => true,
  34. 'cafile' => '%s',
  35. 'verify_peer_name' => false
  36. ]]);
  37. phpt_wait();
  38. $client = stream_socket_client($serverUri, $errno, $errstr, 1, $clientFlags, $clientCtx);
  39. var_dump($client);
  40. CODE;
  41. $clientCode = sprintf($clientCode, $securityLevel, $cacertFile);
  42. include 'CertificateGenerator.inc';
  43. $certificateGenerator = new CertificateGenerator();
  44. $certificateGenerator->saveCaCert($cacertFile);
  45. $certificateGenerator->saveNewCertAsFileWithKey('stream_security_level', $certFile, $keyLength);
  46. include 'ServerClientTestCase.inc';
  47. ServerClientTestCase::getInstance()->run($clientCode, $serverCode);
  48. ?>
  49. --CLEAN--
  50. <?php
  51. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'stream_security_level.pem.tmp');
  52. @unlink(__DIR__ . DIRECTORY_SEPARATOR . 'stream_security_level-ca.pem.tmp');
  53. ?>
  54. --EXPECTF--
  55. Warning: stream_socket_client(): SSL operation failed with code 1. OpenSSL Error messages:
  56. error:1416F086:SSL routines:tls_process_server_certificate:certificate verify failed in %s : eval()'d code on line %d
  57. Warning: stream_socket_client(): Failed to enable crypto in %s : eval()'d code on line %d
  58. Warning: stream_socket_client(): unable to connect to ssl://127.0.0.1:64322 (Unknown error) in %s : eval()'d code on line %d
  59. bool(false)