wapstack/wapmessageapi/sws/ActiveSocket.h
author Pat Downey <patd@symbian.org>
Tue, 13 Jul 2010 14:53:59 +0100
branchRCL_3
changeset 50 2ac16fe2d995
parent 18 50bae5c5c85f
permissions -rw-r--r--
Re-merge addition of wapstack to fid bug 1398.

// Copyright (c) 2003-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:
//

#ifndef __ACTIVESOCKET_H__
#define __ACTIVESOCKET_H__

#include <e32std.h>
#include <wapmessage.h>
#include "WapSwsTimeOut.h"


class CActiveSocketSMS;
class CActiveSocketUDP;
class MProgressNotify;

enum TWapMessageState
	{
	/**
	The state that is no outstanding request.
	*/
	EIdle,
	/**
	The state that the messaging API client is requesting data length
	*/
	ERequestingLength,
	/**
	The state the the messaging API client is requesting data
	*/
	ERequestingData,
	/**
	The state that the data size is ready to be read
	*/
	EPendingLength,
	/**
	The state that the messaging API client got the data length
	*/
	EGotLength,
	/**
	The state that the received data is ready to be read
	*/
	EPendingData,
	/**
	The state the data is being reading, but not finished
	*/
	EReading,
	/**
	The state that there are more data to be received from ESock (PRT 1.5)
	*/
	EContinuous
	};
enum TWapMessageType
	{
	/**
	Wsp message
	*/
	EWapWsp,
	/**
	Wdp message
	*/
	EWapWdp
	};
enum TWapActiveSocketState
	{
	/**
	No outstanding request state
	*/
	ESocketIdle,
	/**
	Waiting for the PDU length state
	*/
	ESocketWaitingForLength,
	/**
	Waiting for the PDU data state
	*/
	ESocketWaitingForData
	};
enum TWapNotificationEvent
	{
	/**
	The event that PDU length is ready.
	*/
	EPduLengthReceived,
	/**
	The event thst PDU us ready
	*/
	EPduReceived
	};

class TWapNotificationInfo
	{
public:
	inline TWapNotificationInfo(Wap::TBearer aBearer, TInt aError);
	Wap::TBearer iBearer;
	TInt iError;
	};

inline TWapNotificationInfo::TWapNotificationInfo(Wap::TBearer aBearer, TInt aError):
iBearer(aBearer), iError(aError)
	{
	}

typedef TPckgBuf<TWapNotificationInfo> TWapNotificationInfoBuf;

const TUint KMaxUdpBearerDataBufferLength=1024;

class CWapMessageRecord: public CBase
/** 
The Base class to represent the received WSP and WDP PDU
@internalComponent
@released
@since v8.0
*/
	{
public:
	static CWapMessageRecord* NewL(TWapMessageType aType);
	virtual ~CWapMessageRecord();
	TWapMessageState GetDataState();
	void SetDataState(TWapMessageState aStatus);
	void CreatePduBufferL(TBool aFixLengthFlag);
	TPckgBuf<TUint32>* GetPduSizeRef();
	void SetPduSize(TUint32 aLength);
	TUint32 GetPduSize();
	HBufC8*& GetPduPtr();
	/**
	To read the received Wdp pdu
	@internalComponent
	@released
	@since v8.0
	@param aBuffer(out) the buffer to contain the received wdp pdu
	@param aTruncated(out) the flag to represent if the data is truncated or not
	@returns KErrNone on successful completion, or one of the system error codes on failure.
	*/
	virtual TInt GetPduData(TDes8& aBuffer, TBool& aTruncated)=0;
	/**
	To unpack the received wdp pdu to wsp message.
	@internalComponent
	@released
	@since v8.0
	*/
	virtual void UnpackPduToWspDataL()=0;
	/**
	To read the wsp message from the buffer
	@internalComponent
	@released
	@since v8.0
	@param aWspHeader(out) the buffer to contain the wsp header
	@param aWspBody(out) the buffer to contain the wsp body
	@param iTransactionId(out) the received transaction ID
	@param aWspStatus(out) the received wsp status
	@returns KErrNone on successful completion, or one of the system error codes on failure.
	*/
	virtual TInt GetWspData(TDes8& aWspHeader, TDes8& aWspBody, TUint8& aTransactionId, TWSPStatus& aWspStatus)=0;
	virtual void CleanUpData();
public:
	/**The received WDP PDU Data buffer
	*/
	HBufC8* iPdu;
	/**The received WDP PDU length buffer
	*/
	TPckgBuf<TUint32> iDataLength;

protected:
	CWapMessageRecord();
	/**The state of the received the WSP or WDP data
	*/
	TWapMessageState iState;
	};

