Team Fortress 2 Source Code as on 22/4/2020
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

43 lines
1.5 KiB

  1. #ifndef CRYPTOPP_OAEP_H
  2. #define CRYPTOPP_OAEP_H
  3. #include "cryptlib.h"
  4. #include "pubkey.h"
  5. #include "sha.h"
  6. NAMESPACE_BEGIN(CryptoPP)
  7. //! _
  8. class CRYPTOPP_DLL OAEP_Base : public PK_EncryptionMessageEncodingMethod
  9. {
  10. public:
  11. bool ParameterSupported(const char *name) const {return strcmp(name, Name::EncodingParameters()) == 0;}
  12. size_t MaxUnpaddedLength(size_t paddedLength) const;
  13. void Pad(RandomNumberGenerator &rng, const byte *raw, size_t inputLength, byte *padded, size_t paddedLength, const NameValuePairs &parameters) const;
  14. DecodingResult Unpad(const byte *padded, size_t paddedLength, byte *raw, const NameValuePairs &parameters) const;
  15. protected:
  16. virtual unsigned int DigestSize() const =0;
  17. virtual HashTransformation * NewHash() const =0;
  18. virtual MaskGeneratingFunction * NewMGF() const =0;
  19. };
  20. //! <a href="http://www.weidai.com/scan-mirror/ca.html#cem_OAEP-MGF1">EME-OAEP</a>, for use with classes derived from TF_ES
  21. template <class H, class MGF=P1363_MGF1>
  22. class OAEP : public OAEP_Base, public EncryptionStandard
  23. {
  24. public:
  25. static std::string CRYPTOPP_API StaticAlgorithmName() {return std::string("OAEP-") + MGF::StaticAlgorithmName() + "(" + H::StaticAlgorithmName() + ")";}
  26. typedef OAEP<H, MGF> EncryptionMessageEncodingMethod;
  27. protected:
  28. unsigned int DigestSize() const {return H::DIGESTSIZE;}
  29. HashTransformation * NewHash() const {return new H;}
  30. MaskGeneratingFunction * NewMGF() const {return new MGF;}
  31. };
  32. CRYPTOPP_DLL_TEMPLATE_CLASS OAEP<SHA>;
  33. NAMESPACE_END
  34. #endif