PDOS

[uia] / trunk / uia / sst / lib / sign.h  

View of /trunk/uia/sst/lib/sign.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 3672 - (download) (as text) (annotate)
Wed Jan 21 14:30:25 2009 UTC (10 months ago) by baford
File size: 2107 byte(s)
Add LGPL copyright notices, update licensing info/explanation in README
/*
 * Structured Stream Transport
 * Copyright (C) 2006-2008 Massachusetts Institute of Technology
 * Author: Bryan Ford
 *
 * This library 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 2.1 of the License, or (at your option) any later version.
 * 
 * This library 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 this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
 */
//
// SignKey: abstract base class for public-key cryptographic signing methods
//
#ifndef SST_SIGN_H
#define SST_SIGN_H

#include <QString>

class QObject;
class QByteArray;

namespace SST {

class SecureHash;

class SignKey
{
public:
	enum Type {
		Invalid = 0,		// Uninitialized or invalid key
		Public = 1,		// Public key only
		Private = 2		// Private key
	};

private:
	Type t;

public:
	// Get the type of this key
	inline Type type() const { return t; }

	// Get the short hash ID of this public or private key,
	// which is usable only for uniquely identifying the key.
	virtual QByteArray id() const = 0;

	// Get this Ident's binary-encoded public or private key.
	virtual QByteArray key(bool getPrivateKey = false) const = 0;

	// Create a new SecureHash object suitable for hashing messages
	// to be signed using this identity's private key.
	virtual SecureHash *newHash(QObject *parent = 0) const = 0;

	// Generate or verify a signature
	virtual QByteArray sign(const QByteArray &digest) const = 0;
	virtual bool verify(const QByteArray &digest,
				const QByteArray &sig) const = 0;

	virtual ~SignKey();

protected:
	SignKey();

	inline void setType(Type t) { this->t = t; }
};

} // namespace SST

#endif	// SST_SIGN_H

Maintained by PDOS
ViewVC Help
Powered by ViewVC 1.0.3