crypto/weakcrypto/inc/randsvr.h
author MattD <mattd@symbian.org>
Mon, 14 Sep 2009 13:51:57 +0100
changeset 5 d938dcc0238a
parent 0 2c201484c85f
child 8 35751d3474b7
permissions -rw-r--r--
Added tag PDK_2.0.e for changeset 8e4b1aa36db9

/*
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
* Random Server Codes
*
*/




/**
 @file 
 @internalTechnology
*/
 
#ifndef __RANDSVR_H__
#define __RANDSVR_H__

#include <e32base.h>
#include <hash.h>


/** 
@publishedPartner
@released
*/
IMPORT_C TInt RunRandomServer(TAny* /*someParameters*/);

const TInt KRandomBlockSize=1024;
const TInt KRandomPoolSize=2048;

/**
 *
 * @internalTechnology
 */
class CRandomScheduler:public CActiveScheduler
	{
public:
	static TBool New(void);
	void Error(TInt aError) const;
	};

class CRandomSession;

/**
 *
 * @internalTechnology
 */
class CRandomServer : public CServer2
	{
public:
	static TInt New(void);
	~CRandomServer(void);
	CSession2* NewSessionL(const TVersion& aVersion, const RMessage2& aMessage) const;
	friend class CRandomSession;
private:
	CRandomServer(void);
	void ConstructL(void);
	void Stir(void);
	TPtrC8 GetRandom(void); 
	CMessageDigest* Hash(void) const;
	static TInt Tick(TAny* aPointer);
	TUint8* iPool;
	TInt iPoolIn;
	TInt iPoolOut;
	TInt iQuality;
	TBool iFast;
	CMessageDigest* iHash;
	CPeriodic* iTicker;
	};

/**
 *
 * @internalTechnology
 */
class CRandomSession : public CSession2 
	{
public:
	enum { KRandomRequest };
	static CRandomSession* NewL(CRandomServer* aServer);
	~CRandomSession(void);
	void ServiceL(const RMessage2& aMessage);
private:
	TInt FillBuffer(const RMessage2& aMessage);
	CRandomServer* iServer;
	CRandomSession(CRandomServer* aServer);
	};

#endif