class CWspMessageRecord: public CWapMessageRecord
/** 
The class to represent the received WSP PDU
@internalComponent
@released
@since v8.0
*/
	{
public: 
	CWspMessageRecord();
	~CWspMessageRecord();
	void UnpackPduToWspDataL();
	TInt GetWspData(TDes8& aWspHeader, TDes8& aWspBody, TUint8& aTransactionId, TWSPStatus& aWspStatus);
	TInt GetPduData(TDes8& aBuffer, TBool& aTruncated);
	void CleanUpData();
private:
	/**
	The buffer for received Wsp header.
	*/
	HBufC8* iWspHeader;
	/**
	The buffer for received Wsp body.
	*/
	HBufC8* iWspBody;
	/**
	The received the transaction Id.
	*/
	TUint8 iTransactionId;
	/**
	The received WSP layer status
	*/
	TWSPStatus iWspStatus;
	/**
	The offset of the header for next reading
	*/
	TInt iHeaderOffset;
	/**
	The offset of the body for next reading
	*/
	TInt iBodyOffset;
	};

class CWdpMessageRecord: public CWapMessageRecord
/** 
The class to represent the received WDP PDU
@internalComponent
@released
@since v8.0
*/
	{
public:
	CWdpMessageRecord();
	~CWdpMessageRecord();
	void UnpackPduToWspDataL();
	TInt GetWspData(TDes8& aWspHeader, TDes8& aWspBody, TUint8& aTransactionId, TWSPStatus& aWspStatus);
	TInt GetPduData(TDes8& aBuffer, TBool& aTruncated);
	void CleanUpData();
private:
	/**
	The offset of the pdu for next reading
	*/
	TUint32 iPduOffset;
	};

