| // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 
 | // Use of this source code is governed by a BSD-style license that can be | 
 | // found in the LICENSE file. | 
 |  | 
 | #ifndef CRYPTO_SIGNATURE_CREATOR_H_ | 
 | #define CRYPTO_SIGNATURE_CREATOR_H_ | 
 |  | 
 | #include <vector> | 
 |  | 
 | #include "build/build_config.h" | 
 | #include "base/basictypes.h" | 
 | #include "crypto/crypto_export.h" | 
 |  | 
 | #if defined(USE_OPENSSL) | 
 | // Forward declaration for openssl/*.h | 
 | typedef struct env_md_ctx_st EVP_MD_CTX; | 
 | #elif defined(USE_NSS) || defined(OS_WIN) || defined(OS_MACOSX) | 
 | // Forward declaration. | 
 | struct SGNContextStr; | 
 | #endif | 
 |  | 
 | namespace crypto { | 
 |  | 
 | class RSAPrivateKey; | 
 |  | 
 | // Signs data using a bare private key (as opposed to a full certificate). | 
 | // Currently can only sign data using SHA-1 or SHA-256 with RSA PKCS#1v1.5. | 
 | class CRYPTO_EXPORT SignatureCreator { | 
 |  public: | 
 |   // The set of supported hash functions. Extend as required. | 
 |   enum HashAlgorithm { | 
 |     SHA1, | 
 |     SHA256, | 
 |   }; | 
 |  | 
 |   ~SignatureCreator(); | 
 |  | 
 |   // Create an instance. The caller must ensure that the provided PrivateKey | 
 |   // instance outlives the created SignatureCreator. Uses the HashAlgorithm | 
 |   // specified. | 
 |   static SignatureCreator* Create(RSAPrivateKey* key, HashAlgorithm hash_alg); | 
 |  | 
 |  | 
 |   // Signs the precomputed |hash_alg| digest |data| using private |key| as | 
 |   // specified in PKCS #1 v1.5. | 
 |   static bool Sign(RSAPrivateKey* key, | 
 |                    HashAlgorithm hash_alg, | 
 |                    const uint8* data, | 
 |                    int data_len, | 
 |                    std::vector<uint8>* signature); | 
 |  | 
 |   // Update the signature with more data. | 
 |   bool Update(const uint8* data_part, int data_part_len); | 
 |  | 
 |   // Finalize the signature. | 
 |   bool Final(std::vector<uint8>* signature); | 
 |  | 
 |  private: | 
 |   // Private constructor. Use the Create() method instead. | 
 |   SignatureCreator(); | 
 |  | 
 | #if defined(USE_OPENSSL) | 
 |   EVP_MD_CTX* sign_context_; | 
 | #elif defined(USE_NSS) || defined(OS_WIN) || defined(OS_MACOSX) | 
 |   SGNContextStr* sign_context_; | 
 | #endif | 
 |  | 
 |   DISALLOW_COPY_AND_ASSIGN(SignatureCreator); | 
 | }; | 
 |  | 
 | }  // namespace crypto | 
 |  | 
 | #endif  // CRYPTO_SIGNATURE_CREATOR_H_ |