cryptoservices/certificateandkeymgmt/tcertstore/T_unifiedcertstoreactiongetcert.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Thu, 10 Sep 2009 14:01:51 +0300
changeset 8 35751d3474b7
parent 0 2c201484c85f
permissions -rw-r--r--
Revision: 200935

/*
* Copyright (c) 2005-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: 
*
*/


/**
 @file
*/

#include "t_unifiedcertstoreactiongetcert.h"
#include "t_input.h"
#include "t_certstoredefs.h"
#include "t_certstoreout.h"

CTestAction* CUnifiedCertStoreGetCert::NewL(RFs& aFs, CConsoleBase& aConsole,
											Output& aOut, 
											const TTestActionSpec& aTestActionSpec)

	{
	CUnifiedCertStoreGetCert* self = new(ELeave) CUnifiedCertStoreGetCert(aFs, aConsole, aOut);
	CleanupStack::PushL(self);
	self->ConstructL(aTestActionSpec);
	CleanupStack::Pop(self);
	return self;
	}


CUnifiedCertStoreGetCert::~CUnifiedCertStoreGetCert()
	{
	if (iCertInfo)
		iCertInfo->Release();
	}

CUnifiedCertStoreGetCert::CUnifiedCertStoreGetCert(RFs& aFs, CConsoleBase& aConsole,	
												   Output& aOut)
: CCertStoreTestAction(aFs, aConsole, aOut),
iState(EGetCert)
	{
	}

void CUnifiedCertStoreGetCert::ConstructL(const TTestActionSpec& aTestActionSpec)
	{
	CCertStoreTestAction::ConstructL(aTestActionSpec);
	TInt pos = 0;
	TInt err = KErrNone;
	TLex8 lex(Input::ParseElement(aTestActionSpec.iActionBody, KTokenTypeStart, KTokenTypeEnd, pos, err));
	if (err != KErrNone)
		{
		User::Leave(err);
		}
	TUid uid;
	lex.Val(uid.iUid); // check for error

	TInt token;
	lex = TLex8(Input::ParseElement(aTestActionSpec.iActionBody, KTokenStart, KTokenEnd, pos, err));
	lex.Val(token);

	TInt object;
	lex = TLex8(Input::ParseElement(aTestActionSpec.iActionBody, KObjectStart, KObjectEnd, pos, err));
	lex.Val(object);

	iHandle = TCTTokenObjectHandle(TCTTokenHandle(uid, token), object);

	pos = 0;

	HBufC* result = HBufC::NewLC(aTestActionSpec.iActionResult.Length());
	TPtr(result->Des()).Copy(aTestActionSpec.iActionResult);
	Input::GetExpectedResultL(Input::ParseElement(*result, KReturnStart, KReturnEnd), iExpectedResult);
	CleanupStack::PopAndDestroy(result);
	}

void CUnifiedCertStoreGetCert::PerformAction(TRequestStatus& aStatus)
	{
	switch (iState)
		{
	case EGetCert:
		CertStore().GetCert(iCertInfo, iHandle, aStatus);
		iState = EFinished;
		break;

	case EFinished:
		{
		if (aStatus == iExpectedResult)
			{
			iResult = ETrue;
			}
		else
			{
			iResult = EFalse;
			}
		iFinished = ETrue;
		TRequestStatus* status = &aStatus;
		User::RequestComplete(status, KErrNone);
		break;
		}
	
	// The initial state is set to EGetCert and the default case would
	// never be reached.
	default:
		iResult = EFalse;
		iFinished = ETrue;
		TRequestStatus* status = &aStatus;
		User::RequestComplete(status, KErrNotSupported);
		break;
		}
	}

void CUnifiedCertStoreGetCert::PerformCancel()
	{
	}

void CUnifiedCertStoreGetCert::Reset()
	{
	__ASSERT_DEBUG(EFalse, User::Panic(_L("CUnifiedCertStoreGetCert::Reset()"), 1));
	}

void CUnifiedCertStoreGetCert::DoReportAction()
	{
	//iOut.writeString(_L("Setting trust settings..."));
	iOut.writeHex(iHandle.iTokenHandle.iTokenTypeUid.iUid);
	//iOut.writeNewLine();
	//iOut.writeString(_L("\tLabel = "));
//	iOut.writeString(iLabel);
//	iOut.writeNewLine();
	//iOut.writeString(_L("\tTrusters = "));
	//TInt count = iTrusters->Count();
	//for (TInt i = 0; i < count; i++)
	//	{
	//	iOut.writeNum((*iTrusters)[i].iUid);
	//	iOut.writeString(_L(" "));
	//	}
	//iOut.writeNewLine();
	//iOut.writeNewLine();
	}	

void CUnifiedCertStoreGetCert::DoCheckResult(TInt /*aError*/)
	{
	}