simpleengine/siputils/src/simplesettings.cpp
changeset 0 c8caa15ef882
child 12 e6a66db4e9d0
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/simpleengine/siputils/src/simplesettings.cpp	Tue Feb 02 01:05:17 2010 +0200
@@ -0,0 +1,328 @@
+/*
+* Copyright (c) 2006 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:    SIMPLE engine settings
+*
+*/
+
+
+
+
+// INCLUDE FILES
+#include <e32std.h>
+#include <e32base.h>
+#include <centralrepository.h>
+#include <pressettingsapi.h>
+#include "simpleenginedomaincrkeys.h"
+#include "simpleengineprivatecrkeys.h"
+
+#ifdef _DEBUG
+#include <bautils.h>
+#include "simpledebugutils.h"
+#endif
+
+#include "simplesettings.h"
+
+#ifdef _DEBUG
+_LIT ( KSimpleIniFile, "\\system\\data\\simple.ini");
+_LIT8 ( KSimpleExpiryPuhlish, "expiry_publish");
+_LIT8 ( KSimpleExpiryWatcher, "expiry_watcher");
+_LIT8 ( KSimpleExpiryWinfo, "expiry_winfo");
+_LIT8 ( KSimpleExpiryAPI, "expiry_api");
+_LIT8 ( KSimpleObjLimit, "obj_limit");
+_LIT8 ( KSimpleThrottle, "throttle");
+_LIT8 ( KSimpleMaxSubs, "max_subs");
+#endif
+
+/** default API expiry time */
+const TInt KMyDefaultAPIExpiry = 60;
+/** default SIP refresh expiry time */
+const TInt KMyDefaultSIPExpiry = 43200;
+/** default OTA settings value */
+const TInt KOTASettingsDefault = 0;
+
+// ================= MEMBER FUNCTIONS =======================
+
+
+
+
+//**********************************
+// TSimpleSettings
+//**********************************
+
+// ---------------------------------------------------------
+// TSimpleSettings::TSimpleSettings
+// ---------------------------------------------------------
+//
+TSimpleSettings::TSimpleSettings( )
+    :
+    iExpiryPuhlish( KMyDefaultSIPExpiry ),
+    iExpiryWatcher( KMyDefaultSIPExpiry ),
+    iExpiryWinfo( KMyDefaultSIPExpiry ),
+    iExpiryApi( KMyDefaultAPIExpiry ),
+    iObjLimit(KOTASettingsDefault),
+    iThrottle(KOTASettingsDefault),
+    iMaxSubscriptions(KOTASettingsDefault),
+    iSipProfileId(KOTASettingsDefault)
+    {}
+
+TUint TSimpleSettings::ExpiryPuhlish()
+    {
+    return iExpiryPuhlish;
+    }
+
+TUint TSimpleSettings::ExpiryWatcher()
+    {
+    return iExpiryWatcher;
+    }
+
+TUint TSimpleSettings::ExpiryWinfo()
+    {
+    return iExpiryWinfo;
+    }
+
+TUint TSimpleSettings::ExpiryApi()
+    {
+    return iExpiryApi;
+    }
+
+TInt TSimpleSettings::ObjLimit()
+    {
+    return iObjLimit;
+    }
+
+TInt TSimpleSettings::Throttle()
+    {
+    return iThrottle;
+    }
+
+TInt TSimpleSettings::MaxSubscriptions()
+    {
+    return iMaxSubscriptions;
+    }
+
+TInt TSimpleSettings::SipProfileId()
+    {
+    return iSipProfileId;
+    }
+
+// ---------------------------------------------------------
+// TSimpleSettings::ReadCentRepSettings
+// ---------------------------------------------------------
+//
+void TSimpleSettings::ReadCentRepSettings( )
+    {
+    // Read Central Repository settings
+    CRepository* repository = NULL;
+    TRAP_IGNORE( repository = CRepository::NewL( KCRUIDSimpleVariation ));
+    if ( repository )
+        {
+        //TRAP_IGNORE( iExpiryPuhlish = GetCenRepIntValueL(
+        //    repository, KSimplePublishRefresh ));
+        TRAP_IGNORE( iExpiryWatcher = GetCenRepIntValueL(
+            repository, KSimpleSubscribeRefresh ));
+        TRAP_IGNORE( iExpiryWinfo = GetCenRepIntValueL(
+            repository, KSimpleSubscribeWinfoRefresh ));
+        TRAP_IGNORE( iExpiryApi = GetCenRepIntValueL(
+            repository, KSimpleExpiryTime));
+        delete repository;
+        repository = NULL;
+#ifdef _DEBUG
+#ifdef __WINS__
+        TSimpleLogger::Log(_L("CentRep iExpiryPuhlish=%d iExpiryWatcher=%d iExpiryWinfo=%d iExpiryAPI=%d"),
+        iExpiryPuhlish, iExpiryWatcher, iExpiryWinfo, iExpiryApi);
+#endif
+#endif
+        }
+    }
+
+// ---------------------------------------------------------
+// TSimpleSettings::ReadOTASettings
+// ---------------------------------------------------------
+//
+void TSimpleSettings::ReadOTASettingsL( TInt aSetId )
+    {
+    // Read OTA settings using PresSettingsApi
+
+    TPresSettingsSet set;
+    TInt error( KErrNone );
+    error = PresSettingsApi::SettingsSetL( aSetId, set );
+    User::LeaveIfError( error );
+
+    // convert -1 values (undefined) to default values
+    iObjLimit = set.iObjectSize > KOTASettingsDefault ?
+        set.iObjectSize : KOTASettingsDefault;
+    iMaxSubscriptions = set.iMaxSubscriptions > KOTASettingsDefault ?
+        set.iMaxSubscriptions : KOTASettingsDefault;
+    iThrottle = set.iPublicationInt > KOTASettingsDefault ?
+        set.iPublicationInt : KOTASettingsDefault;
+    iSipProfileId = set.iSipProfile > KOTASettingsDefault ?
+        set.iSipProfile : KOTASettingsDefault;
+
+#ifdef _DEBUG
+#ifdef __WINS__
+        TSimpleLogger::Log(_L("OTAsettings iObjLimit=%d iThrottle=%d iMaxSubs=%d iSip=%d"),
+        iObjLimit, iThrottle, iMaxSubscriptions, iSipProfileId );
+#endif
+#endif
+
+    }
+
+// ---------------------------------------------------------
+// TSimpleSettings:GetCenRepIntValueL
+// ---------------------------------------------------------
+//
+TInt TSimpleSettings::GetCenRepIntValueL(
+    CRepository* aRepository,
+    TUint32 aId )
+    {
+    TInt value( 0 );
+    User::LeaveIfError( aRepository->Get( aId, value ) );
+    return value;
+    }
+
+// ---------------------------------------------------------
+// TSimpleSettings::ReadIniFileL
+// ---------------------------------------------------------
+//
+#ifdef _DEBUG
+
+void TSimpleSettings::ReadIniFileL( RFs&  aFs )
+    {
+    // Set few values without reading them from ini file
+    CSimpleSettingFile* configFile = CSimpleSettingFile::NewL( aFs );
+    CleanupStack::PushL( configFile );  // *****
+    // Search current drive
+    TFileName path;
+    Dll::FileName( path );
+    TDriveName drive( TParsePtrC( path ).Drive( ) );
+
+    // In emulator we try to find from c drive
+    // in hardware we try to find from current drive and then from RAM.
+#ifdef __WINS__
+    TFileName fileN( KSimpleIniFile);
+#else
+    TFileName fileN( drive );
+    fileN.Append( KSimpleIniFile );
+#endif
+
+    TInt err = 0;
+
+    // Open temporary config file
+    TRAP( err, configFile->OpenL( fileN ));
+    if ( err && drive.CompareF( _L("c:") ))
+        {
+        err = KErrNone;
+        fileN = _L("c:");
+        fileN.Append( KSimpleIniFile );
+        TRAP( err, configFile->OpenL( fileN ));
+        }
+    if ( err )
+        {
+        err = KErrNone;
+        TSimpleLogger::Log(_L("Config file not found ***"));
+        User::Leave( KErrNotFound );
+        }
+    else
+        {
+        TSimpleLogger::Log(_L("Config file found ***"));
+        }
+
+    TUint32 myUint = 0;
+    TPtrC8 myPtr;
+    TBuf<8> myBuffer;
+
+    // read expiry times
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleExpiryPuhlish)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iExpiryPuhlish = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleExpiryWatcher)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iExpiryWatcher = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleExpiryWinfo)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iExpiryWinfo = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleExpiryAPI)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iExpiryApi = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleObjLimit)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iObjLimit = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleThrottle)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iThrottle = (TInt) myUint;
+        }
+
+    TRAP( err, myPtr.Set( configFile->KeyValueL(KSimpleMaxSubs)));
+    if ( !err )
+        {
+        myBuffer.Copy( myPtr );
+        TLex lex;
+        lex.Assign( myBuffer );
+        lex.Val(myUint, EDecimal);
+        iMaxSubscriptions = (TInt) myUint;
+        }
+    CleanupStack::PopAndDestroy(configFile);
+
+    // debug logging
+    TSimpleLogger::Log(_L("ReadFile iExpiryPuhlish=%d iExpiryWatcher=%d iExpiryWinfo=%d iExpiryAPI=%d"),
+    iExpiryPuhlish, iExpiryWatcher, iExpiryWinfo, iExpiryApi);
+    TSimpleLogger::Log(_L("ReadFile iObjLimit=%d iThrottle=%d iMaxSubs=%d"),
+    iObjLimit, iThrottle, iMaxSubscriptions );
+    }
+
+#endif // _DEBUG
+
+
+//  End of File
+