mirror of
https://github.com/php/php-src.git
synced 2024-10-20 16:02:44 +00:00
5fbeb235d2
for the contents of the exported private key to Phar->setSignatureAlgorithm, and expects the public key to be in a file named blah.phar.pubkey in the same directory as the phar blah.phar. This works with openssl static or shared and fails gracefully if openssl is not present without adding a dependency. config.w32 needs updating to match config.m4 [DOC]
36 lines
1002 B
PHP
36 lines
1002 B
PHP
--TEST--
|
|
Phar: verify signature parsing works
|
|
--SKIPIF--
|
|
<?php if (!extension_loaded("phar")) die("skip"); ?>
|
|
<?php if (!extension_loaded("hash")) die("skip extension hash conflicts"); ?>
|
|
<?php if (!extension_loaded("openssl")) die("skip extension openssl conflicts"); ?>
|
|
--INI--
|
|
phar.require_hash=0
|
|
phar.readonly=0
|
|
--FILE--
|
|
<?php
|
|
$a = new Phar(dirname(__FILE__) . '/files/sha1.phar');
|
|
$r = $a->getSignature();
|
|
var_dump($r['hash_type']);
|
|
$a = new Phar(dirname(__FILE__) . '/files/sha512.phar');
|
|
$r = $a->getSignature();
|
|
var_dump($r['hash_type']);
|
|
$a = new Phar(dirname(__FILE__) . '/files/sha256.phar');
|
|
$r = $a->getSignature();
|
|
var_dump($r['hash_type']);
|
|
$a = new Phar(dirname(__FILE__) . '/files/md5.phar');
|
|
$r = $a->getSignature();
|
|
var_dump($r['hash_type']);
|
|
$a = new Phar(dirname(__FILE__) . '/files/openssl.phar');
|
|
$r = $a->getSignature();
|
|
var_dump($r['hash_type']);
|
|
?>
|
|
===DONE===
|
|
--EXPECT--
|
|
string(5) "SHA-1"
|
|
string(7) "SHA-512"
|
|
string(7) "SHA-256"
|
|
string(3) "MD5"
|
|
string(7) "OpenSSL"
|
|
===DONE===
|