sysstatemgmt/ssmcustcmds/ssmsystemcmds/src/ssminitpskeys.cpp
changeset 0 4e1aa6a622a0
child 9 21e939dd208a
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/sysstatemgmt/ssmcustcmds/ssmsystemcmds/src/ssminitpskeys.cpp	Tue Feb 02 00:53:00 2010 +0200
@@ -0,0 +1,293 @@
+/*
+* Copyright (c) 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:
+* Implementation of CSsmInitPsKeys class.
+*
+*/
+
+#include "ssminitpskeys.h"
+#include "ssmmapperutility.h"
+#include "ssmmapperutilityinternalpskeys.h"
+#include "ssmcustcmdsprivatepskeys.h"
+#include "trace.h"
+
+#include <ssm/startupdomainpskeys.h>
+#include <ssm/starterdomaincrkeys.h>
+#include <ssm/ssmrefcustomcmdcommon.h>
+
+_LIT_SECURITY_POLICY_C1( KReadDeviceDataPolicy, ECapabilityReadDeviceData );
+_LIT_SECURITY_POLICY_C1( KWriteDeviceDataPolicy, ECapabilityWriteDeviceData );
+_LIT_SECURITY_POLICY_C1( KPowerMgmtPolicy, ECapabilityPowerMgmt );
+_LIT_SECURITY_POLICY_PASS( KAlwaysPassPolicy );
+
+
+// ======== MEMBER FUNCTIONS ========
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::NewL
+// ---------------------------------------------------------------------------
+//
+CSsmInitPsKeys* CSsmInitPsKeys::NewL()
+	{
+    FUNC_LOG;
+    return new ( ELeave ) CSsmInitPsKeys();
+	}
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::~CSsmInitPsKeys
+// ---------------------------------------------------------------------------
+//
+CSsmInitPsKeys::~CSsmInitPsKeys()
+    {
+    FUNC_LOG;
+    }
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::Initialize
+// ---------------------------------------------------------------------------
+//
+TInt CSsmInitPsKeys::Initialize( CSsmCustomCommandEnv* /*aCmdEnv*/ )
+    {
+    FUNC_LOG;
+    return KErrNone;
+    }
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::Execute
+// ---------------------------------------------------------------------------
+//
+void CSsmInitPsKeys::Execute(
+    const TDesC8& /*aParams*/,
+    TRequestStatus& aRequest )
+    {
+    FUNC_LOG;
+    aRequest = KRequestPending;
+
+    TRAPD( errorCode, InitializeKeysL() );
+    ERROR( errorCode, "Failed to initialize P&S keys" );
+
+    TRequestStatus* request = &aRequest;
+    User::RequestComplete( request, errorCode );
+    }
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::ExecuteCancel
+// ---------------------------------------------------------------------------
+//
+void CSsmInitPsKeys::ExecuteCancel()
+    {
+    FUNC_LOG;
+    // Nothing to do.
+    }
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::Close
+// ---------------------------------------------------------------------------
+//
+void CSsmInitPsKeys::Close()
+    {
+    FUNC_LOG;
+
+    /**
+    * Close resources initialized in the previous call to Initialize.
+    */
+    }
+
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::Release
+// ---------------------------------------------------------------------------
+//
+void CSsmInitPsKeys::Release()
+    {
+    FUNC_LOG;
+
+	delete this;
+    }
+
+// ---------------------------------------------------------------------------
+// CSsmInitPsKeys::InitializeKeysL
+// ---------------------------------------------------------------------------
+//
+void CSsmInitPsKeys::InitializeKeysL()
+    {
+    FUNC_LOG;
+
+// Startup Security Status API
+
+    INFO( "KPSUidStartup::KStartupSimSecurityStatus" );
+    DefineL( KPSUidStartup,
+             KStartupSimSecurityStatus,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup,
+          KStartupSimSecurityStatus,
+          ESimSecurityStatusUninitialized );
+
+    INFO( "KPSUidStartup::KStartupSimLockStatus" );
+    DefineL( KPSUidStartup,
+             KStartupSimLockStatus,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup,
+          KStartupSimLockStatus,
+          ESimLockStatusUninitialized );
+
+    INFO( "KPSUidStartup::KStartupSecurityCodeStatus" );
+    DefineL( KPSUidStartup,
+             KStartupSecurityCodeStatus,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup,
+          KStartupSecurityCodeStatus,
+          ESecurityCodeStatusUninitialized );
+
+    INFO( "KPSUidStartup::KStartupSecurityCodeQueryStatus" );
+    DefineL( KPSUidStartup,
+             KStartupSecurityCodeQueryStatus,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup,
+          KStartupSecurityCodeQueryStatus,
+          ESecurityQueryUninitialized );
+
+// System Application Startup API
+
+    INFO( "KPSUidStartup::KStartupBootIntoOffline" );
+    DefineL( KPSUidStartup,
+             KStartupBootIntoOffline,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup,
+          KStartupBootIntoOffline,
+          EBootIntoOnlineModeUninitialized );
+
+    INFO( "KPSUidStartup::KStartupCleanBoot" );
+    DefineL( KPSUidStartup,
+             KStartupCleanBoot,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KStartupCleanBoot, EStartupCleanBootUninitialized );
+
+// SIM Utils API
+
+    INFO( "KPSUidStartup::KPSSimStatus" );
+    DefineL( KPSUidStartup,
+             KPSSimStatus,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KPSSimStatus, ESimStatusUninitialized );
+
+    INFO( "KPSUidStartup::KPSSimOwned" );
+    DefineL( KPSUidStartup,
+             KPSSimOwned,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KPSSimOwned, ESimOwnedUninitialized );
+
+    INFO( "KPSUidStartup::KPSSimChanged" );
+    DefineL( KPSUidStartup,
+             KPSSimChanged,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KPSSimChanged, ESimChangedUninitialized );
+
+// System State API
+
+    INFO( "KPSUidStartup::KPSGlobalSystemState" );
+    DefineL( KPSUidStartup,
+             KPSGlobalSystemState,
+             KAlwaysPassPolicy,
+             KPowerMgmtPolicy );
+    INFO( "KPSUidStartup::KPSGlobalStartupMode" );
+    DefineL( KPSUidStartup,
+             KPSGlobalStartupMode,
+             KAlwaysPassPolicy,
+             KPowerMgmtPolicy );
+
+    INFO( "KPSUidStartup::KPSIdlePhase1Ok" );
+    DefineL( KPSUidStartup,
+             KPSIdlePhase1Ok,
+             KAlwaysPassPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KPSIdlePhase1Ok, EIdlePhase1NOK );
+
+    INFO( "KPSUidStartup::KPSPhonePhase1Ok" );
+    DefineL( KPSUidStartup,
+             KPSPhonePhase1Ok,
+             KAlwaysPassPolicy,
+             KPowerMgmtPolicy );
+    SetL( KPSUidStartup, KPSPhonePhase1Ok, EPhonePhase1NOK );
+
+    INFO( "KPSUidStartup::KPSStartupReason" );
+    DefineL( KPSUidStartup,
+             KPSStartupReason,
+             KAlwaysPassPolicy,
+             KPowerMgmtPolicy );
+
+// Wakeup Alarm API
+    INFO( "KPSUidStartup::KPSWakeupAlarmStatus" );
+    DefineL( KPSUidStartup,
+             KPSWakeupAlarmStatus,
+             KAlwaysPassPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSUidStartup, KPSWakeupAlarmStatus, EWakeupAlarmUninitialized );
+    
+    // Startup Security Phase API
+    INFO( "KPSStarterUid::KStarterSecurityPhase" );
+    DefineL( KPSStarterUid,
+             KStarterSecurityPhase,
+             KAlwaysPassPolicy,
+             KWriteDeviceDataPolicy );
+    
+    SetL( KPSStarterUid, KStarterSecurityPhase, EStarterSecurityPhaseUninitialized );
+    
+// Disk Reserver API
+    INFO( "KPSStarterUid::KDiskReserveKey" );
+    DefineL( KPSStarterUid,
+             KDiskReserveKey,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSStarterUid, KDiskReserveKey, 0 );
+    
+// RTC validation API
+    INFO( "KPSStarterUid::KRTCPropertyKey" );
+    DefineL( KPSStarterUid,
+             KRTCPropertyKey,
+             KReadDeviceDataPolicy,
+             KWriteDeviceDataPolicy );
+    SetL( KPSStarterUid, KRTCPropertyKey, 0 );
+    
+// Store FirstBoot Value from cenrep
+TInt csVal( 0 );
+TInt psVal( 0 );
+    CSsmMapperUtility& util = MapperUtilityL(); 
+    User::LeaveIfError( util.CrValue( KCRUidStartup, 
+                                      KStartupFirstBoot,
+                                      csVal ) );
+
+    INFO( "KPSUidStartup::KPSStartupFirstBoot" );
+    psVal = ( csVal == EStartupIsFirstBoot )? EPSStartupFirstBoot : EPSStartupNotFirstBoot;
+    DefineL( KPSUidStartup,
+             KPSStartupFirstBoot,
+             KAlwaysPassPolicy,
+             KWriteDeviceDataPolicy );
+             
+    SetL(  KPSUidStartup, KPSStartupFirstBoot, psVal );
+    }