multimediacommsengine/tsrc/testdriver/siptester/src/TCmdSendSubscribe.cpp
changeset 0 1bce908db942
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/multimediacommsengine/tsrc/testdriver/siptester/src/TCmdSendSubscribe.cpp	Tue Feb 02 01:04:58 2010 +0200
@@ -0,0 +1,126 @@
+/*
+* Copyright (c) 2004 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
+*
+*/
+
+#include <sipclienttransaction.h>
+#include <sipconnection.h>
+#include <sipcontactheader.h>
+#include <sipfromheader.h>
+#include <sipregistrationbinding.h>
+#include <sipsubscribedialogassoc.h>
+#include <siptoheader.h>
+#include <sipdialog.h>
+
+#include "CTcSIPConnectionContainer.h"
+#include "TCmdSendSubscribe.h"
+#include "SIPConstants.h"
+
+/**
+ * INPUT:
+ *   Headers:		From, To*, Contact*, Content-Type*, Content-Encoding*,
+ *					Accept*, Event*, Route*, Expires*
+ *   Parameters:	Content*, RemoteURI*, Refresh*
+ *   IDs:			RegistrationId*
+ *
+ * OUTPUT:
+ *   Parameters:	-
+ *   IDs:			TransactionId, SubscribeDialogId
+ */
+void TCmdSendSubscribe::ExecuteL()
+	{
+	// -- Setup ---------------------------------------------------------------
+
+	// Select connection; either default or user specified (and existing)
+	CSIPConnection& connection = SelectConnectionL().Connection();
+
+	// Get SIP objects from registry
+	CSIPRegistrationBinding* registration = GetRegistrationL( EFalse );
+	TBool fromHeaderMandatory( ETrue );
+	if( registration )
+		{
+		fromHeaderMandatory = EFalse;
+		}
+
+	// Extract required headers (From may be either mandatory or optional)
+	CSIPToHeader* toHeader = ExtractToHeaderLC( EFalse );
+	CSIPFromHeader* fromHeader = ExtractFromHeaderLC( fromHeaderMandatory );
+	CSIPEventHeader* eventHeader = ExtractEventHeaderLC();
+	
+	// Extract optional headers
+	CSIPContactHeader* contactHeader = ExtractContactHeaderLC( EFalse );
+
+	// Conditionally create remote URI
+	CUri8* remoteUri = ExtractRemoteURILC();
+
+	// Construct the dialog object
+	CSIPSubscribeDialogAssoc* dialogAssoc;
+	
+    if( registration )
+		{
+		dialogAssoc = CSIPSubscribeDialogAssoc::NewL(
+								connection, remoteUri, *registration,
+								eventHeader, fromHeader, toHeader, contactHeader );
+		}
+	else
+		{
+		dialogAssoc = CSIPSubscribeDialogAssoc::NewL(
+											connection, fromHeader, remoteUri,
+											eventHeader, toHeader, contactHeader );
+		}	
+
+	// Purge items from cleanup stack, now they are owned by CSIPInviteDialogAssoc
+	// Some items are optional (i.e. NULL), so we've been tracking the number
+	// of items in pushed to CleanupStack
+	CleanupStack::Pop( iPushed );
+	iPushed = 0;
+
+	CleanupStack::PushL( dialogAssoc );
+
+	// Conditionally create refresh object
+	CSIPRefresh* refresh = ExtractRefreshLC();
+
+	// Extract both headers (that are still left) and content.
+	CSIPMessageElements* elements = ExtractHeadersAndContentLC();
+
+	// -- Execution -----------------------------------------------------------
+
+	// Start SIP Subscribe transaction.
+	CSIPClientTransaction* transaction =
+							dialogAssoc->SendSubscribeL( elements, refresh );
+	CleanupStack::Pop( elements );
+	if( refresh )
+		{
+		CleanupStack::Pop( refresh );
+		}
+
+	// -- Response creation ---------------------------------------------------
+
+	AddIdResponseL( KTransactionId, transaction );	
+	AddIdResponseL( KDialogId, dialogAssoc->Dialog() );
+	CleanupStack::Pop( dialogAssoc );
+	AddIdResponseL( KSubscribeDialogId, dialogAssoc );	
+	}
+
+TBool TCmdSendSubscribe::Match( const TTcIdentifier& aId )
+	{
+	return TTcSIPCommandBase::Match( aId, _L8("SendSubscribe") );
+	}
+
+TTcCommandBase* TCmdSendSubscribe::CreateL( MTcTestContext& aContext )
+	{
+	return new( ELeave ) TCmdSendSubscribe( aContext );
+	}
+