class CActiveSocket: public CActive
/** 
The base class for the different bearer classes.
@internalComponent
@released
@since v8.0
*/
	{
public:
	static void NewL(RSocketServ& aSocketServ, RPointerArray<CActiveSocket>& aActiveSockets, Wap::TBearer aBearer, TWapMessageType aType, MProgressNotify* aNotify, Wap::TPort aLocalPort, RConnection* aConnection=NULL);
	static void NewL(RSocketServ& aSocketServ, RPointerArray<CActiveSocket>& aActiveSockets, Wap::TBearer aBearer, TWapMessageType aType, MProgressNotify* aNotify, const TSockAddr& aRemoteAddr, RConnection* aConnection=NULL);
	virtual ~CActiveSocket();
	virtual void ConstructL(TWapMessageType aType);
	/**
	Read the received Wdp pdu length.
	@internalComponent
	@released
	@since v8.0
	@returns KErrNone on successful completion, or one of the system error codes on failure.
	*/
	virtual TInt AwaitRecvDataSize() = 0;
	/**
	Read the received Wdp pdu.
	@internalComponent
	@released
	@since v8.0
	@returns KErrNone on successful completion, or one of the system error codes on failure.
	*/
	virtual TInt Receive() = 0;
	TSockAddr& GetLocalAddress();
	TInt GetLocalPort(Wap::TPort& aLocalPort);
	TInt GetRemoteAddress(HBufC8*& aAddr);
	TSockAddr& GetRemoteAddress();

	TWapMessageState GetDataState();
	void SetDataState(TWapMessageState aState);
	TUint32 GetPduSize();
	TInt GetPduData(TDes8& aBuffer, TBool& aTruncated);
	TInt GetWspData(TDes8& aWspHeader, TDes8& aWspBody, TUint8& aTransactionId, TWSPStatus& aStatus);	
	void UnpackPduToWspDataL();
	Wap::TBearer GetBearerType();
	RSocket& Socket();
	void CleanUpData();

public:
	/**The RSocket instance to send and receive WDP PDU.
	*/
	RSocket iSocket;
	/**The remote address for the last received message
	*/
	TSockAddr iRemoteAddr;
	/**The local address for the last received message
	*/
	TSockAddr iLocalAddr;

protected:
	CActiveSocket(RSocketServ& aSocketServ, Wap::TBearer aBearerType, MProgressNotify* aNotify, Wap::TPort aLocalPort);
	CActiveSocket(RSocketServ& aSocketServ, Wap::TBearer aBearerType, MProgressNotify* aNotify, const TSockAddr& aRemoteAddr, Wap::TPort aLocalPort);

protected:
	/**The data buffer to receive WDP or WSP message
	*/
	CWapMessageRecord* iMessageRecord;
	/**The RSocketServ reference from WAP message API
	*/
	RSocketServ& iSocketServ;
	/**The Bearer type
	*/
	Wap::TBearer iBearerType;
	/**The port number for the last received message
	*/
	Wap::TPort iLocalPort;
	/**The state of the bearer
	*/
	TWapActiveSocketState iSocketState;
	/**
	The instance that to be notified when data is received
	*/
	MProgressNotify* iNotify;
	/**
	Buffer for the first read from ESock
	*/
	TPtr8 iBuf;
	/**
	Reported remaining length for PRT 1.5 
	*/
	TSockXfrLength iRxlength;
	/**
	Buffer for continious read from ESock
	*/
	TPtr8 iBufCon;
	};

class CActiveSocketSMS : public CActiveSocket
/** 
The class represent the SMS bearer. It will open a RSocket over WapSMS protocol, send and 
receive WDP PDU.
@internalComponent
@released
@since v8.0
*/
{
public:
	CActiveSocketSMS(RSocketServ& aSocketServ, MProgressNotify* aNotify, Wap::TBearer aBearer, Wap::TPort aLocalPort);
	CActiveSocketSMS(RSocketServ& aSocketServ, MProgressNotify* aNotify, Wap::TBearer aBearer, const TSockAddr& aRemoteAddr);
	virtual ~CActiveSocketSMS();
	TInt AwaitRecvDataSize();
	TInt Receive();
	void ConstructL(TWapMessageType aType);
private:
	void RunL();
	void DoCancel();
};

class CActiveSocketUDP : public CActiveSocket
/** 
The class represent the UDP bearer. It will open a RSocket over UDP protocol, send and 
receive WDP PDU. It is not supported in released v8.0.
@internalComponent
@released
@since v8.0
*/
{
public:
	CActiveSocketUDP(RSocketServ& aSocketServ, MProgressNotify* aNotify, Wap::TBearer aBearer, Wap::TPort aLocalPort, RConnection* aConnection);
	CActiveSocketUDP(RSocketServ& aSocketServ, MProgressNotify* aNotify, Wap::TBearer aBearer, const TSockAddr& aRemoteAddr, RConnection* aConnection);
	virtual ~CActiveSocketUDP();
	TInt AwaitRecvDataSize();
	TInt Receive();
	void ConstructL(TWapMessageType aType);
private:
	void RunL();
	void DoCancel();
	/**
	The RConnection shared with the WAP message API client.
	*/
	RConnection* iConnection;
};

#endif // __ACTIVESOCKET_H__