Files
pcp/bindings/cpp/sign.cpp

160 lines
3.5 KiB
C++
Raw Normal View History

2013-12-07 13:24:44 +01:00
/*
This file is part of Pretty Curved Privacy (pcp1).
Copyright (C) 2013-2014 T.c.Dein.
2013-12-07 13:24:44 +01:00
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
You can contact me by mail: <tom AT vondein DOT org>.
2013-12-07 13:24:44 +01:00
*/
#include "sign++.h"
using namespace std;
using namespace pcp;
2014-05-06 11:49:31 +02:00
Signature::Signature(PcpContext &P, Key &skey) {
2013-12-07 13:24:44 +01:00
S = skey;
PTX = P;
2013-12-07 13:24:44 +01:00
havevault = false;
}
2014-05-06 11:49:31 +02:00
Signature::Signature(PcpContext &C,PubKey &pkey) {
2013-12-07 13:24:44 +01:00
P = pkey;
PTX = C;
2013-12-07 13:24:44 +01:00
havevault = false;
}
2014-05-06 11:49:31 +02:00
Signature::Signature(PcpContext &C,Key &skey, PubKey &pkey) {
2013-12-07 13:24:44 +01:00
P = pkey;
S = skey;
PTX = C;
2013-12-07 13:24:44 +01:00
havevault = false;
}
2014-05-06 11:49:31 +02:00
Signature::Signature(PcpContext &P,Vault &v) {
2013-12-07 13:24:44 +01:00
vault = v;
havevault = true;
PTX = P;
2013-12-07 13:24:44 +01:00
S = vault.get_primary();
}
Signature::~Signature() {
}
bool Signature::sign(std::vector<unsigned char> message) {
if(! S)
throw exception(PTX, "Error: cannot sign without a secret key, use another constructor.");
if(S.is_encrypted())
throw exception(PTX, "Error: cannot sign with an encrypted secret key, decrypt it before using.");
char n[] = "signvec";
Buffer *m = buffer_new(32, n);
2013-12-07 13:24:44 +01:00
for(size_t i=0; i<message.size(); ++i)
buffer_add8(m, message[i]);
Pcpstream *p = ps_new_inbuffer(m);
bool ok = Signature::sign(p);
ps_close(p);
buffer_free(m);
if(!ok)
throw exception(PTX);
return true;
2013-12-07 13:24:44 +01:00
}
bool Signature::sign(unsigned char *message, size_t mlen) {
2013-12-07 13:24:44 +01:00
if(! S)
throw exception(PTX, "Error: cannot sign without a secret key, use another constructor.");
2013-12-07 13:24:44 +01:00
if(S.is_encrypted())
throw exception(PTX, "Error: cannot sign with an encrypted secret key, decrypt it before using.");
2013-12-07 13:24:44 +01:00
char n[] = "signchar";
Buffer *m = buffer_new(32, n);
buffer_add(m, message, mlen);
Pcpstream *p = ps_new_inbuffer(m);
bool ok = Signature::sign(p);
ps_close(p);
buffer_free(m);
2013-12-07 13:24:44 +01:00
if(! ok)
throw exception(PTX);
2013-12-07 13:24:44 +01:00
return true;
2013-12-07 13:24:44 +01:00
}
bool Signature::sign(Pcpstream *message) {
Pcpstream *out = ps_new_outbuffer();
size_t sigsize = pcp_ed_sign_buffered(PTX.ptx, message, out, S.K, 0);
if(sigsize > 0) {
Buffer *o = ps_buffer(out);
sig.add_buf(o);
}
else {
ps_close(out);
return false;
}
ps_close(out);
return true;
}
bool Signature::verify(vector<unsigned char> message) {
if(!P) {
throw exception(PTX, "No public key specified, unable to verify.");
}
Buf _sig = Buf();
2013-12-07 13:24:44 +01:00
for(size_t i=0; i<message.size(); ++i)
_sig.add8(message[i]);
return Signature::verify(_sig);
2013-12-07 13:24:44 +01:00
}
bool Signature::verify(unsigned char *signature, size_t mlen) {
2013-12-07 13:24:44 +01:00
if(!P) {
throw exception(PTX, "No public key specified, unable to verify.");
2013-12-07 13:24:44 +01:00
}
Buf _sig = Buf();
_sig.add(signature, mlen);
return Signature::verify(_sig);
}
bool Signature::verify(Buf _sig) {
Pcpstream *p = ps_new_inbuffer(_sig.get_buffer());
pcp_pubkey_t *pub = pcp_ed_verify_buffered(PTX.ptx, p, P.K);
ps_close(p);
if(pub != NULL) {
Signedby = PubKey(PTX, pub);
2013-12-07 13:24:44 +01:00
return true;
}
else {
throw exception(PTX);
2013-12-07 13:24:44 +01:00
}
}