TrinityCore
Trinity::Crypto::SRP::BnetSRP6v2Base Class Reference

#include <SRP6.h>

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

Public Member Functions

 BnetSRP6v2Base (std::string const &username, Salt const &salt, Verifier const &verifier, BigNumber const &k)
 
 BnetSRP6v2Base (ForRegistrationTag t)
 
BigNumber const & GetN () const final
 
BigNumber const & Getg () const final
 
uint8 GetVersion () const final
 
uint32 GetXIterations () const final
 
- Public Member Functions inherited from Trinity::Crypto::SRP::BnetSRP6Base
 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
 

Static Public Attributes

static BigNumber const N = "AC6BDB41324A9A9BF166DE5E1389582FAF72B6651987EE07FC3192943DB56050A37329CBB4A099ED8193E0757767A13DD52312AB4B03310DCD7F48A9DA04FD50E8083969EDB767B0CF6095179A163AB3661A05FBD5FAAAE82918A9962F0B93B855F97993EC975EEAA80D740ADBF4FF747359D041D5C33EA71D281E446B14773BCA97B43A23FB801676BD207A436C6481F1D2B9078717461A5B9D32E688F87748544523B524B0D57D5EA77A2775D2ECFA032CFBDBF52FB3786160279004E57AE6AF874E7303CE53299CCC041C7BC308D82A5698F3A8D0C38271AE35F8E9DBFBB694B5C803D89F7AE435DE236D525F54759B65E372FCD68EF20FA7111F9E4AFF73"s
 
static BigNumber const g = 2
 

Protected Member Functions

BigNumber CalculateX (std::string const &username, std::string const &password, Salt const &salt) const final
 
- Protected Member Functions inherited from Trinity::Crypto::SRP::BnetSRP6Base
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
 

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
 
- Static Protected Member Functions inherited from Trinity::Crypto::SRP::BnetSRP6Base
static std::vector< uint8GetBrokenEvidenceVector (BigNumber const &bn)
 
- Static Protected Member Functions inherited from Trinity::Crypto::SRP::SRP6
static BigNumber CalculatePrivateB (BigNumber const &N)
 
- Protected Attributes inherited from Trinity::Crypto::SRP::SRP6
BigNumber const I
 
BigNumber const b
 
BigNumber const v
 

Detailed Description

Definition at line 172 of file SRP6.h.

Constructor & Destructor Documentation

◆ BnetSRP6v2Base() [1/2]

Trinity::Crypto::SRP::BnetSRP6v2Base::BnetSRP6v2Base ( std::string const &  username,
Salt const &  salt,
Verifier const &  verifier,
BigNumber const &  k 
)
explicit

Definition at line 202 of file SRP6.cpp.

◆ BnetSRP6v2Base() [2/2]

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

Definition at line 179 of file SRP6.h.

Member Function Documentation

◆ CalculateX()

BigNumber Trinity::Crypto::SRP::BnetSRP6v2Base::CalculateX ( std::string const &  username,
std::string const &  password,
Salt const &  salt 
) const
finalprotectedvirtual

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

Definition at line 207 of file SRP6.cpp.

+ Here is the call graph for this function:

◆ Getg()

BigNumber const & Trinity::Crypto::SRP::BnetSRP6v2Base::Getg ( ) const
inlinefinalvirtual

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

Definition at line 182 of file SRP6.h.

◆ GetN()

BigNumber const & Trinity::Crypto::SRP::BnetSRP6v2Base::GetN ( ) const
inlinefinalvirtual

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

Definition at line 181 of file SRP6.h.

◆ GetVersion()

uint8 Trinity::Crypto::SRP::BnetSRP6v2Base::GetVersion ( ) const
inlinefinalvirtual

Implements Trinity::Crypto::SRP::BnetSRP6Base.

Definition at line 184 of file SRP6.h.

◆ GetXIterations()

uint32 Trinity::Crypto::SRP::BnetSRP6v2Base::GetXIterations ( ) const
inlinefinalvirtual

Implements Trinity::Crypto::SRP::BnetSRP6Base.

Definition at line 185 of file SRP6.h.

+ Here is the caller graph for this function:

Member Data Documentation

◆ g

BigNumber const Trinity::Crypto::SRP::BnetSRP6v2Base::g = 2
static

Definition at line 176 of file SRP6.h.

◆ N

BigNumber const Trinity::Crypto::SRP::BnetSRP6v2Base::N = "AC6BDB41324A9A9BF166DE5E1389582FAF72B6651987EE07FC3192943DB56050A37329CBB4A099ED8193E0757767A13DD52312AB4B03310DCD7F48A9DA04FD50E8083969EDB767B0CF6095179A163AB3661A05FBD5FAAAE82918A9962F0B93B855F97993EC975EEAA80D740ADBF4FF747359D041D5C33EA71D281E446B14773BCA97B43A23FB801676BD207A436C6481F1D2B9078717461A5B9D32E688F87748544523B524B0D57D5EA77A2775D2ECFA032CFBDBF52FB3786160279004E57AE6AF874E7303CE53299CCC041C7BC308D82A5698F3A8D0C38271AE35F8E9DBFBB694B5C803D89F7AE435DE236D525F54759B65E372FCD68EF20FA7111F9E4AFF73"s
static

Definition at line 175 of file SRP6.h.


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