File: key3.cc

package info (click to toggle)
bobcat 6.11.00-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 15,292 kB
  • sloc: cpp: 21,370; fortran: 6,507; makefile: 2,787; sh: 724; perl: 401; ansic: 26
file content (16 lines) | stat: -rw-r--r-- 516 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#include "diffiehellman.ih"

BigInt const &DiffieHellman::key(istream &peerPublicStream)
{
    BigInt prime;
    BigInt generator;

    if (not(peerPublicStream >> hex >> prime >> generator >> d_peerPubKey))
        throw exception() << "could not read the peer's public key";

    if (prime != d_prime || generator != d_generator)
        throw exception() <<
            "the peer's prime and/or generator differ from "
                                                    "the current values";
    return key();
}