Skip to content

Commit

Permalink
Merge branch 'master' of https://github.com/phpseclib/phpseclib
Browse files Browse the repository at this point in the history
  • Loading branch information
terrafrost committed Nov 15, 2024
2 parents 9dab78c + ea10516 commit ea8535a
Show file tree
Hide file tree
Showing 22 changed files with 40 additions and 40 deletions.
2 changes: 1 addition & 1 deletion phpseclib/Common/Functions/Strings.php
Original file line number Diff line number Diff line change
Expand Up @@ -119,7 +119,7 @@ public static function unpackSSH2(string $format, string &$data): array
// 64-bit floats can be used to get larger numbers then 32-bit signed ints would allow
// for. sure, you're not gonna get the full precision of 64-bit numbers but just because
// you need > 32-bit precision doesn't mean you need the full 64-bit precision
extract(unpack('Nupper/Nlower', self::shift($data, 8)));
extract(unpack('Nupper/Nlower', self::shift($data, 8)), EXTR_SKIP);
$temp = $upper ? 4294967296 * $upper : 0;
$temp += $lower < 0 ? ($lower & 0x7FFFFFFFF) + 0x80000000 : $lower;
// $temp = hexdec(bin2hex(self::shift($data, 8)));
Expand Down
10 changes: 5 additions & 5 deletions phpseclib/Crypt/Common/Formats/Keys/PKCS8.php
Original file line number Diff line number Diff line change
Expand Up @@ -345,7 +345,7 @@ protected static function load($key, ?string $password = null): array
if (!$temp) {
throw new RuntimeException('Unable to decode BER');
}
extract(ASN1::asn1map($temp[0], Maps\PBEParameter::MAP));
extract(ASN1::asn1map($temp[0], Maps\PBEParameter::MAP), EXTR_SKIP);
$iterationCount = (int) $iterationCount->toString();
$cipher->setPassword($password, $kdf, $hash, $salt, $iterationCount);
$key = $cipher->decrypt($decrypted['encryptedData']);
Expand All @@ -363,7 +363,7 @@ protected static function load($key, ?string $password = null): array
throw new RuntimeException('Unable to decode BER');
}
$temp = ASN1::asn1map($temp[0], Maps\PBES2params::MAP);
extract($temp);
extract($temp, EXTR_SKIP);

$cipher = self::getPBES2EncryptionObject($encryptionScheme['algorithm']);
$meta['meta']['cipher'] = $encryptionScheme['algorithm'];
Expand All @@ -373,7 +373,7 @@ protected static function load($key, ?string $password = null): array
throw new RuntimeException('Unable to decode BER');
}
$temp = ASN1::asn1map($temp[0], Maps\PBES2params::MAP);
extract($temp);
extract($temp, EXTR_SKIP);

