| Index: base/crypto/signature_creator_openssl.cc
|
| diff --git a/base/crypto/signature_creator_openssl.cc b/base/crypto/signature_creator_openssl.cc
|
| index 5d70f014a67a243d3a57e60c7e78db0e800222f1..7eed379fe820bee2fb96c72007ac8f4c6e93d550 100644
|
| --- a/base/crypto/signature_creator_openssl.cc
|
| +++ b/base/crypto/signature_creator_openssl.cc
|
| @@ -4,29 +4,50 @@
|
|
|
| #include "base/crypto/signature_creator.h"
|
|
|
| +#include <openssl/evp.h>
|
| +
|
| #include "base/logging.h"
|
| +#include "base/openssl_util.h"
|
| +#include "base/scoped_ptr.h"
|
|
|
| namespace base {
|
|
|
| // static
|
| SignatureCreator* SignatureCreator::Create(RSAPrivateKey* key) {
|
| - return NULL;
|
| + OpenSSLErrStackTracer err_tracer(FROM_HERE);
|
| + scoped_ptr<SignatureCreator> result(new SignatureCreator);
|
| + result->key_ = key;
|
| + if (!EVP_SignInit_ex(result->sign_context_, EVP_sha1(), NULL))
|
| + return NULL;
|
| + return result.release();
|
| }
|
|
|
| -SignatureCreator::SignatureCreator() {
|
| +SignatureCreator::SignatureCreator()
|
| + : sign_context_(EVP_MD_CTX_create()) {
|
| }
|
|
|
| SignatureCreator::~SignatureCreator() {
|
| + EVP_MD_CTX_destroy(sign_context_);
|
| }
|
|
|
| bool SignatureCreator::Update(const uint8* data_part, int data_part_len) {
|
| - NOTIMPLEMENTED();
|
| - return false;
|
| + OpenSSLErrStackTracer err_tracer(FROM_HERE);
|
| + return EVP_SignUpdate(sign_context_, data_part, data_part_len) == 1;
|
| }
|
|
|
| bool SignatureCreator::Final(std::vector<uint8>* signature) {
|
| - NOTIMPLEMENTED();
|
| - return false;
|
| + OpenSSLErrStackTracer err_tracer(FROM_HERE);
|
| + EVP_PKEY* key = key_->key();
|
| + signature->resize(EVP_PKEY_size(key));
|
| +
|
| + unsigned int len = 0;
|
| + int rv = EVP_SignFinal(sign_context_, signature->data(), &len, key);
|
| + if (!rv) {
|
| + signature->clear();
|
| + return false;
|
| + }
|
| + signature->resize(len);
|
| + return true;
|
| }
|
|
|
| } // namespace base
|
|
|