keyring and message work

This commit is contained in:
Mirek Kratochvil 2013-01-04 12:43:36 +01:00
parent be9acd4984
commit 814c7642af
4 changed files with 187 additions and 5 deletions

View file

@ -16,8 +16,41 @@
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _ccr_sigs_h_
#define _ccr_sigs_h_
#include "keyring.h"
#endif
bool keyring::disk_sync()
{
return false;
}
sencode* keyring::get_pubkey (const std::string&key_id)
{
}
void keyring::remove_pubkey (const std::string&key_id)
{
}
bool keyring::store_pubkey (const std::string&key_id, sencode*)
{
}
sencode* keyring::get_privkey (const std::string&key_id)
{
}
void keyring::remove_privkey (const std::string&key_id)
{
}
bool keyring::store_privkey (const std::string&key_id, sencode*)
{
}

View file

@ -16,9 +16,26 @@
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _ccr_enc_h_
#define _ccr_enc_h_
#ifndef _ccr_keys_h_
#define _ccr_keys_h_
#include <string>
#include "sencode.h"
class keyring
{
public:
bool disk_sync();
sencode* get_pubkey (const std::string&key_id);
void remove_pubkey (const std::string&key_id);
bool store_pubkey (const std::string&key_id, sencode*);
sencode* get_privkey (const std::string&key_id);
void remove_privkey (const std::string&key_id);
bool store_privkey (const std::string&key_id, sencode*);
};
#endif

93
src/message.cpp Normal file
View file

@ -0,0 +1,93 @@
/*
* This file is part of Codecrypt.
*
* Codecrypt is free software: you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at
* your option) any later version.
*
* Codecrypt 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 Lesser General Public
* License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with Codecrypt. If not, see <http://www.gnu.org/licenses/>.
*/
#include "message.h"
#include "mce_qd.h"
int encrypted_msg::encrypt (const bvector&msg,
const std::string& Alg_id, const std::string& Key_id,
keyring&kr, prng&rng)
{
key_id = Key_id;
alg_id = Alg_id;
sencode*pubkey = kr.get_pubkey (key_id);
if (!pubkey) return 1; //PK not found
if (alg_id == "MCEQD-128") {
} else if (alg_id == "MCEQD-256") {
mce_qd::pubkey pk;
if (!pk.unserialize (pubkey) ) return 3; //Key unreadable
//TODO fujisaki-okamoto
} else return 2; //unknown algorithm
return 0;
}
int encrypted_msg::decrypt (bvector&msg, keyring&kr)
{
sencode*privkey = kr.get_privkey (key_id);
if (!privkey) return 1; //no key found
if (alg_id == "MCEQD-128") {
} else if (alg_id == "MCEQD-256") {
mce_qd::privkey sk;
if (!sk.unserialize (privkey) ) return 3; //key unreadable
//TODO fujisaki-okamoto
} else return 2; //unknown algorithm
return 0;
}
int signed_msg::sign (const bvector&msg,
const std::string& Alg_id, const std::string&Key_id,
keyring&kr, prng&rng)
{
key_id = Key_id;
alg_id = Alg_id;
message = msg;
sencode*privkey = kr.get_privkey (key_id);
if (!privkey) return 1;
if (alg_id == "FMTSEQ-S256-128") {
} else if (alg_id == "FMTSEQ-S256-256") {
//TODO produce a reasonable signature
} else return 2; //unknown algorithm
}
int signed_msg::verify (keyring&kr)
{
sencode*pubkey = kr.get_pubkey (key_id);
if (!pubkey) return 1;
if (alg_id == "FMTSEQ-S256-128") {
//TODO check it
} else if (alg_id == "FMTSEQ-S256-256") {
} else return 2; //unknown algorithm
return 0;
}

View file

@ -19,5 +19,44 @@
#ifndef _ccr_msg_h_
#define _ccr_msg_h_
#include <string>
#include "bvector.h"
#include "sencode.h"
#include "keyring.h"
#include "prng.h"
class encrypted_msg
{
public:
bvector message;
std::string alg_id, key_id;
int decrypt (bvector&, keyring&);
int encrypt (const bvector& msg,
const std::string& alg_id,
const std::string& key_id,
keyring&, prng&);
sencode* serialize();
bool unserialize (sencode*);
};
class signed_msg
{
public:
bvector message, signature;
std::string alg_id, key_id;
int verify (keyring&);
int sign (const bvector&msg,
const std::string&alg_id,
const std::string&key_id,
keyring&, prng&);
sencode* serialize();
bool unserialize (sencode*);
};
#endif