Some checks failed
Docker. / Ubuntu (push) Has been cancelled
User-agent updater. / User-agent (push) Failing after 15s
Lock Threads / lock (push) Failing after 10s
Waiting for answer. / waiting-for-answer (push) Failing after 22s
Close stale issues and PRs / stale (push) Successful in 13s
Needs user action. / needs-user-action (push) Failing after 8s
Can't reproduce. / cant-reproduce (push) Failing after 8s
39 lines
921 B
C++
39 lines
921 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"
|
|
|
|
namespace openssl {
|
|
class BigNum;
|
|
} // namespace openssl
|
|
|
|
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
|