1
0
mirror of https://github.com/danog/MadelineProto.git synced 2025-01-22 22:51:11 +01:00

Fix update2fa

This commit is contained in:
Daniil Gentili 2023-02-04 19:18:08 +01:00
parent 5298b9cc76
commit 33b3d9fd67
4 changed files with 11 additions and 18 deletions

View File

@ -1575,7 +1575,7 @@ abstract class InternalDoc
*
* The params array can contain password, new_password, email and hint params.
*
* @param array $params The params
* @param array{password?: string, new_password?: string, email?: string, hint?: string} $params The params
*/
public function update2fa(array $params): void
{

View File

@ -53,17 +53,17 @@ final class PasswordCalculator
* The algorithm to use for calculatuing the hash of the current password (a PasswordKdfAlgo object).
*
*/
private array $current_algo;
private ?array $current_algo;
/**
* SRP b parameter.
*
*/
private BigInteger $srp_B;
private ?BigInteger $srp_B;
/**
* SRP b parameter for hashing.
*
*/
private string $srp_BForHash;
private ?string $srp_BForHash;
/**
* SRP ID.
*/
@ -90,9 +90,6 @@ final class PasswordCalculator
if ($object['_'] !== 'account.password') {
throw new Exception('Wrong constructor');
}
if ($object['has_secure_values']) {
//throw new Exception('Cannot parse secure values');
}
if ($object['has_password']) {
switch ($object['current_algo']['_']) {
case 'passwordKdfAlgoUnknown':
@ -135,8 +132,10 @@ final class PasswordCalculator
Crypt::checkPG($object['new_algo']['p'], $object['new_algo']['g']);
$object['new_algo']['gForHash'] = \str_pad($object['new_algo']['g']->toBytes(), 256, \chr(0), STR_PAD_LEFT);
$object['new_algo']['pForHash'] = \str_pad($object['new_algo']['p']->toBytes(), 256, \chr(0), STR_PAD_LEFT);
$object['current_algo']['salt1'] = (string) $object['current_algo']['salt1'];
$object['current_algo']['salt2'] = (string) $object['current_algo']['salt2'];
if (isset($object['current_algo'])) {
$object['current_algo']['salt1'] = (string) $object['current_algo']['salt1'];
$object['current_algo']['salt2'] = (string) $object['current_algo']['salt2'];
}
break;
default:
throw new Exception("Unknown KDF algo {$object['new_algo']['_']}");
@ -237,8 +236,8 @@ final class PasswordCalculator
$return = ['password' => $oldPassword, 'new_settings' => ['_' => 'account.passwordInputSettings', 'new_algo' => ['_' => 'passwordKdfAlgoUnknown'], 'new_password_hash' => '', 'hint' => '']];
$new_settings =& $return['new_settings'];
if (isset($params['new_password']) && ((string) $params['new_password']) !== '') {
$client_salt = $this->createSalt($this->new_algo['salt1']);
$server_salt = $this->new_algo['salt2'];
$client_salt = $this->createSalt((string) $this->new_algo['salt1']);
$server_salt = (string) $this->new_algo['salt2'];
$g = $this->new_algo['g'];
$p = $this->new_algo['p'];
$pForHash = $this->new_algo['pForHash'];

View File

@ -249,7 +249,7 @@ trait Login
*
* The params array can contain password, new_password, email and hint params.
*
* @param array $params The params
* @param array{password?: string, new_password?: string, email?: string, hint?: string} $params The params
*/
public function update2fa(array $params): void
{

View File

@ -8,11 +8,6 @@ if (defined('MADELINE_POLYFILLED')) {
define('MADELINE_POLYFILLED', true);
use Amp\Http\Client\Cookie\InMemoryCookieJar;
use Amp\Http\Client\Cookie\LocalCookieJar;
use Amp\Socket\EncryptableSocket;
use Amp\Socket\ResourceSocket;
$ampFilePolyfill = 'namespace Amp\\File {';
foreach ([
'open' => 'openFile',
@ -41,4 +36,3 @@ foreach ([
$ampFilePolyfill .= '}';
eval($ampFilePolyfill);
unset($ampFilePolyfill);