realtimenetprots/sipfw/SIP/TransactionUser/src/RouteSet.h
changeset 0 307788aac0a8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/realtimenetprots/sipfw/SIP/TransactionUser/src/RouteSet.h	Tue Feb 02 01:03:15 2010 +0200
@@ -0,0 +1,249 @@
+/*
+* Copyright (c) 2005-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:
+* Name          : RouteSet.h
+* Part of       : TransactionUser
+* Version       : SIP/4.0
+*
+*/
+
+
+
+
+/**
+ @internalComponent
+*/
+
+
+#ifndef ROUTESET_H
+#define ROUTESET_H
+
+#include <e32base.h>
+
+#include "SipStackServerDefs.h"
+
+class CSIPRequest;
+class CSIPHeaderBase;
+class CSIPRouteHeader;
+class CURIContainer;
+class MSipRegistrations;
+
+
+/*
+ * This class is used for storing and manipulating a route set.
+ */
+class CRouteSet : public CBase
+	{
+public:	
+	/**
+	 * Creates the route set and copies all Route headers from the aReq.
+	 * If aReq doesn't have Route headers, the possibly existing outbound
+	 * proxy is added into the route set.
+	 *
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aReq SIP request
+	 * @param aRegistrations Registration subsystem
+	 * @param aRegisterId Registration identifier
+	 * @return New CRouteSet object, ownership is transferred
+	 */
+	static CRouteSet* NewL(CSIPRequest& aReq,
+						   MSipRegistrations& aRegistrations,
+						   TRegistrationId aRegisterId);
+						   
+
+	/**
+	 * Creates a deep copy of aRouteSet.
+	 *
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aRouteSet CRouteSet to be copied	 
+	 * @return New CRouteSet object, ownership is transferred
+	 */
+	static CRouteSet* NewL(const CRouteSet& aRouteSet);
+
+
+	~CRouteSet();
+
+
+	/**
+	 * Copies the Route-headers present in the route set, to aReq.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aReq SIP request where Route headers are added
+	 * @param aIndex Indicates the first entry in route set, from where the
+	 *	entries are copied.
+	 *	0 = copy all entries, 1 = copy from the second entry onwards, etc.
+	 * @return -
+	 */
+    void CopyToRequestL(CSIPRequest& aReq, TUint aIndex = 0) const;
+
+
+	/**
+	 * Returns the URI of the first entry of the route set.
+	 *
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param
+	 * @return CURIContainer* URI of the first entry of the route set,
+	 *	ownership is not transferred. NULL if route set is empty.
+	 */
+	const CURIContainer* TopUri() const;
+
+	
+	/**
+	 * Replaces the topmost route with a new value.
+	 *	 
+	 * @pre IsEmpty() == EFalse
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aContact 
+	 * @return -
+	 */
+	void ReplaceTopRouteL();
+	
+	
+    /**
+	 * Checks if the topmost route has LR parameter.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *	 
+	 * @return ETrue if topmost route has LR parameter, EFalse if it doesn't
+     *  have, or if the route set is empty.
+	 */
+	TBool IsLrParamInTopRoute() const;
+
+
+	/**
+	 * Checks if the route set is empty.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *	 
+	 * @return ETrue if route set is empty, EFalse otherwise.
+	 */
+	TBool IsEmpty() const;
+	
+	
+	/**
+	 * Checks if the original request contained route headers when the request
+	 * first was passed to TransactionUser.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *	 
+	 * @return ETrue if preconfigured route exists, EFalse otherwise.
+	 */
+	TBool PreconfigRouteExists() const;
+	
+	
+	/**
+	 * Returns the next hop URI.
+	 *
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aRemoteTarget Remote target
+	 * @return CURIContainer& Next hop URI
+	 */
+	CURIContainer& NextHop(CURIContainer& aRemoteTarget) const;
+
+
+	/**
+	 * Sets a aRoute as the first route entry.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aRoute Route to be added
+	 * @param aOverwrite ETrue if aRoute will replace the current first route
+	 *	EFalse if aRoute is appended to the beginning	 
+	 */
+	void AddToBeginningL(const CSIPRouteHeader& aRoute, TBool aOverwrite);
+
+
+	/**
+	 * Check if the URI is present in the route set.
+	 *
+	 * @param aUri URI
+	 * @return ETrue: aUri is present in the route set,
+	 *	EFalse: otherwise
+	 */
+	TBool IsInSet(const CURIContainer& aUri) const;
+
+private:
+	CRouteSet();
+
+	void ConstructL(CSIPRequest& aReq,
+					MSipRegistrations& aRegistrations,
+				    TRegistrationId aRegisterId);
+
+	void ConstructL(const CRouteSet& aRouteSet);
+
+
+	/**
+	 * Creates a copy of aRouteHeader and adds it the route set.
+	 *	 
+	 * @pre
+	 * @post
+	 *
+	 * @see
+	 *
+	 * @param aRouteHeader Route header to be added	 
+	 */
+	void AddRouteL(const CSIPHeaderBase& aRouteHeader);
+
+
+    //Route headers of the route set
+    RPointerArray<CSIPRouteHeader> iRoutes;
+    
+    //ETrue if a preconfigured route set exists (=the original request contained
+    //Route headers filled by upper layer).
+    TBool iPreconfigRouteExists;
+
+#ifdef CPPUNIT_TEST	
+	friend class CRouteSet_Test;
+	friend class CUserAgentClient_Test;
+#endif
+	};
+
+#endif // end of ROUTESET_H
+
+// End of File