obex/obexprotocol/obex/src/authentication.cpp
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 0 d0791faffa3f
permissions -rw-r--r--
201044_04

// Copyright (c) 1997-2009 Nokia Corporation and/or its subsidiary(-ies).
// All rights reserved.
// This component and the accompanying materials are made available
// under the terms of "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:
//

/**
 @file
 @internalComponent
*/

#include <hash.h>
#include <e32math.h>
#include <obex.h>
#include "authentication.h"

_LIT8(KColonCharacter, ":");

CObexAuthenticator* CObexAuthenticator::NewL()
	{
	CObexAuthenticator* s = new(ELeave) CObexAuthenticator;
	CleanupStack::PushL(s);
	s->ConstructL();
	CleanupStack::Pop();
	return s;
	}

void CObexAuthenticator::ConstructL()
	{
	iMD5 = CMD5::NewL();
	}

CObexAuthenticator::CObexAuthenticator()
	{
	TTime time;
	time.UniversalTime();
	iSeed = time.Int64();
	}

CObexAuthenticator::~CObexAuthenticator()
	{
	delete iMD5;
	}

TInt CObexAuthenticator::GenerateNonce(TDes8& aNonce)
	{
	TTime time;
	time.UniversalTime();

	TInt64 randomNumber = Math::Rand(iSeed);
	randomNumber <<= 32;
	randomNumber += Math::Rand(iSeed);

	TBuf8<33> key;
	key.Zero();
	key.AppendNum(time.Int64(), EHex);
	key.Append(_L8(":"));
	key.AppendNum(randomNumber, EHex);
	
	iMD5->Reset();
	aNonce.Append(iMD5->Hash(key));
	return KErrNone;
	}

void CObexAuthenticator::GenerateResponseL(const TDesC8& aPasswd, const TNonce& aNonce, TRequestDigest& aRequestDigest)
	{
	//work out the length of buffer we need
	TInt buflen = aNonce.Length() + KColonCharacter().Length() + aPasswd.Length();
	HBufC8* buf = HBufC8::NewLC(buflen);
	TPtr8 ptr = buf->Des();
	ptr.Zero();
	ptr.Append(aNonce);
	ptr.Append(KColonCharacter);
	ptr.Append(aPasswd);
	iMD5->Reset();
	aRequestDigest.Append(iMD5->Hash(*buf));

	CleanupStack::PopAndDestroy();//buf
	}

void CObexAuthenticator::ChallengeResponseL(const TDesC8& aPasswd, const TNonce& aNonce, const TRequestDigest& aRequestDigest)
	{
	TRequestDigest digest;
	digest.Zero();
	GenerateResponseL(aPasswd, aNonce, digest);
	if (digest != aRequestDigest)
		User::Leave(KErrAccessDenied);
	}