121 lines
4.1 KiB
PHP
121 lines
4.1 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Crypt module.
|
|
*
|
|
* This file is part of MadelineProto.
|
|
* MadelineProto is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
|
|
* MadelineProto is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
* See the GNU Affero General Public License for more details.
|
|
* You should have received a copy of the GNU General Public License along with MadelineProto.
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* @author Daniil Gentili <daniil@daniil.it>
|
|
* @copyright 2016-2020 Daniil Gentili <daniil@daniil.it>
|
|
* @license https://opensource.org/licenses/AGPL-3.0 AGPLv3
|
|
*
|
|
* @link https://docs.madelineproto.xyz MadelineProto documentation
|
|
*/
|
|
|
|
namespace danog\MadelineProto\MTProtoTools;
|
|
|
|
trait Crypt
|
|
{
|
|
/**
|
|
* AES KDF function for MTProto v2.
|
|
*
|
|
* @param string $msg_key Message key
|
|
* @param string $auth_key Auth key
|
|
* @param boolean $to_server To server/from server direction
|
|
*
|
|
* @internal
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function aesCalculate(string $msg_key, string $auth_key, bool $to_server = true): array
|
|
{
|
|
$x = $to_server ? 0 : 8;
|
|
$sha256_a = \hash('sha256', $msg_key . \substr($auth_key, $x, 36), true);
|
|
$sha256_b = \hash('sha256', \substr($auth_key, 40 + $x, 36) . $msg_key, true);
|
|
$aes_key = \substr($sha256_a, 0, 8) . \substr($sha256_b, 8, 16) . \substr($sha256_a, 24, 8);
|
|
$aes_iv = \substr($sha256_b, 0, 8) . \substr($sha256_a, 8, 16) . \substr($sha256_b, 24, 8);
|
|
return [$aes_key, $aes_iv];
|
|
}
|
|
/**
|
|
* AES KDF function for MTProto v1.
|
|
*
|
|
* @param string $msg_key Message key
|
|
* @param string $auth_key Auth key
|
|
* @param boolean $to_server To server/from server direction
|
|
*
|
|
* @internal
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function oldAesCalculate(string $msg_key, string $auth_key, bool $to_server = true): array
|
|
{
|
|
$x = $to_server ? 0 : 8;
|
|
$sha1_a = \sha1($msg_key . \substr($auth_key, $x, 32), true);
|
|
$sha1_b = \sha1(\substr($auth_key, 32 + $x, 16) . $msg_key . \substr($auth_key, 48 + $x, 16), true);
|
|
$sha1_c = \sha1(\substr($auth_key, 64 + $x, 32) . $msg_key, true);
|
|
$sha1_d = \sha1($msg_key . \substr($auth_key, 96 + $x, 32), true);
|
|
$aes_key = \substr($sha1_a, 0, 8) . \substr($sha1_b, 8, 12) . \substr($sha1_c, 4, 12);
|
|
$aes_iv = \substr($sha1_a, 8, 12) . \substr($sha1_b, 0, 8) . \substr($sha1_c, 16, 4) . \substr($sha1_d, 0, 8);
|
|
return [$aes_key, $aes_iv];
|
|
}
|
|
/**
|
|
* CTR encrypt.
|
|
*
|
|
* @param string $message Message to encrypt
|
|
* @param string $key Key
|
|
* @param string $iv IV
|
|
*
|
|
* @internal
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function ctrEncrypt(string $message, string $key, string $iv): string
|
|
{
|
|
$cipher = new \tgseclib\Crypt\AES('ctr');
|
|
$cipher->setKey($key);
|
|
$cipher->setIV($iv);
|
|
return @$cipher->encrypt($message);
|
|
}
|
|
/**
|
|
* IGE encrypt.
|
|
*
|
|
* @param string $message Message to encrypt
|
|
* @param string $key Key
|
|
* @param string $iv IV
|
|
*
|
|
* @internal
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function igeEncrypt(string $message, string $key, string $iv): string
|
|
{
|
|
$cipher = new \tgseclib\Crypt\AES('ige');
|
|
$cipher->setKey($key);
|
|
$cipher->setIV($iv);
|
|
return @$cipher->encrypt($message);
|
|
}
|
|
/**
|
|
* CTR decrypt.
|
|
*
|
|
* @param string $message Message to encrypt
|
|
* @param string $key Key
|
|
* @param string $iv IV
|
|
*
|
|
* @internal
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function igeDecrypt(string $message, string $key, string $iv): string
|
|
{
|
|
$cipher = new \tgseclib\Crypt\AES('ige');
|
|
$cipher->setKey($key);
|
|
$cipher->setIV($iv);
|
|
return @$cipher->decrypt($message);
|
|
}
|
|
}
|