~ubuntu-branches/ubuntu/quantal/poco/quantal

« back to all changes in this revision

Viewing changes to Crypto/src/RSADigestEngine.cpp

  • Committer: Bazaar Package Importer
  • Author(s): Krzysztof Burghardt
  • Date: 2008-11-15 11:39:15 UTC
  • mfrom: (3.1.1 sid)
  • Revision ID: james.westby@ubuntu.com-20081115113915-7kauhm2c3m2i7oid
Tags: 1.3.3p1-2
* Fixed FTBFS with GCC 4.4 due to missing #include (Closes: #505619)
* Renamed 20_gcc43-missing-include.dpatch to 20_gcc44-missing-include.dpatch
* Downgraded dependencies on -dbg packages (Closes: #504342)

Show diffs side-by-side

added added

removed removed

Lines of Context:
 
1
//
 
2
// RSADigestEngine.cpp
 
3
//
 
4
// $Id: //poco/1.3/Crypto/src/RSADigestEngine.cpp#1 $
 
5
//
 
6
// Library: Crypto
 
7
// Package: CryptoCore
 
8
// Module:  RSADigestEngine
 
9
//
 
10
// Copyright (c) 2008, Applied Informatics Software Engineering GmbH.
 
11
// and Contributors.
 
12
//
 
13
// Permission is hereby granted, free of charge, to any person or organization
 
14
// obtaining a copy of the software and accompanying documentation covered by
 
15
// this license (the "Software") to use, reproduce, display, distribute,
 
16
// execute, and transmit the Software, and to prepare derivative works of the
 
17
// Software, and to permit third-parties to whom the Software is furnished to
 
18
// do so, all subject to the following:
 
19
// 
 
20
// The copyright notices in the Software and this entire statement, including
 
21
// the above license grant, this restriction and the following disclaimer,
 
22
// must be included in all copies of the Software, in whole or in part, and
 
23
// all derivative works of the Software, unless such copies or derivative
 
24
// works are solely in the form of machine-executable object code generated by
 
25
// a source language processor.
 
26
// 
 
27
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 
28
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 
29
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
 
30
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
 
31
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
 
32
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
 
33
// DEALINGS IN THE SOFTWARE.
 
34
//
 
35
 
 
36
 
 
37
#include "Poco/Crypto/RSADigestEngine.h"
 
38
#include <openssl/pem.h>
 
39
 
 
40
 
 
41
namespace Poco {
 
42
namespace Crypto {
 
43
 
 
44
 
 
45
RSADigestEngine::RSADigestEngine(const RSAKey& key):
 
46
        _key(key),
 
47
        _sig(),
 
48
        _sha1()
 
49
{
 
50
        _sig = DigestEngine::Digest(key.size());
 
51
}
 
52
 
 
53
 
 
54
RSADigestEngine::~RSADigestEngine()
 
55
{
 
56
}
 
57
 
 
58
 
 
59
unsigned RSADigestEngine::digestLength() const
 
60
{
 
61
        return _sha1.digestLength();
 
62
}
 
63
 
 
64
 
 
65
void RSADigestEngine::reset()
 
66
{
 
67
        _sha1.reset();
 
68
        _sig = DigestEngine::Digest(_key.size());
 
69
}
 
70
 
 
71
        
 
72
const DigestEngine::Digest& RSADigestEngine::digest()
 
73
{
 
74
        return _sha1.digest();
 
75
}
 
76
 
 
77
 
 
78
const DigestEngine::Digest& RSADigestEngine::signature()
 
79
{
 
80
        const DigestEngine::Digest& digest = _sha1.digest();
 
81
        unsigned int sigLen = _sig.size();
 
82
        RSA_sign(NID_sha1, &digest[0], (unsigned int)digest.size(), &_sig[0], &sigLen, _key.impl()->getRSA());
 
83
        // truncate _sig to sigLen
 
84
        if (sigLen < _sig.size())
 
85
                _sig.resize(sigLen);
 
86
    return _sig;
 
87
}
 
88
 
 
89
        
 
90
void RSADigestEngine::verify(const DigestEngine::Digest& sig)
 
91
{
 
92
        const DigestEngine::Digest& digest = _sha1.digest();
 
93
        DigestEngine::Digest sigCpy = sig; // copy becausse RSA_verify can modify sigCpy
 
94
        int ret = RSA_verify(NID_sha1, &digest[0], (unsigned int)digest.size(), &sigCpy[0], (unsigned int)sigCpy.size(), _key.impl()->getRSA());
 
95
        if (ret == 0)
 
96
                throw Poco::DataFormatException("Signature does not match");
 
97
}
 
98
 
 
99
 
 
100
void RSADigestEngine::updateImpl(const void* data, unsigned length)
 
101
{
 
102
        _sha1.update(data, length);
 
103
}
 
104
 
 
105
 
 
106
} } // namespace Poco::Crypto