/*
This file is part of Pretty Curved Privacy (pcp1).
Copyright (C) 2013-2014 T.c.Dein.
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 .
You can contact me by mail: .
*/
#include "sign++.h"
using namespace std;
using namespace pcp;
Signature::Signature(PcpContext *ptx, Key &skey) {
S = skey;
PTX = ptx;
sig = Buf("sign2");
havevault = false;
Signedby = NULL;
}
Signature::Signature(PcpContext *C,PubKey &pkey) {
P = pkey;
PTX = C;
havevault = false;
sig = Buf("sign1");
Signedby = NULL;
}
Signature::Signature(PcpContext *C,Key &skey, PubKey &pkey) {
P = pkey;
S = skey;
PTX = C;
havevault = false;
Signedby = NULL;
}
Signature::Signature(PcpContext *C,Vault &v) {
vault = v;
havevault = true;
PTX = C;
S = vault.get_primary();
Signedby = NULL;
}
Signature::~Signature() {
if(Signedby != NULL)
delete Signedby;
}
bool Signature::sign(std::vector 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);
for(size_t i=0; iptx, 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 message) {
if(!P) {
throw exception(PTX, "No public key specified, unable to verify.");
}
Buf _sig = Buf();
for(size_t i=0; iptx, p, P.K);
ps_close(p);
if(pub != NULL) {
Signedby = new PubKey(PTX, pub);
return true;
}
else {
throw exception(PTX);
}
}