os/security/cryptoservices/filebasedcertificateandkeystores/test/certtool/certtool_setapps.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2004-2009 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of the License "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description: 
sl@0
    15
*
sl@0
    16
*/
sl@0
    17
sl@0
    18
sl@0
    19
#include "certtool_commands.h"
sl@0
    20
#include "certtool_controller.h"
sl@0
    21
sl@0
    22
sl@0
    23
/*static*/ CCertToolSetApps* CCertToolSetApps::NewLC(CCertToolController* aController)
sl@0
    24
	{
sl@0
    25
	CCertToolSetApps* self = new (ELeave) CCertToolSetApps(aController);
sl@0
    26
	CleanupStack::PushL(self);
sl@0
    27
	self->ConstructL();
sl@0
    28
	return self;
sl@0
    29
	}
sl@0
    30
	
sl@0
    31
/*static*/ CCertToolSetApps* CCertToolSetApps::NewL(CCertToolController* aController)
sl@0
    32
	{
sl@0
    33
	CCertToolSetApps* self = CCertToolSetApps::NewLC(aController);
sl@0
    34
	CleanupStack::Pop(self);
sl@0
    35
	return self;
sl@0
    36
	}
sl@0
    37
sl@0
    38
CCertToolSetApps::CCertToolSetApps(CCertToolController* aController) : CCertToolList(aController), iCertIndex (-1)
sl@0
    39
	{
sl@0
    40
	}
sl@0
    41
sl@0
    42
	
sl@0
    43
CCertToolSetApps::~CCertToolSetApps()
sl@0
    44
	{
sl@0
    45
	Cancel();	
sl@0
    46
	}
sl@0
    47
sl@0
    48
void CCertToolSetApps::RunL()
sl@0
    49
	{
sl@0
    50
	if (iStatus.Int() != KErrNone)
sl@0
    51
		{
sl@0
    52
		// A problem occured. Handle gracefully.
sl@0
    53
		User::Leave(iStatus.Int());
sl@0
    54
		}	
sl@0
    55
		
sl@0
    56
	switch (iState)
sl@0
    57
		{	 
sl@0
    58
		case EListCerts:
sl@0
    59
			{
sl@0
    60
			if (iCertInfos.Count()==0)
sl@0
    61
				{
sl@0
    62
				iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_EMPTY);
sl@0
    63
				CActiveScheduler::Stop();				
sl@0
    64
				}
sl@0
    65
			else
sl@0
    66
				{ 
sl@0
    67
				if (iParams->iDefault)    
sl@0
    68
					{
sl@0
    69
					// Look for a specific certificate					
sl@0
    70
					for (TInt j = 0; j < iCertInfos.Count(); j++)
sl@0
    71
						{
sl@0
    72
						if (iCertInfos[j]->Label() == *iParams->iDefault) 
sl@0
    73
							{
sl@0
    74
							iCertIndex = j;
sl@0
    75
							break;
sl@0
    76
							}
sl@0
    77
						}	
sl@0
    78
						
sl@0
    79
					if (iCertIndex != -1)
sl@0
    80
						{
sl@0
    81
						// Certificate found set app uids!
sl@0
    82
						if (iParams->iCertstoreIndex == -1)
sl@0
    83
							{
sl@0
    84
							iParams->iCertstoreIndex = 0;
sl@0
    85
							}
sl@0
    86
						if (iParams->iCertstoreIndex >= iCertStore->CertStoreCount())
sl@0
    87
							{
sl@0
    88
							iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTEXIST);	
sl@0
    89
							User::Leave(KErrArgument);			
sl@0
    90
							}
sl@0
    91
						if(iCertInfos[iCertIndex]->CertificateOwnerType() == ECACertificate)							
sl@0
    92
							{
sl@0
    93
							iState = ESetTrust;
sl@0
    94
							}
sl@0
    95
						else
sl@0
    96
							{
sl@0
    97
							iState = EFinished;								
sl@0
    98
							}	
sl@0
    99
						iCertStore->SetApplicability(*iCertInfos[iCertIndex], iParams->iUIDs, iStatus);
sl@0
   100
						SetActive();
sl@0
   101
						break;
sl@0
   102
						}
sl@0
   103
					else 
sl@0
   104
						{
sl@0
   105
						User::Leave(KErrNotFound);
sl@0
   106
						}			
sl@0
   107
					}
sl@0
   108
				}
sl@0
   109
			}
sl@0
   110
		case ESetTrust:
sl@0
   111
			{
sl@0
   112
			iState = EFinished;
sl@0
   113
			const TBool caCert = ETrue;
sl@0
   114
			iCertStore->SetTrust(*iCertInfos[iCertIndex],caCert,iStatus);
sl@0
   115
			SetActive();				
sl@0
   116
			}
sl@0
   117
			break;
sl@0
   118
		case EFinished:
sl@0
   119
			{
sl@0
   120
			iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_SETAPPS_SUCCESS);				
sl@0
   121
			CActiveScheduler::Stop();			
sl@0
   122
			}
sl@0
   123
			break;
sl@0
   124
		default:
sl@0
   125
			{
sl@0
   126
			User::Panic(_L("SETAPPS action: Illegal state."), 1);
sl@0
   127
			}
sl@0
   128
		}
sl@0
   129
	}
sl@0
   130
sl@0
   131
sl@0
   132
TInt CCertToolSetApps::RunError(TInt aError)
sl@0
   133
	{
sl@0
   134
	CActiveScheduler::Stop();
sl@0
   135
sl@0
   136
	switch (aError)
sl@0
   137
		{
sl@0
   138
		case KErrNotFound :
sl@0
   139
			{
sl@0
   140
			TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTFOUND));
sl@0
   141
			TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise));			
sl@0
   142
			}
sl@0
   143
			break;
sl@0
   144
		default:
sl@0
   145
			{
sl@0
   146
			TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_ADDAPPS_FAIL));			
sl@0
   147
			TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise));			
sl@0
   148
			}
sl@0
   149
		}	
sl@0
   150
sl@0
   151
	return KErrNone;	
sl@0
   152
	}