35 lines
		
	
	
	
		
			894 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			35 lines
		
	
	
	
		
			894 B
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
This file is part of Telegram Desktop,
 | 
						|
the official desktop application for the Telegram messaging service.
 | 
						|
 | 
						|
For license and copyright information please follow this link:
 | 
						|
https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL
 | 
						|
*/
 | 
						|
#pragma once
 | 
						|
 | 
						|
#include "base/bytes.h"
 | 
						|
#include "base/openssl_help.h"
 | 
						|
 | 
						|
namespace MTP {
 | 
						|
 | 
						|
struct ModExpFirst {
 | 
						|
	static constexpr auto kRandomPowerSize = 256;
 | 
						|
 | 
						|
	bytes::vector modexp;
 | 
						|
	bytes::vector randomPower;
 | 
						|
};
 | 
						|
 | 
						|
[[nodiscard]] bool IsPrimeAndGood(bytes::const_span primeBytes, int g);
 | 
						|
[[nodiscard]] bool IsGoodModExpFirst(
 | 
						|
	const openssl::BigNum &modexp,
 | 
						|
	const openssl::BigNum &prime);
 | 
						|
[[nodiscard]] ModExpFirst CreateModExp(
 | 
						|
	int g,
 | 
						|
	bytes::const_span primeBytes,
 | 
						|
	bytes::const_span randomSeed);
 | 
						|
[[nodiscard]] bytes::vector CreateAuthKey(
 | 
						|
	bytes::const_span firstBytes,
 | 
						|
	bytes::const_span randomBytes,
 | 
						|
	bytes::const_span primeBytes);
 | 
						|
 | 
						|
} // namespace MTP
 |