realtimenetprots/sipfw/SIP/SigCompController/Common/inc/MSigCompController.h
changeset 0 307788aac0a8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/realtimenetprots/sipfw/SIP/SigCompController/Common/inc/MSigCompController.h	Tue Feb 02 01:03:15 2010 +0200
@@ -0,0 +1,187 @@
+/*
+* 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          : MSigCompController.h
+* Part of       : ConnectionMgr
+* Version       : SIP/4.0 
+*
+*/
+
+
+
+
+/**
+ @internalComponent
+*/
+#ifndef __MSIGCOMPCONTROLLER_H__
+#define __MSIGCOMPCONTROLLER_H__
+
+#include <in_sock.h>
+class CSIPRequest;
+class CSIPResponse;
+class TSIPTransportParams;
+
+/**
+ * Interface class for sigcomp controller
+ */
+
+class MSigCompController 
+	{
+	public:
+
+    /**
+     * Destructor.
+	 */
+
+    virtual ~MSigCompController () { };
+
+    /**
+     * Checks if signalling compression is installed.
+     *
+     * @returns ETrue if installed, EFalse otherwise.
+	 */
+    virtual TBool IsSupported () const = 0;
+
+    /**
+     * After calling this function Connection Mgr always uses
+     * signalling compression for requests sent with compartmentId
+     * returned by this function.      
+     * Multiple users can share a compression to one host:
+     * In sending phase remote inetaddr and compartmentid are mapped together.
+     * If some other compartmentid has already same remote destination address
+     * mapped with it, ids share the same compartment.
+     *
+     * @returns compartmentId
+	 */
+    virtual TUint32 CreateCompartmentL (TUint32 aIapId) = 0;
+
+    /**
+     * Removes compression for passed compartmentId.
+     * If no compression for the host was found, the function silently returns.
+	 */
+    virtual void RemoveCompartment (TUint32 aCompartmentId) = 0;
+
+	/**
+	 * The function encodes the Request and compresses 
+	 * it if there is compartment matching compartmentId. After calling
+	 * this function, next-hop address is mapped with compartmentId.
+	 * Leaves with a system wide error if encoding or compressing fails.
+	 * 
+	 * @param aTransportParams contains compartmentId and iapId
+	 *
+	 * @param aRequest a request to encode and compress	
+	 *			
+	 * @param aAddress	A remote destination address
+	 *					
+	 * @returns encoded data, the ownership is transferred
+	 */
+	virtual CBufBase* EncodeL (const TSIPTransportParams& aTransportParams,
+	                           CSIPRequest& aRequest,
+                               const TInetAddr& aAddress,
+							   TBool aStreambasedProtocol,
+							   TBool& aCompressed) = 0;
+
+	/**
+	 * The function encodes the Response and compresses 
+     * it if there is compartment matching compartmentId. After calling
+	 * this function, next-hop address is mapped with compartmentId.
+	 * Leaves with a system wide error if encoding or compressing fails.
+	 * 
+	 * @param aTransportParams contains compartmentId and iapId
+	 *
+	 * @param aResponse a response to encode and compress	
+	 *				
+	 * @param aAddress	A remote destination address					
+	 * 
+	 * @returns encoded data, the ownership is transferred
+	 */
+	virtual CBufBase* EncodeL (const TSIPTransportParams& aTransportParams,
+	                           CSIPResponse& aResponse,
+                               const TInetAddr& aAddress,
+							   TBool aStreambasedProtocol,
+							   TBool& aCompressed) = 0;
+
+	/**
+	 * Checks if the message contains the delimeter indicating SigComp
+	 * message end. This function must be used only with stream-based
+	 * transports, otherwise it will always return EFalse.
+	 *
+	 * @pre IsSigCompMsg()==ETrue
+	 *
+	 * @returns ETrue is the SigComp message is complete, EFalse otherwise
+	 */
+	virtual TBool IsCompleteSigCompMessageL (const TDesC8& aMessage) const = 0;
+
+	
+	/**
+	 * Checks if the first byte contains bit pattern indicating the start
+	 * of the SigComp message. Function examines only the first byte.
+	 *
+	 * @returns ETrue if the first byte indicates the start of the SigComp message,
+	 *          EFalse otherwise
+	 */
+	virtual TBool IsSigCompMsg (const TDesC8& aMessage) const = 0;
+
+
+  	/**
+	 * Decompress the message; leaves on failure. 
+	 * Leaves with a system wide error decompressing fails.
+	 * The function expects the client to provide complete SigComp message.
+	 *
+	 * @pre IsSigCompMsg()==ETrue
+	 * 
+	 * @param aMessage a message to decompress. The message must start with SigComp specific
+	 *                 delimeter and end with SigComp specific delimeter
+	 *
+	 * @param aBytesConsumed on return will contain the number of bytes consumed by the decompression
+	 *                       from the original message 
+	 * @returns decompressed message, the ownership is transferred
+	 */
+	virtual CBufBase* DecompressL (const TDesC8& aMessage,
+                                   TUint& aBytesConsumed,
+                                   TBool aIsStreamBased) = 0;
+
+	/**
+	 * The function returns count of compartments
+	 *
+	 * @returns count of compartments
+	 */
+	virtual TInt CompartmentCount () = 0;
+
+	/**
+     * If the compartment has been previously used for decompressing,
+     * resets the compartment. If not, deletes the compartment. 
+     *
+     * @param aCompartmentId the IAP for which the sending failed
+     *
+     */
+	virtual void SendFailedL (TUint32 aCompartmentId) = 0;
+
+	/**
+	 * Allows the state of the decompressed message to be saved; leaves on failure.
+	 * 
+	 * @param aAddress	A remote destination address					
+	 * @param aIapId	A iap id
+	 */
+	virtual void AllowL(const TInetAddr& aAddress, TUint32 aIapId) = 0;
+
+	/**
+	 * Denies the state of the message to be saved.
+	 */
+	virtual void Deny() = 0;
+
+    };
+
+#endif // end of __MSIGCOMPCONTROLLER_H__
+