TrinityCore
Trinity::Crypto::SRP::BnetSRP6Base Class Referenceabstract

#include <SRP6.h>

+ Inheritance diagram for Trinity::Crypto::SRP::BnetSRP6Base:

Public Member Functions

 BnetSRP6Base (BigNumber const &i, Salt const &salt, Verifier const &verifier, BigNumber const &N, BigNumber const &g, BigNumber const &k)
 
 BnetSRP6Base (ForRegistrationTag t)
 
BigNumber CalculateServerEvidence (BigNumber const &A, BigNumber const &clientM1, BigNumber const &K) const final
 
virtual uint8 GetVersion () const =0
 
virtual uint32 GetXIterations () const =0
 
- Public Member Functions inherited from Trinity::Crypto::SRP::SRP6
 SRP6 (BigNumber const &i, Salt const &salt, Verifier const &verifier, BigNumber const &N, BigNumber const &g, BigNumber const &k)
 
 SRP6 (ForRegistrationTag)
 
 SRP6 (SRP6 const &)=delete
 
 SRP6 (SRP6 &&)=delete
 
SRP6operator= (SRP6 const &)=delete
 
SRP6operator= (SRP6 &&)=delete
 
virtual ~SRP6 ()=default
 
virtual BigNumber const & GetN () const =0
 
virtual BigNumber const & Getg () const =0
 
Optional< BigNumberVerifyClientEvidence (BigNumber const &A, BigNumber const &clientM1)
 
virtual BigNumber CalculateServerEvidence (BigNumber const &A, BigNumber const &clientM1, BigNumber const &K) const =0
 
bool CheckCredentials (std::string const &username, std::string const &password) const
 

Protected Member Functions

Optional< BigNumberDoVerifyClientEvidence (BigNumber const &A, BigNumber const &clientM1) final
 
virtual BigNumber CalculateU (BigNumber const &A) const =0
 
virtual BigNumber DoCalculateEvidence (std::span< BigNumber const * > bns) const =0
 
template<typename CryptoHash >
BigNumber DoCalculateEvidence (std::span< BigNumber const * > bns) const
 
- Protected Member Functions inherited from Trinity::Crypto::SRP::SRP6
BigNumber CalculatePublicB (BigNumber const &N, BigNumber const &g, BigNumber const &k) const
 
virtual BigNumber CalculateX (std::string const &username, std::string const &password, Salt const &salt) const =0
 
Verifier CalculateVerifier (std::string const &username, std::string const &password, Salt const &salt) const
 
virtual Optional< BigNumberDoVerifyClientEvidence (BigNumber const &A, BigNumber const &clientM1)=0
 

Static Protected Member Functions

static std::vector< uint8GetBrokenEvidenceVector (BigNumber const &bn)
 
- Static Protected Member Functions inherited from Trinity::Crypto::SRP::SRP6
static BigNumber CalculatePrivateB (BigNumber const &N)
 

Additional Inherited Members

- Static Public Member Functions inherited from Trinity::Crypto::SRP::SRP6
template<typename Impl >
static std::pair< Salt, VerifierMakeRegistrationData (std::string const &username, std::string const &password)
 
- Public Attributes inherited from Trinity::Crypto::SRP::SRP6
Salt const s
 
BigNumber const B
 
- Protected Attributes inherited from Trinity::Crypto::SRP::SRP6
BigNumber const I
 
BigNumber const b
 
BigNumber const v
 

Detailed Description

Definition at line 121 of file SRP6.h.

Constructor & Destructor Documentation

◆ BnetSRP6Base() [1/2]

Trinity::Crypto::SRP::BnetSRP6Base::BnetSRP6Base ( BigNumber const &  i,
Salt const &  salt,
Verifier const &  verifier,
BigNumber const &  N,
BigNumber const &  g,
BigNumber const &  k 
)
explicit

Definition at line 152 of file SRP6.cpp.

◆ BnetSRP6Base() [2/2]

Trinity::Crypto::SRP::BnetSRP6Base::BnetSRP6Base ( ForRegistrationTag  t)
inlineexplicit

Definition at line 125 of file SRP6.h.

Member Function Documentation

◆ CalculateServerEvidence()

BigNumber Trinity::Crypto::SRP::BnetSRP6Base::CalculateServerEvidence ( BigNumber const &  A,
BigNumber const &  clientM1,
BigNumber const &  K 
) const
finalvirtual

Implements Trinity::Crypto::SRP::SRP6.

Definition at line 157 of file SRP6.cpp.

+ Here is the call graph for this function:

◆ CalculateU()

virtual BigNumber Trinity::Crypto::SRP::BnetSRP6Base::CalculateU ( BigNumber const &  A) const
protectedpure virtual

Implemented in Trinity::Crypto::SRP::BnetSRP6v1< CryptoHash >, and Trinity::Crypto::SRP::BnetSRP6v2< CryptoHash >.

+ Here is the caller graph for this function:

◆ DoCalculateEvidence() [1/2]

template<typename CryptoHash >
BigNumber Trinity::Crypto::SRP::BnetSRP6Base::DoCalculateEvidence ( std::span< BigNumber const * >  bns) const
inlineprotected

Definition at line 140 of file SRP6.h.

◆ DoCalculateEvidence() [2/2]

virtual BigNumber Trinity::Crypto::SRP::BnetSRP6Base::DoCalculateEvidence ( std::span< BigNumber const * >  bns) const
protectedpure virtual

Implemented in Trinity::Crypto::SRP::BnetSRP6v1< CryptoHash >, and Trinity::Crypto::SRP::BnetSRP6v2< CryptoHash >.

+ Here is the caller graph for this function:

◆ DoVerifyClientEvidence()

Optional< BigNumber > Trinity::Crypto::SRP::BnetSRP6Base::DoVerifyClientEvidence ( BigNumber const &  A,
BigNumber const &  clientM1 
)
finalprotectedvirtual

Implements Trinity::Crypto::SRP::SRP6.

Definition at line 163 of file SRP6.cpp.

+ Here is the call graph for this function:

◆ GetBrokenEvidenceVector()

std::vector< uint8 > Trinity::Crypto::SRP::BnetSRP6Base::GetBrokenEvidenceVector ( BigNumber const &  bn)
staticprotected

Definition at line 183 of file SRP6.cpp.

+ Here is the call graph for this function:

◆ GetVersion()

virtual uint8 Trinity::Crypto::SRP::BnetSRP6Base::GetVersion ( ) const
pure virtual

◆ GetXIterations()

virtual uint32 Trinity::Crypto::SRP::BnetSRP6Base::GetXIterations ( ) const
pure virtual

The documentation for this class was generated from the following files: