omaprovisioning/provisioning/ProvisioningSC/Src/CWPWimHandler.cpp
changeset 0 b497e44ab2fc
child 23 4af31167ea77
equal deleted inserted replaced
-1:000000000000 0:b497e44ab2fc
       
     1 /*
       
     2 * Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies). 
       
     3 * All rights reserved.
       
     4 * This component and the accompanying materials are made available
       
     5 * under the terms of "Eclipse Public License v1.0"
       
     6 * which accompanies this distribution, and is available
       
     7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
       
     8 *
       
     9 * Initial Contributors:
       
    10 * Nokia Corporation - initial contribution.
       
    11 *
       
    12 * Contributors:
       
    13 *
       
    14 * Description:  
       
    15 *
       
    16 */
       
    17 
       
    18 
       
    19 // INCLUDE FILES
       
    20 #include	"CWPWimHandler.h"
       
    21 #include	<e32std.h>  
       
    22 #include	"CWPEngine.pan"
       
    23 #include	<ProvSC.h>
       
    24 #include	"ProvisioningDebug.h"
       
    25 #include	"MWPWimObserver.h"
       
    26 
       
    27 
       
    28 // ============================ MEMBER FUNCTIONS ===============================
       
    29 
       
    30 
       
    31 // -----------------------------------------------------------------------------
       
    32 // CWPWimHandler::NewL
       
    33 // Two-phased constructor.
       
    34 // -----------------------------------------------------------------------------
       
    35 //
       
    36 CWPWimHandler* CWPWimHandler::NewL( MWPWimObserver& aObserver )
       
    37     {
       
    38 	CWPWimHandler* handler  = CWPWimHandler::NewLC( aObserver );
       
    39     CleanupStack::Pop();
       
    40     return handler;
       
    41     }
       
    42 
       
    43 // -----------------------------------------------------------------------------
       
    44 // CWPWimHandler::NewLC
       
    45 // Two-phased constructor.
       
    46 // -----------------------------------------------------------------------------
       
    47 //
       
    48 CWPWimHandler* CWPWimHandler::NewLC( MWPWimObserver& aObserver )
       
    49     {
       
    50     CWPWimHandler* self = new( ELeave ) CWPWimHandler( aObserver );    
       
    51     CleanupStack::PushL( self );
       
    52     self->ConstructL();
       
    53     return self;
       
    54     }
       
    55 
       
    56 // -----------------------------------------------------------------------------
       
    57 // CWPWimHandler::~CWPWimHandler
       
    58 // Destructor
       
    59 // -----------------------------------------------------------------------------
       
    60 //
       
    61 CWPWimHandler::~CWPWimHandler()
       
    62     {
       
    63     Cancel(); // CActive
       
    64 	delete iFileLoader;
       
    65 	delete iProvisioningDoc;
       
    66     }
       
    67 
       
    68 // -----------------------------------------------------------------------------
       
    69 // CWPWimHandler::ReadProvFile();
       
    70 // -----------------------------------------------------------------------------
       
    71 //
       
    72 void CWPWimHandler::ReadProvFile( const TOMAType& aFileType )
       
    73     {
       
    74     FLOG( _L( "[ProvisioningSC] CWPWimHandler::ReadProvFile" ) );
       
    75     
       
    76 	iFileType = aFileType;
       
    77 	if( !iClientInitialized )
       
    78 		{
       
    79 		iPhase = EInitialize;
       
    80 		iFileLoader->Initialize( iStatus );
       
    81 		SetActive();
       
    82 		}
       
    83     }
       
    84 
       
    85 // -----------------------------------------------------------------------------
       
    86 // CWPWimHandler::DocL();
       
    87 // -----------------------------------------------------------------------------
       
    88 //
       
    89 HBufC8* CWPWimHandler::DocL()
       
    90 	{
       
    91 	if( iProvisioningDoc )
       
    92 		{
       
    93 		return iProvisioningDoc->AllocL();
       
    94 		}
       
    95 	else
       
    96 		{
       
    97 		return NULL;
       
    98 		}
       
    99 	}
       
   100 
       
   101 // -----------------------------------------------------------------------------
       
   102 // CWPWimHandler::CWPWimHandler
       
   103 // C++ default constructor can NOT contain any code, that
       
   104 // might leave.
       
   105 // -----------------------------------------------------------------------------
       
   106 //
       
   107 CWPWimHandler::CWPWimHandler( MWPWimObserver& aObserver )
       
   108     : CActive( EPriorityIdle ), iObserver( aObserver ),
       
   109 	 iProvData( NULL, 0 ), iClientInitialized( EFalse ), iFileType( EBootStrap)
       
   110     {
       
   111     }
       
   112 
       
   113 // -----------------------------------------------------------------------------
       
   114 // CWPWimHandler::ConstructL
       
   115 // Symbian 2nd phase constructor can leave.
       
   116 // -----------------------------------------------------------------------------
       
   117 //
       
   118 void CWPWimHandler::ConstructL()
       
   119     {
       
   120     FLOG( _L( "[ProvisioningSC] CWPWimHandler::ConstructL" ) );
       
   121     
       
   122 	CActiveScheduler::Add( this );
       
   123 	iFileLoader = CWimOMAProv::NewL();
       
   124     }
       
   125 
       
   126 // -----------------------------------------------------------------------------
       
   127 // CWPWimHandler::RunL
       
   128 // -----------------------------------------------------------------------------
       
   129 //
       
   130 void CWPWimHandler::RunL()
       
   131     {
       
   132     FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL" ) );
       
   133     
       
   134 	switch( iPhase )
       
   135 		{
       
   136 		case EInitialize:
       
   137 			{
       
   138 			FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL EInitialize" ) );
       
   139 			if( iStatus == KErrNone )
       
   140 				{
       
   141 				Retrieve(); // ready to read the actual document
       
   142 				}
       
   143 			else
       
   144 				{
       
   145 				FTRACE(RDebug::Print(_L("[ProvisioningSC] CWPWimHandler::RunL EInitialize err (%d)"), iStatus.Int()));
       
   146 				iObserver.ReadErrorL();
       
   147 				}
       
   148 			break;
       
   149 			}
       
   150 		case EGetSize:
       
   151 			{
       
   152             FTRACE(RDebug::Print(_L("[ProvisioningSC] CWPWimHandler::RunL EGetSize status:%d, size:%d"), iStatus.Int(), iFileSize));
       
   153 			
       
   154 			if (iFileSize > 0 && iStatus == KErrNone )
       
   155 				{
       
   156 				delete iProvisioningDoc;
       
   157 				iProvisioningDoc = NULL;
       
   158 				iProvisioningDoc = HBufC8::NewL( iFileSize );
       
   159 				// get the provisioningdoc from sim card, use first accessible
       
   160 				// file type (EBootStrap, EConfig1, EConfig2)
       
   161 				iProvData.Set(iProvisioningDoc->Des()) ;
       
   162 				FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL EGetSize retrieving file" ) );
       
   163 				
       
   164 				iFileLoader->Retrieve( iFileType, iProvData, iStatus );
       
   165 				iPhase = ERetrieve;
       
   166 				SetActive();
       
   167 				}
       
   168 			else // try to get another type
       
   169 				{
       
   170 				FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL EGetSize error" ) );
       
   171 				TBool tryToRead( ETrue );
       
   172 				switch( iFileType )
       
   173 					{
       
   174 					case EBootStrap:
       
   175 						{
       
   176 						iFileType = EConfig1;
       
   177 						}
       
   178 					break;
       
   179 					case EConfig1:
       
   180 						{
       
   181 						iFileType = EConfig2;
       
   182 						}
       
   183 					break;
       
   184 					default:
       
   185 						{
       
   186 						tryToRead = EFalse;
       
   187 						}
       
   188 					break;
       
   189 					}
       
   190 				if( tryToRead )
       
   191 					{
       
   192 					FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL EGetSize file not found" ) );
       
   193 					iFileLoader->GetSize( iFileSize, iFileType, iStatus  );	
       
   194 					iPhase = EGetSize;
       
   195 					SetActive();
       
   196 					}
       
   197 				else
       
   198 					{
       
   199 					FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL EGetSize no more files" ) );
       
   200 					iObserver.ReadErrorL();
       
   201 					}
       
   202 				}
       
   203 			break;
       
   204 			}
       
   205 		case ERetrieve:
       
   206 			{
       
   207 			FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL ERetrieve" ) );
       
   208 			if( iStatus==KErrNone )
       
   209 				{
       
   210 				FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL ERetrieve ok" ) );
       
   211                 #ifdef _DEBUG
       
   212 				FHex(iProvisioningDoc->Des());
       
   213                 #endif
       
   214 				FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL ERetrieve finished" ) );
       
   215 				
       
   216 				iObserver.ReadCompletedL();
       
   217 				}
       
   218 			else 
       
   219 				{
       
   220 	            FTRACE(RDebug::Print(_L("[ProvisioningSC] CWPWimHandler::RunL ERetrieve err:%d"), iStatus.Int()));
       
   221 				iObserver.ReadErrorL();
       
   222 				}
       
   223 			break;
       
   224 			}
       
   225 		default:
       
   226 			{
       
   227 			FLOG( _L( "[ProvisioningSC] CWPWimHandler::RunL default" ) );
       
   228 			break;
       
   229 			}
       
   230 		}
       
   231     }
       
   232 
       
   233 // -----------------------------------------------------------------------------
       
   234 // CWPWimHandler::DoCancel
       
   235 // Cancel active request
       
   236 // -----------------------------------------------------------------------------
       
   237 //
       
   238 void CWPWimHandler::DoCancel()
       
   239     {
       
   240     FLOG( _L( "[ProvisioningSC] CWPWimHandler::DoCancel" ) );
       
   241     
       
   242 	TRAPD( ignoreError, iObserver.ReadCancelledL() );
       
   243 	if (ignoreError) ignoreError = KErrNone; 
       
   244 	switch( iPhase )
       
   245 		{
       
   246 		case EInitialize:
       
   247 			{
       
   248 			iFileLoader->CancelInitialize();
       
   249 			break;
       
   250 			}
       
   251 		case EGetSize:
       
   252 			{
       
   253 			iFileLoader->CancelGetSize();
       
   254 			break;
       
   255 			}
       
   256 		case ERetrieve:
       
   257 			{
       
   258 			iFileLoader->CancelRetrieve();
       
   259 			break;
       
   260 			}
       
   261 		default:
       
   262 			{
       
   263 			break;
       
   264 			}
       
   265 		}
       
   266     }
       
   267 
       
   268 // -----------------------------------------------------------------------------
       
   269 // CWPWimHandler::Retrieve
       
   270 // -----------------------------------------------------------------------------
       
   271 //
       
   272 void CWPWimHandler::Retrieve()
       
   273 	{
       
   274 	FLOG( _L( "[ProvisioningSC] CWPWimHandler::Retrieve" ) );
       
   275 
       
   276 	if( iProvisioningDoc )
       
   277 		{
       
   278 		delete iProvisioningDoc;
       
   279 		iProvisioningDoc = NULL;
       
   280 		}
       
   281 	iFileLoader->GetSize( iFileSize, iFileType, iStatus  );	
       
   282 	iPhase = EGetSize;
       
   283 	SetActive();
       
   284 	}
       
   285 
       
   286 //  End of File