diff -r 675a964f4eb5 -r 35751d3474b7 cryptoservices/filebasedcertificateandkeystores/test/certtool/certtool_addapps.cpp --- a/cryptoservices/filebasedcertificateandkeystores/test/certtool/certtool_addapps.cpp Tue Jul 21 01:04:32 2009 +0100 +++ b/cryptoservices/filebasedcertificateandkeystores/test/certtool/certtool_addapps.cpp Thu Sep 10 14:01:51 2009 +0300 @@ -1,173 +1,173 @@ -/* -* Copyright (c) 2004-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: -* -*/ - - -#include "certtool_commands.h" -#include "certtool_controller.h" -#include "keytool_utils.h" - -/*static*/ CCertToolAddApps* CCertToolAddApps::NewLC(CCertToolController* aController) - { - CCertToolAddApps* self = new (ELeave) CCertToolAddApps(aController); - CleanupStack::PushL(self); - self->ConstructL(); - return self; - } - -/*static*/ CCertToolAddApps* CCertToolAddApps::NewL(CCertToolController* aController) - { - CCertToolAddApps* self = CCertToolAddApps::NewLC(aController); - CleanupStack::Pop(self); - return self; - } - -CCertToolAddApps::CCertToolAddApps(CCertToolController* aController) : CCertToolList(aController) - { - } - - -CCertToolAddApps::~CCertToolAddApps() - { - Cancel(); - } - -void CCertToolAddApps::RunL() - { - if (iStatus.Int() != KErrNone) - { - // A problem occured. Handle gracefully. - User::Leave(iStatus.Int()); - } - - switch (iState) - { - case EListCerts: - { - if (iCertInfos.Count()==0) - { - iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_EMPTY); - CActiveScheduler::Stop(); - } - else - { - if (iParams->iDefault) - { - // Look for a specific certificate - TInt certIndex = -1; - for (TInt j = 0; j < iCertInfos.Count(); j++) - { - if (iCertInfos[j]->Label() == *iParams->iDefault) - { - certIndex = j; - break; - } - } - - if (certIndex != -1) - { - iIndex = certIndex; - // Certificate found set app uids! - if (iParams->iCertstoreIndex == -1) - { - iParams->iCertstoreIndex = 0; - } - if (iParams->iCertstoreIndex >= iCertStore->CertStoreCount()) - { - iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTEXIST); - User::Leave(KErrArgument); - } - iCertStore->Applications(*iCertInfos[iIndex], iApps, iStatus); - iState = ESetApps; - SetActive(); - } - else - { - User::Leave(KErrNotFound); - } - } - } - } - break; - case ESetApps: - { - if (iParams->iCertstoreIndex == -1) - { - iParams->iCertstoreIndex = 0; - } - if (iParams->iCertstoreIndex >= iCertStore->CertStoreCount()) - { - iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTEXIST); - User::Leave(KErrArgument); - } - // Check for duplicates - for (TInt k = 0; k < iParams->iUIDs.Count(); k++) - { - if (iApps.Find(iParams->iUIDs[k]) != KErrNotFound) - { - TBuf<128> msg; - const TDesC& tmp = KeyToolUtils::Uid2Des(iParams->iUIDs[k]); - msg.Format(_L("The certificate is already trusted for application %S."), &tmp); - iController->DisplayErrorL(msg, iParams->iPageWise); - User::Leave(KErrArgument); - } - } - - // add the apps to the array - for (TInt j = 0; j < iApps.Count(); j++) - { - iParams->iUIDs.Append(iApps[j]); - } - iState = EFinished; - iCertStore->SetApplicability(*iCertInfos[iIndex], iParams->iUIDs, iStatus); - SetActive(); - } - break; - case EFinished: - { - iCertInfos.Close(); - iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_ADDAPPS_SUCCESS); - CActiveScheduler::Stop(); - } - break; - default: - { - User::Panic(_L("ADDAPPS action: Illegal state."), 1); - } - } - } - -TInt CCertToolAddApps::RunError(TInt aError) - { - CActiveScheduler::Stop(); - - switch (aError) - { - case KErrNotFound : - { - TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTFOUND)); - TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise)); - } - break; - default: - { - TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_ADDAPPS_FAIL)); - TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise)); - } - } - - return KErrNone; - } +/* +* Copyright (c) 2004-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: +* +*/ + + +#include "certtool_commands.h" +#include "certtool_controller.h" +#include "keytool_utils.h" + +/*static*/ CCertToolAddApps* CCertToolAddApps::NewLC(CCertToolController* aController) + { + CCertToolAddApps* self = new (ELeave) CCertToolAddApps(aController); + CleanupStack::PushL(self); + self->ConstructL(); + return self; + } + +/*static*/ CCertToolAddApps* CCertToolAddApps::NewL(CCertToolController* aController) + { + CCertToolAddApps* self = CCertToolAddApps::NewLC(aController); + CleanupStack::Pop(self); + return self; + } + +CCertToolAddApps::CCertToolAddApps(CCertToolController* aController) : CCertToolList(aController) + { + } + + +CCertToolAddApps::~CCertToolAddApps() + { + Cancel(); + } + +void CCertToolAddApps::RunL() + { + if (iStatus.Int() != KErrNone) + { + // A problem occured. Handle gracefully. + User::Leave(iStatus.Int()); + } + + switch (iState) + { + case EListCerts: + { + if (iCertInfos.Count()==0) + { + iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_EMPTY); + CActiveScheduler::Stop(); + } + else + { + if (iParams->iDefault) + { + // Look for a specific certificate + TInt certIndex = -1; + for (TInt j = 0; j < iCertInfos.Count(); j++) + { + if (iCertInfos[j]->Label() == *iParams->iDefault) + { + certIndex = j; + break; + } + } + + if (certIndex != -1) + { + iIndex = certIndex; + // Certificate found set app uids! + if (iParams->iCertstoreIndex == -1) + { + iParams->iCertstoreIndex = 0; + } + if (iParams->iCertstoreIndex >= iCertStore->CertStoreCount()) + { + iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTEXIST); + User::Leave(KErrArgument); + } + iCertStore->Applications(*iCertInfos[iIndex], iApps, iStatus); + iState = ESetApps; + SetActive(); + } + else + { + User::Leave(KErrNotFound); + } + } + } + } + break; + case ESetApps: + { + if (iParams->iCertstoreIndex == -1) + { + iParams->iCertstoreIndex = 0; + } + if (iParams->iCertstoreIndex >= iCertStore->CertStoreCount()) + { + iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTEXIST); + User::Leave(KErrArgument); + } + // Check for duplicates + for (TInt k = 0; k < iParams->iUIDs.Count(); k++) + { + if (iApps.Find(iParams->iUIDs[k]) != KErrNotFound) + { + TBuf<128> msg; + const TDesC& tmp = KeyToolUtils::Uid2Des(iParams->iUIDs[k]); + msg.Format(_L("The certificate is already trusted for application %S."), &tmp); + iController->DisplayErrorL(msg, iParams->iPageWise); + User::Leave(KErrArgument); + } + } + + // add the apps to the array + for (TInt j = 0; j < iApps.Count(); j++) + { + iParams->iUIDs.Append(iApps[j]); + } + iState = EFinished; + iCertStore->SetApplicability(*iCertInfos[iIndex], iParams->iUIDs, iStatus); + SetActive(); + } + break; + case EFinished: + { + iCertInfos.Close(); + iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_ADDAPPS_SUCCESS); + CActiveScheduler::Stop(); + } + break; + default: + { + User::Panic(_L("ADDAPPS action: Illegal state."), 1); + } + } + } + +TInt CCertToolAddApps::RunError(TInt aError) + { + CActiveScheduler::Stop(); + + switch (aError) + { + case KErrNotFound : + { + TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_NOTFOUND)); + TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise)); + } + break; + default: + { + TRAP_IGNORE(iController->DisplayLocalisedMsgL(R_CERTTOOL_ERR_ADDAPPS_FAIL)); + TRAP_IGNORE(iController->DisplayErrorL(_L("\n"), iParams->iPageWise)); + } + } + + return KErrNone; + }