if (!$cipher instanceof RC2) {
$cipher->setIV($encryptionScheme['parameters']['octetString']);
Expand All @@ -382,7 +382,7 @@ protected static function load($key, ?string $password = null): array
if (!$temp) {
throw new RuntimeException('Unable to decode BER');
}
extract(ASN1::asn1map($temp[0], Maps\RC2CBCParameter::MAP));
extract(ASN1::asn1map($temp[0], Maps\RC2CBCParameter::MAP), EXTR_SKIP);
$effectiveKeyLength = (int) $rc2ParametersVersion->toString();
switch ($effectiveKeyLength) {
case 160:
Expand All @@ -409,7 +409,7 @@ protected static function load($key, ?string $password = null): array
}
$prf = ['algorithm' => 'id-hmacWithSHA1'];
$params = ASN1::asn1map($temp[0], Maps\PBKDF2params::MAP);
extract($params);
extract($params, EXTR_SKIP);
$meta['meta']['prf'] = $prf['algorithm'];
$hash = str_replace('-', '/', substr($prf['algorithm'], 11));
$params = [
Expand Down
6 changes: 3 additions & 3 deletions phpseclib/Crypt/Common/Formats/Keys/PuTTY.php
Original file line number Diff line number Diff line change
Expand Up @@ -186,7 +186,7 @@ public static function load($key, $password)

$source = Strings::packSSH2('ssss', $type, $encryption, $components['comment'], $public);

extract(unpack('Nlength', Strings::shift($public, 4)));
extract(unpack('Nlength', Strings::shift($public, 4)), EXTR_SKIP);
$newtype = Strings::shift($public, $length);
if ($newtype != $type) {
throw new RuntimeException('The binary type does not match the human readable type field');
Expand Down Expand Up @@ -214,7 +214,7 @@ public static function load($key, $password)
$parallelism = trim(preg_replace('#Argon2-Parallelism: (\d+)#', '$1', $key[$offset++]));
$salt = Strings::hex2bin(trim(preg_replace('#Argon2-Salt: ([0-9a-f]+)#', '$1', $key[$offset++])));

extract(self::generateV3Key($password, $flavour, (int)$memory, (int)$passes, $salt));
extract(self::generateV3Key($password, $flavour, (int)$memory, (int)$passes, $salt), EXTR_SKIP);

break;
case 2:
Expand Down Expand Up @@ -306,7 +306,7 @@ protected static function wrapPrivateKey(string $public, string $private, string
$key .= "Argon2-Passes: 13\r\n";
$key .= "Argon2-Parallelism: 1\r\n";
$key .= "Argon2-Salt: " . Strings::bin2hex($salt) . "\r\n";
extract(self::generateV3Key($password, 'Argon2id', 8192, 13, $salt));
extract(self::generateV3Key($password, 'Argon2id', 8192, 13, $salt), EXTR_SKIP);

$hash = new Hash('sha256');
$hash->setKey($hashkey);
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/DSA/Formats/Keys/PuTTY.php
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ public static function load($key, $password)
if (!isset($components['private'])) {
return $components;
}
extract($components);
extract($components, EXTR_SKIP);
unset($components['public'], $components['private']);

[$p, $q, $g, $y] = Strings::unpackSSH2('iiii', $public);
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/DSA/PrivateKey.php
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ public function sign($message): string
return $signature;
}

extract(ASN1Signature::load($signature));
extract(ASN1Signature::load($signature), EXTR_SKIP);

return $format::save($r, $s);
}
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/DSA/PublicKey.php
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@ public function verify($message, $signature): bool
if ($params === false || count($params) != 2) {
return false;
}
extract($params);
extract($params, EXTR_SKIP);

if (self::$engines['OpenSSL'] && in_array($this->hash->getHash(), openssl_get_md_methods())) {
$sig = $format != 'ASN1' ? ASN1Signature::save($r, $s) : $signature;
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/EC/PrivateKey.php
Original file line number Diff line number Diff line change
Expand Up @@ -156,7 +156,7 @@ public function sign($message)
return $signature;
}

extract(ASN1Signature::load($signature));
extract(ASN1Signature::load($signature), EXTR_SKIP);

return $this->formatSignature($r, $s);
}
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/EC/PublicKey.php
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ public function verify($message, $signature): bool
if ($params === false || count($params) != 2) {
return false;
}
extract($params);
extract($params, EXTR_SKIP);

if (self::$engines['OpenSSL'] && in_array($this->hash->getHash(), openssl_get_md_methods())) {
$sig = $format != 'ASN1' ? ASN1Signature::save($r, $s) : $signature;
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/RSA.php
Original file line number Diff line number Diff line change
Expand Up @@ -352,7 +352,7 @@ public static function createKey(int $bits = 2048): PrivateKey
if ($i != $num_primes) {
$primes[$i] = BigInteger::randomPrime($regSize);
} else {
extract(BigInteger::minMaxBits($bits));
extract(BigInteger::minMaxBits($bits), EXTR_SKIP);
/** @var BigInteger $min
* @var BigInteger $max
*/
Expand Down
4 changes: 2 additions & 2 deletions phpseclib/Crypt/RSA/Formats/Keys/MSBLOB.php
Original file line number Diff line number Diff line change
Expand Up @@ -83,7 +83,7 @@ public static function load($key, ?string $password = null): array

// PUBLICKEYSTRUC publickeystruc
// https://msdn.microsoft.com/en-us/library/windows/desktop/aa387453(v=vs.85).aspx
extract(unpack('atype/aversion/vreserved/Valgo', Strings::shift($key, 8)));
extract(unpack('atype/aversion/vreserved/Valgo', Strings::shift($key, 8)), EXTR_SKIP);
/**
* @var string $type
* @var string $version
Expand Down Expand Up @@ -116,7 +116,7 @@ public static function load($key, ?string $password = null): array
// RSAPUBKEY rsapubkey
// https://msdn.microsoft.com/en-us/library/windows/desktop/aa387685(v=vs.85).aspx
// could do V for pubexp but that's unsigned 32-bit whereas some PHP installs only do signed 32-bit
extract(unpack('Vmagic/Vbitlen/a4pubexp', Strings::shift($key, 12)));
extract(unpack('Vmagic/Vbitlen/a4pubexp', Strings::shift($key, 12)), EXTR_SKIP);
/**
* @var integer $magic
* @var integer $bitlen
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Crypt/RSA/Formats/Keys/PuTTY.php
Original file line number Diff line number Diff line change
Expand Up @@ -60,7 +60,7 @@ public static function load($key, $password)
if (!isset($components['private'])) {
return $components;
}
extract($components);
extract($components, EXTR_SKIP);
unset($components['public'], $components['private']);

$isPublicKey = false;
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/File/ASN1.php
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,7 @@ private static function decode_ber(string $encoded, int $start = 0, int $encoded
// tags of indefinte length don't really have a header length; this length includes the tag
$current += ['headerlength' => $length + 2];
$start += $length;
extract(unpack('Nlength', substr(str_pad($temp, 4, chr(0), STR_PAD_LEFT), -4)));
extract(unpack('Nlength', substr(str_pad($temp, 4, chr(0), STR_PAD_LEFT), -4)), EXTR_SKIP);
/** @var integer $length */
} else {
$current += ['headerlength' => 2];
Expand Down
4 changes: 2 additions & 2 deletions phpseclib/File/X509.php
Original file line number Diff line number Diff line change
Expand Up @@ -618,7 +618,7 @@ private function mapOutExtensions(array &$root, string $path): void
$extensions = &$this->subArray($root, $path, !empty($this->extensionValues));

foreach ($this->extensionValues as $id => $data) {
extract($data);
extract($data, EXTR_SKIP);
$newext = [
'extnId' => $id,
'extnValue' => $value,
Expand Down Expand Up @@ -1792,7 +1792,7 @@ public function getDN($format = self::DN_ARRAY, ?array $dn = null)
$dn = $this->getDN(self::DN_CANON, $dn);
$hash = new Hash('sha1');
$hash = $hash->hash($dn);
extract(unpack('Vhash', $hash));
extract(unpack('Vhash', $hash), EXTR_SKIP);
return strtolower(Strings::bin2hex(pack('N', $hash)));
}

Expand Down
4 changes: 2 additions & 2 deletions phpseclib/Math/BigInteger.php
Original file line number Diff line number Diff line change
Expand Up @@ -309,7 +309,7 @@ public function modInverse(BigInteger $n): BigInteger
*/
public function extendedGCD(BigInteger $n): array
{
extract($this->value->extendedGCD($n->value));
extract($this->value->extendedGCD($n->value), EXTR_SKIP);
/**
* @var BigInteger $gcd
* @var BigInteger $x
Expand Down Expand Up @@ -550,7 +550,7 @@ public static function minMaxBits(int $bits): array
self::initialize_static_variables();

$class = self::$mainEngine;
extract($class::minMaxBits($bits));
extract($class::minMaxBits($bits), EXTR_SKIP);
/** @var BigInteger $min
* @var BigInteger $max
*/
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Math/BigInteger/Engines/BCMath.php
Original file line number Diff line number Diff line change
Expand Up @@ -274,7 +274,7 @@ public function extendedGCD(BCMath $n): array
*/
public function gcd(BCMath $n): BCMath
{
extract($this->extendedGCD($n));
extract($this->extendedGCD($n), EXTR_SKIP);
/** @var BCMath $gcd */
return $gcd;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -92,7 +92,7 @@ protected static function reduce(string $n, string $m): string
'm1' => $m1, // m.length
];
} else {
extract($cache[self::DATA][$key]);
extract($cache[self::DATA][$key], EXTR_SKIP);
}

$cutoff = $m_length + ($m_length >> 1);
Expand Down
6 changes: 3 additions & 3 deletions phpseclib/Math/BigInteger/Engines/Engine.php
Original file line number Diff line number Diff line change
Expand Up @@ -311,7 +311,7 @@ protected function modInverseHelper(Engine $n)
return $this->normalize($n->subtract($temp));
}

extract($this->extendedGCD($n));
extract($this->extendedGCD($n), EXTR_SKIP);
/**
* @var Engine $gcd
* @var Engine $x
Expand Down Expand Up @@ -706,7 +706,7 @@ protected static function slidingWindow(Engine $x, Engine $e, Engine $n, string
*/
public static function random(int $size): Engine
{
extract(static::minMaxBits($size));
extract(static::minMaxBits($size), EXTR_SKIP);
/**
* @var BigInteger $min
* @var BigInteger $max
Expand All @@ -721,7 +721,7 @@ public static function random(int $size): Engine
*/
public static function randomPrime(int $size): Engine
{
extract(static::minMaxBits($size));
extract(static::minMaxBits($size), EXTR_SKIP);
/**
* @var static $min
* @var static $max
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Math/BigInteger/Engines/GMP.php
Original file line number Diff line number Diff line change
Expand Up @@ -271,7 +271,7 @@ public function modInverse(GMP $n)
*/
public function extendedGCD(GMP $n): array
{
extract(gmp_gcdext($this->value, $n->value));
extract(gmp_gcdext($this->value, $n->value), EXTR_SKIP);

return [
'gcd' => $this->normalize(new self($g)),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ protected static function reduce(array $n, array $m, string $class): array
'm1' => $m1, // m.length
];
} else {
extract($cache[self::DATA][$key]);
extract($cache[self::DATA][$key], EXTR_SKIP);
}

$cutoff = $m_length + ($m_length >> 1);
Expand Down
4 changes: 2 additions & 2 deletions phpseclib/Net/SFTP.php
Original file line number Diff line number Diff line change
Expand Up @@ -3023,7 +3023,7 @@ private function get_sftp_packet($request_id = null)
if (strlen($this->packet_buffer) < 4) {
throw new RuntimeException('Packet is too small');
}
extract(unpack('Nlength', Strings::shift($this->packet_buffer, 4)));
extract(unpack('Nlength', Strings::shift($this->packet_buffer, 4)), EXTR_SKIP);
/** @var integer $length */

$tempLength = $length;
Expand Down Expand Up @@ -3054,7 +3054,7 @@ private function get_sftp_packet($request_id = null)
$this->packet_type = ord(Strings::shift($this->packet_buffer));

if ($this->use_request_id) {
extract(unpack('Npacket_id', Strings::shift($this->packet_buffer, 4))); // remove the request id
extract(unpack('Npacket_id', Strings::shift($this->packet_buffer, 4)), EXTR_SKIP); // remove the request id
$length -= 5; // account for the request id and the packet type
} else {
$length -= 1; // account for the packet type
Expand Down
2 changes: 1 addition & 1 deletion phpseclib/Net/SFTP/Stream.php
Original file line number Diff line number Diff line change
Expand Up @@ -124,7 +124,7 @@ public function __construct()
protected function parse_path(string $path)
{
$orig = $path;
extract(parse_url($path) + ['port' => 22]);
extract(parse_url($path) + ['port' => 22], EXTR_SKIP);
if (isset($query)) {
$path .= '?' . $query;
} elseif (preg_match('/(\?|\?#)$/', $orig)) {
Expand Down
14 changes: 7 additions & 7 deletions phpseclib/Net/SSH2.php
Original file line number Diff line number Diff line change
Expand Up @@ -3318,7 +3318,7 @@ private function get_binary_packet(): string
}
$padding_length = 0;
$payload = $packet->plain;
extract(unpack('Cpadding_length', Strings::shift($payload, 1)));
extract(unpack('Cpadding_length', Strings::shift($payload, 1)), EXTR_SKIP);
if ($padding_length > 0) {
Strings::pop($payload, $padding_length);
}
Expand Down Expand Up @@ -3400,13 +3400,13 @@ private function get_binary_packet_size(object &$packet): void
switch ($this->decryptName) {
case '[email protected]':
case '[email protected]':
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)));
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)), EXTR_SKIP);
$packet->size = $packet_length_header_size + $packet_length + $this->decrypt_block_size; // expect tag
break;
case '[email protected]':
$this->lengthDecrypt->setNonce(pack('N2', 0, $this->get_seq_no));
$packet_length_header = $this->lengthDecrypt->decrypt(substr($packet->raw, 0, $packet_length_header_size));
extract(unpack('Npacket_length', $packet_length_header));
extract(unpack('Npacket_length', $packet_length_header), EXTR_SKIP);
$packet->size = $packet_length_header_size + $packet_length + 16; // expect tag
break;
default:
Expand All @@ -3415,17 +3415,17 @@ private function get_binary_packet_size(object &$packet): void
return;
}
$packet->plain = $this->decrypt->decrypt(substr($packet->raw, 0, $this->decrypt_block_size));
extract(unpack('Npacket_length', Strings::shift($packet->plain, $packet_length_header_size)));
extract(unpack('Npacket_length', Strings::shift($packet->plain, $packet_length_header_size)), EXTR_SKIP);
$packet->size = $packet_length_header_size + $packet_length;
$added_validation_length = $packet_length_header_size;
} else {
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)));
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)), EXTR_SKIP);
$packet->size = $packet_length_header_size + $packet_length;
}
break;
}
} else {
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)));
extract(unpack('Npacket_length', substr($packet->raw, 0, $packet_length_header_size)), EXTR_SKIP);
$packet->size = $packet_length_header_size + $packet_length;
$added_validation_length = $packet_length_header_size;
}
Expand Down Expand Up @@ -3508,7 +3508,7 @@ private function filter(string $payload): string
switch (ord($payload[0])) {
case MessageType::CHANNEL_REQUEST:
if (strlen($payload) == 31) {
extract(unpack('cpacket_type/Nchannel/Nlength', $payload));
extract(unpack('cpacket_type/Nchannel/Nlength', $payload), EXTR_SKIP);
if (substr($payload, 9, $length) == '[email protected]' && isset($this->server_channels[$channel])) {
if (ord(substr($payload, 9 + $length))) { // want reply
$this->send_binary_packet(pack('CN', MessageType::CHANNEL_SUCCESS, $this->server_channels[$channel]));
Expand Down

0 comments on commit ea8535a

Please sign in to comment.