imservices/ossprotocoladaptation/src/presenceauthorization/cpresenceauthuserrequest.cpp
changeset 0 e6b17d312c8b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/imservices/ossprotocoladaptation/src/presenceauthorization/cpresenceauthuserrequest.cpp	Thu Dec 17 08:54:49 2009 +0200
@@ -0,0 +1,220 @@
+/*
+* Copyright (c) 2007-2008 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:  Request for accepting add invite to the Network Server.
+*
+*/
+
+
+#include <ximpprotocolconnectionhost.h>
+#include "cpresenceauthuserrequest.h"
+#include "mossprotocolconnectionmanager.h"
+#include "ossprotocolpluginlogger.h"
+#include <presenceinfo.h>
+
+#include <ximpobjectfactory.h>
+#include <ximpobjectcollection.h>
+#include <protocolpresentitygroupsdatahost.h>
+#include <presentitygroupinfo.h>
+#include <presentitygroupmemberinfo.h>
+#include <ximpidentity.h>
+#include <presenceinfofilter.h>
+
+#include <glib/gstrfuncs.h>
+#include <gtypes.h>
+#include <stdlib.h>
+#include "stringutils.h"
+#include <string.h>
+#include <sys/types.h>
+#include <stdio.h>
+#include <glib/gprintf.h>
+#include "msgliterals.h"
+#include "msg_enums.h"
+#include "waittimer.h"
+#include <ximperrors.hrh>
+#include "ossprotocoladaptutils.h"
+	
+// ======== MEMBER FUNCTIONS ========
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::CPresenceAuthUserRequest
+// ---------------------------------------------------------------------------
+//
+CPresenceAuthUserRequest::CPresenceAuthUserRequest( 
+						MOSSProtocolConnectionManager& aConnMan,
+						TXIMPRequestId aRequestId ) :
+    CActive( EPriorityNormal ),
+    iRequestId( aRequestId ),
+    iConnMan( aConnMan )
+    {
+    LOGGER ( TXT("::CPresenceAuthUserRequest Start") );
+    CActiveScheduler::Add( this );
+    LOGGER ( TXT("::CPresenceAuthUserRequest End") );
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::ConstructL
+// ---------------------------------------------------------------------------
+//
+void CPresenceAuthUserRequest::ConstructL()
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::ConstructL Start-End") );
+    
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::NewL
+// ---------------------------------------------------------------------------
+//
+CPresenceAuthUserRequest* CPresenceAuthUserRequest::NewL(
+    MOSSProtocolConnectionManager& aConnMan,
+    TXIMPRequestId aRequestId )
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::NewL Start") );
+    
+    CPresenceAuthUserRequest* self = 
+    				new( ELeave ) CPresenceAuthUserRequest( aConnMan, aRequestId );
+    CleanupStack::PushL( self );
+    self->ConstructL();
+    CleanupStack::Pop( self );
+    
+    LOGGER ( TXT("CPresenceAuthUserRequest::NewL End") );
+    return self;
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::NewLC
+// ---------------------------------------------------------------------------
+//
+CPresenceAuthUserRequest* CPresenceAuthUserRequest::NewLC(
+    MOSSProtocolConnectionManager& aConnMan,
+    TXIMPRequestId aRequestId )
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::NewLC Start") );
+    
+    CPresenceAuthUserRequest* self = 
+    				 CPresenceAuthUserRequest::NewL( aConnMan, aRequestId );
+    CleanupStack::PushL( self );
+       
+    LOGGER ( TXT("CPresenceAuthUserRequest::NewLC End") );
+    return self;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::~CPresenceAuthUserRequest
+// ---------------------------------------------------------------------------
+//
+CPresenceAuthUserRequest::~CPresenceAuthUserRequest()
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::~CPresenceAuthUserRequest Start") );
+
+    CActive::Cancel();
+    LOGGER ( TXT("CPresenceAuthUserRequest::~CPresenceAuthUserRequest End") );
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::DoCancel()
+// ---------------------------------------------------------------------------
+//
+void CPresenceAuthUserRequest::DoCancel()
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::DoCancel Start") );
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::RunL()
+// ---------------------------------------------------------------------------
+//
+void CPresenceAuthUserRequest::RunL()
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::RunL Start") );
+    
+   	message_hdr_resp* msg_struct = NULL;
+	User::LeaveIfError( iStatus.Int() );
+    char* pResponse = NULL;  
+	pResponse = iConnMan.DataHandler().ResponseL( iSendId ); 
+	
+	msg_struct = ( message_hdr_resp* )pResponse ;
+
+	if( !( msg_struct->response ) )
+	{
+		//for all other error codes like ssl related are mapped to general error
+	  iConnMan.HandleToHost().HandleRequestCompleted ( iRequestId, KXIMPErrServiceGeneralError );
+	}
+	else
+	{
+	  iConnMan.HandleToHost().HandleRequestCompleted ( iRequestId, KErrNone );
+	}
+	free(pResponse);
+	delete this;
+	LOGGER ( TXT("CPresenceAuthUserRequest::RunL End") );
+    }
+
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::RunError
+// ---------------------------------------------------------------------------
+//
+TInt CPresenceAuthUserRequest::RunError( TInt  aError )
+    {
+    LOGGER ( TXT("CPresenceAuthUserRequest::RunError Start") );
+    
+    iConnMan.HandleToHost().HandleRequestCompleted( iRequestId, aError );
+    
+    delete this;
+	LOGGER ( TXT("CPresenceAuthUserRequest::RunError End") );
+    return KErrNone;
+    }
+
+// ---------------------------------------------------------------------------
+// CPresenceAuthUserRequest::PresenceAuthUserRequest
+// ---------------------------------------------------------------------------
+//
+void CPresenceAuthUserRequest::PresenceAuthUserRequestL(	
+									const MXIMPIdentity & aIdentity,
+                                    const MPresenceInfoFilter &/*aPif*/ )
+    {   
+    LOGGER ( TXT("CPresenceAuthUserRequest::PresenceAuthUserRequest Start") );
+
+	char *smsg = NULL;
+	int totalLen = 0;
+	
+    message_hdr_req msgHdr = {0,};
+	msgHdr.message_type = EAccept_Contact_Request ;
+	TInt headerSize = sizeof( message_hdr_req ) ;
+
+	charFormatData tmpmsgData = OssProtocolAdapUtils::ConvertTUint16ToCharLC( aIdentity.Identity() );
+	char* tmpmsg = tmpmsgData.data;
+	TInt  tmpmsgLength = tmpmsgData.dataSize;	
+	totalLen = headerSize + tmpmsgLength;
+	 
+	smsg = ( char* ) User::AllocLC(totalLen);
+	memcpy( smsg, &msgHdr, headerSize );
+	memcpy ( smsg + headerSize, tmpmsg, tmpmsgLength );
+	
+	iSendId = iConnMan.DataHandler().SendDataL ( iStatus, smsg, totalLen );
+
+	// signal the scheduler
+	SetActive();
+
+	CleanupStack::PopAndDestroy ( 2 );	//smsg, tmpmsg.
+	LOGGER ( TXT("CPresenceAuthUserRequest::PresenceAuthUserRequest End") );
+    }
+
+
+// End of file