wapstack/wapmessageapi/inc/wapmessage.h
author hgs
Mon, 09 Aug 2010 17:43:08 +0100
changeset 59 ac20d6a0a19d
parent 53 12b52b1a573e
permissions -rw-r--r--
201029_06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
53
12b52b1a573e 201027_09
hgs
parents: 44
diff changeset
     1
// Copyright (c) 2001-2010 Nokia Corporation and/or its subsidiary(-ies).
44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     2
// All rights reserved.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     7
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    10
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    11
// Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    12
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    13
// Description:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    14
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
#ifndef __WAPMESSAGE_H__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
#define __WAPMESSAGE_H__
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
#include <e32base.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
#include <e32std.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
#include <in_sock.h>
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
* @file
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
* The WAP Messaging API.  
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
* Four interfaces are defined that provide bound and fully-specified versions of WDP and Connectionless Push.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
* An instantiation of each may be obtained using the CreateImplementationL() function, and must be released 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
* using Release() when no longer required.  Release() causes the instantiation to be deleted.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
* For error codes returned by methods in this API, see <wapmsgerr.h>.  Most methods can return a set of general 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
* errors, with some returning additional specific errors.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
* @publishedAll
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
* @released since v7.0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
* Defines WAP-related types and error codes. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
namespace Wap
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
	// Bearer type definition
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
	typedef enum
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
	/** Type definition for an enum defining WAP bearer types. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
		/** All bearers. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
		EAll,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
		/** Internet Protocol. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
		EIP,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
		/** 7-bit SMS. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
		ESMS7,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
		/** 8-bit SMS. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
		ESMS,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
		/** 7-bit SMS. The bearers WAPSMS and WAPSMS7 are intended for WAP browsing where 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
		delivery reports are not required and the validity period is much shorter (5 minutes). */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
		EWAPSMS7,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
		/** 8-bit SMS. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
		EWAPSMS
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
		} TBearer;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
	// Port number definition
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
	/** A port number. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
	typedef TUint16 TPort;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
	class TAddressInfo
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
	/** Encapsulates an interface name and address. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
	public:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
		/** Interface name. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
		TName iName;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
		/** Interface IP address. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
		TInetAddr iAddress;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
		};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
* The WSP status type definition.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
* @internalComponent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
typedef TUint8 TWSPStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
/** Bound WDP */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
class CWapBoundDatagramService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
* Sends and receives datagrams over WDP using a specified local port.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
* The class is an ECom plug-in interface. Clients use NewL() to request an implementation 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
* of the interface, and then call the interface's virtual functions to access 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
* the implementation's services. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
* The use of the plug-in architecture allows different implementations to use 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
* different underlying WAP stacks.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
* Functions can return system wide error codes, and also API-specific errors 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
* as defined in wapmsgerr.h. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
	IMPORT_C static CWapBoundDatagramService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
	IMPORT_C static CWapBoundDatagramService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
	IMPORT_C virtual ~CWapBoundDatagramService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
	* subsequent incoming datagrams.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
	* This overload of Connect() allows an IP address associated with a network 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
	* interface to be specified. In multihomed systems, this can be used to specify 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
	* the network interface to which the endpoint should be bound.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
	* All CWapBoundDatagramService implementations must automatically close this 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
	* endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
	* @param aBearer	The bearer to listen on. Use EAll to specify all bearers.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
	* @param aPort		The port to listen on. If set to 0, a local port will be chosen 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
	* 					for the client's first SendTo()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
	* @param aInetAddr	The IP address of the network interface that should be used 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	*					in a multihomed system.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
	* @return			KErrNone on successful completion, or one of the system error codes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
	* 					on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
	virtual TInt Connect(Wap::TBearer aBearer, Wap::TPort aPort,TInetAddr aInetAddr)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
	* subsequent incoming datagrams.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
	* All CWapBoundDatagramService implementations must automatically close this 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
	* endpoint upon destruction. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
	* @param aBearer	The bearer to listen on. Use EAll to specify all bearers.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
	* @param aPort		The port to listen on. If set to 0, a local port will be chosen 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
	* 					for the client's first SendTo()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
	* @return			KErrNone on successful completion, or one of the system error codes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
	* 					on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
	virtual TInt Connect(Wap::TBearer aBearer,Wap::TPort aPort)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
	/** Sends data to a remote endpoint. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
	* @param aRemoteHost	The address of the remote host to which to send the data. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
	* 						The format of the address is bearer-specific.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
	* @param aRemotePort	The port on the remote host to which the data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
	* @param aBuffer		The data buffer to be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
	* @param aBearer		The bearer to be used, if the bound connection was opened with EAll
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
	* @return				KErrNone on successful completion, or one of the system error codes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
	* 						on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
virtual TInt SendTo(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, const TDesC8& aBuffer, Wap::TBearer aBearer)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
	* Waits for a datagram to be received, and discovers the size of buffer required 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
	* to retrieve it.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
	* This asynchronous method waits for a datagram to be received and will then 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
	* complete allowing the client to discover how large a buffer is needed to retrieve 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
	* the entire datagram that has been received. A later call to RecvFrom() with 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
	* a buffer of sufficient size will then allow the client to retrieve the datagram 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
	* fully. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
	* @param aDataSizePckg	On completion, the size of data received, in bytes
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
	* @param aReqStatus		Asynchonrous status word, used to signal when a data size is known
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
	* @return				KErrNone on successful completion, or one of the system error codes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
	* 						on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
	virtual TInt AwaitRecvDataSize(TPckg<TUint16>& aDataSizePckg, TRequestStatus& aReqStatus)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
	* Receives data on a bound port. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
	* An asynchronous notification is sent to the client when data arrives. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
	* @param aRemoteHost	On completion, the bearer-dependent address of the remote 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
	* 						host from which the data was received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
	* @param aRemotePort	On completion, the port on the remote host from which the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
	* 						data was received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
	* @param aBuffer		A client-allocated data buffer that on completion is filled 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
	* 						with data received. Data that overflows the buffer is discarded.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
	* @param aTruncated		On completion, indicates whether the received datagram was 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
	* 						truncated to fit in the client's supplied buffer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
	* @param aReqStatus		Asynchronous status word, used to notify the client that 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
	* 						a datagram was received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
	* @param aTimeout		An optional millisecond time-out which allows a timed read 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
	* 						to be made. If no data is received within the timeout period, the request 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
	* 						completes with KErrTimedOut. If a value of 0 is supplied, the timeout is infinite.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
	virtual TInt RecvFrom(TDes8& aRemoteHost, Wap::TPort& aRemotePort, TDes8& aBuffer, TBool& aTruncated, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
							TRequestStatus& aReqStatus, TUint32 aTimeout)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
	* Cancels a previously asynchronous RecvFrom() or AwaitRecvDataSize() request. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
	* If a datagram arrives at the local host, it will be discarded. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
	virtual void CancelRecv()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
	* Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
	* This is useful if the port was chosen automatically.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
	* @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
	* @return		KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
	* Gets the local address of this endpoint. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
	* @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
	* 					in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
	* 					buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
	* @return			KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
	* Gets the bearer on which a received datagram arrived. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
	* This is useful when EAll was specified as the bearer in Connect().
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
	* @param aBearer	On return, the bearer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
	* @return			KErrNone on successful completion, or one of the system error codes on failure.	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
	virtual TInt GetBearer(Wap::TBearer& aBearer)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
	* Queries the WDP bearer for its maximum datagram size and its nominal datagram size.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
	* The nominal size is the size within which a datagram won't have to be split 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
	* into smaller individual messages and then re-assembled at the other end. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
	* The function will fail for a stream connection.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
	* @param aMaxSize		On return, the maximum datagram size
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
	* @param aNominalSize	On return, the nominal datagram size
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
	* @return				KErrNone on successful completion, or one of the system error codes 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
	*						on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
	*/	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
	virtual TInt GetDatagramSizes(TUint16& aMaxSize, TUint16& aNominalSize)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
	IMPORT_C CWapBoundDatagramService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
private: // attributes
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
	};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
/** Fully-Specified WDP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
class CWapFullySpecDatagramService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
* Sends and receives datagrams over WDP using a specified local port and a single, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
* named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
* The class is an ECom plug-in interface. Clients use NewL() to request an implementation 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
* of the interface, and then call the interface's virtual functions to access 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
* the implementation's services. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
* The use of the plug-in architecture allows different implementations to use 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
* different underlying WAP stacks.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
* Functions can return system wide error codes, and also API-specific errors 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
* as defined in wapmsgerr.h. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
	IMPORT_C static CWapFullySpecDatagramService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
	IMPORT_C static CWapFullySpecDatagramService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
	IMPORT_C virtual ~CWapFullySpecDatagramService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
	// Connect to the wapstack, opening an endpoint which is to be used only with a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
	* subsequent incoming datagrams.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
	*	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
	* This overload of Connect() allows an IP address associated with a network 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
	* interface to be specified. In multihomed systems, this can be used to specify 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
	* the network interface to which the endpoint should be bound.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   293
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   294
	* All CWapFullySpecDatagramService implementations must automatically close 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   295
	* this endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   296
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   297
	* @param aRemoteHost	The bearer-dependent address of the remote host with which 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   298
	* 						the data will be exchanged
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   299
	* @param aRemotePort	The port on the remote host to which data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   300
	* @param aBearer		The bearer to use. EAll cannot be used.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   301
	* @param aInetAddr		The IP address of the network interface that should be used 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   302
	* 						in a multihomed system.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   303
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   304
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   305
	virtual TInt Connect(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, Wap::TBearer aBearer, TInetAddr aInetAddr)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   306
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   307
	// Connect to the wapstack, opening an endpoint which is to be used only with a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   308
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   309
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   310
	* subsequent incoming datagrams.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   311
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   312
	* All CWapFullySpecDatagramService implementations must automatically close 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   313
	* this endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   314
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   315
	* @param aRemoteHost	The bearer-dependent address of the remote host with which 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   316
	* 						the data will be exchanged
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   317
	* @param aRemotePort	The port on the remote host to which data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   318
	* @param aBearer		The bearer to use. EAll cannot be used.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   319
	* @return 				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   320
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   321
	virtual TInt Connect(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, Wap::TBearer aBearer)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   322
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   323
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   324
	* Sends data on a fully-specified connection.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   325
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   326
	* @param aBuffer	The data buffer to be written over the connection
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   327
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   328
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   329
	virtual TInt Send(const TDesC8& aBuffer)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   330
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   331
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   332
	* Waits for a datagram to be received, and discover how large a buffer is required 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   333
	* to retrieve it.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   334
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   335
	* This asynchronous request waits for a datagram to be received and will then 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   336
	* complete allowing the client to discover how large a buffer is needed to retrieve 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   337
	* the entire datagram that has been received. A later call to Recv() with a 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   338
	* buffer of sufficent size will then allow the client to retrieve the datagram 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   339
	* fully. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   340
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   341
	* @param aDataSizePckg	On completion, the size of data received, in bytes
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   342
	* @param aReqStatus		Asynchonrous status word, used to signal when a data size is known
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   343
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   344
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   345
	virtual TInt AwaitRecvDataSize(TPckg<TUint16>& aDataSizePckg, TRequestStatus& aReqStatus)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   346
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   347
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   348
	* Receives data on a bound port. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   349
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   350
	* An asynchronous notification is sent to the client when data arrives. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   351
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   352
	* @param aBuffer	A client-allocated data buffer that, on completion, is filled 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   353
	* 					with data received. Data that overflows the buffer is discarded.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   354
	* @param aTruncated	On completion, indicates whether the received datagram was 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   355
	* 					truncated to fit in the client's supplied buffer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   356
	* @param aReqStatus	Asynchronous status word, used to notify the client that 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   357
	* 					a datagram was received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   358
	* @param aTimeout	An optional millisecond time-out which allows a timed read 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   359
	* 					to be made. If no data is received within the timeout period, the request 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   360
	* 					completes with KErrTimedOut. If a value of 0 is supplied, the timeout is infinite.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   361
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   362
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   363
	virtual TInt Recv(TDes8& aBuffer, TBool& aTruncated, TRequestStatus& aReqStatus, TUint32 aTimeout)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   364
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   365
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   366
	* Cancels a previously asynchronous Recv() or AwaitRecvDataSize() request. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   367
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   368
	* If a datagram arrives at the local host, it will be discarded. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   369
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   370
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   371
	virtual void CancelRecv()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   372
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   373
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   374
	* Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   375
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   376
	* This is useful if the port was chosen automatically.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   377
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   378
	* @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   379
	* @return		KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   380
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   381
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   382
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   383
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   384
	* Gets the local address of this endpoint. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   385
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   386
	* @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   387
	* 					in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   388
	* 					buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   389
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   390
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   391
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   392
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   393
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   394
	* Queries the WDP bearer for its maximum datagram size and its nominal datagram size.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   395
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   396
	* The nominal size is the size within which a datagram won't have to be split 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   397
	* into smaller individual messages and then re-assembled at the other end. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   398
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   399
	* @param aMaxSize		On return, the maximum datagram size
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   400
	* @param aNominalSize	On return, the nominal datagram size
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   401
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   402
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   403
	virtual TInt GetDatagramSizes(TUint16& aMaxSize, TUint16& aNominalSize)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   404
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   405
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   406
	IMPORT_C CWapFullySpecDatagramService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   407
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   408
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   409
private: // ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   410
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   411
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   412
	};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   413
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   414
/** Bound Connectionless Push
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   415
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   416
class CWapBoundCLPushService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   417
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   418
* Listens for WAP Push messages from any sender.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   419
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   420
* The class is an ECom plug-in interface. Clients use NewL() to request an implementation 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   421
* of the interface, and then call the interface's virtual functions to access 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   422
* the implementation's services. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   423
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   424
* The use of the plug-in architecture allows different implementations to use 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   425
* different underlying WAP stacks.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   426
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   427
* Functions can return system wide error codes, and also API-specific errors 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   428
* as defined in wapmsgerr.h. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   429
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   430
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   431
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   432
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   433
	IMPORT_C static CWapBoundCLPushService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   434
	IMPORT_C static CWapBoundCLPushService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   435
	IMPORT_C virtual ~CWapBoundCLPushService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   436
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   437
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   438
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   439
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   440
	// Opens a socket which is to be used to listen for subsequent incoming Push messages from any sender;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   441
	// i.e. it has only been 'bound' to the local address	 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   442
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   443
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   444
	* Push messages from any sender.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   445
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   446
	* This overload of Connect() allows an IP address associated with a network 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   447
	* interface to be specified. In multihomed systems, this can be used to specify 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   448
	* the network interface to which the endpoint should be bound.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   449
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   450
	* All CWapBoundCLPushService implementations must automatically close this endpoint 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   451
	* upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   452
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   453
	* @param aBearer	The bearer to listen on. Use EAll to specify all bearers.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   454
	* @param aPort		The port to listen on. If set to 0, a local port will be chosen 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   455
	* 					for the client's first SendTo()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   456
	* @param aSecure	Security flag to indicate whether WTLS should be used or not
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   457
	* @param aInetAddr	The address of the adapter to use
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   458
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   459
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   460
	virtual TInt Connect(Wap::TBearer aBearer, Wap::TPort aPort, TBool aSecure, TInetAddr aInetAddr)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   461
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   462
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   463
	// Opens a socket which is to be used to listen for subsequent incoming Push messages from any sender;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   464
	// i.e. it has only been 'bound' to the local address
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   465
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   466
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   467
	* Push messages from any sender.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   468
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   469
	* All CWapBoundCLPushService implementations must automatically close this endpoint 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   470
	* upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   471
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   472
	* @param aBearer	The bearer to listen on. Use EAll to specify all bearers.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   473
	* @param aPort		The port to listen on. If set to 0, a local port will be chosen 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   474
	* 					for the client's first SendTo()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   475
	* @param aSecure	Security flag to indicate whether WTLS should be used or not
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   476
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   477
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   478
	virtual TInt Connect(Wap::TBearer aBearer, Wap::TPort aPort, TBool aSecure)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   479
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   480
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   481
	* Requests an asynchronous notification upon arrival of the next push message 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   482
	* on the listening connection.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   483
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   484
	* The request completes upon receipt of the message, filling the buffers with 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   485
	* as much received data as possible. A return code indicates whether further 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   486
	* data remains. The call must be re-issued for subsequent messages or to receive 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   487
	* remaining data from a previous push message.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   488
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   489
	* @param aPushHeaders	A client-allocated buffer that, on completion, is filled 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   490
	* 						with the push message's header data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   491
	* @param aPushBody		A client-allocated buffer that, on completion, is filled with 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   492
	* 						the push message's body data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   493
	* @param aPushIdPckg	On completion, an integer ID that uniquely specifies the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   494
	* 						push message
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   495
	* @param aReqStatus		Asynchonrous status word, used by the service provider to 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   496
	* 						notify the client when a push message has arrived. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   497
	*						EMoreData is returned if more pushed data is available.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   498
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   499
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   500
	virtual TInt AwaitPush(TDes8& aPushHeaders, TDes8& aPushBody, TPckgBuf<TUint8>& aPushIdPckg, TRequestStatus& aReqStatus)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   501
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   502
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   503
	* Cancels a previous push message request.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   504
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   505
	* If a push message arrives, the client will not be notified. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   506
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   507
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   508
	virtual void CancelAwaitPush()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   509
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   510
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   511
	* Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   512
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   513
	* This is useful if the port was chosen automatically. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   514
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   515
	* @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   516
	* @return		KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   517
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   518
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   519
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   520
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   521
	* Gets the local address of this endpoint. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   522
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   523
	* @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   524
	* 					in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   525
	* 					buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   526
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   527
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   528
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   529
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   530
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   531
	* Gets the bearer on which a received datagram arrived. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   532
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   533
	* This is useful when EAll was specified as the bearer in Connect().
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   534
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   535
	* @param aBearer	On return, the bearer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   536
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   537
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   538
	virtual TInt GetBearer(Wap::TBearer& aBearer)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   539
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   540
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   541
	 * Gets the address of the remote server.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   542
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   543
	 * This function cannot be called when there is an outstanding AwaitPush().
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   544
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   545
	 * @param aRemoteHost	On return, the address of the remote host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   546
	 * 						in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   547
	 * 						buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   548
	 * @return				KErrNone on successful completion, KErrNotSupported if not implemented,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   549
	 * 						or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   550
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   551
	virtual TInt GetServerAddress(HBufC8*& aRemoteHost)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   552
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   553
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   554
	IMPORT_C CWapBoundCLPushService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   555
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   556
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   557
private: // ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   558
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   559
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   560
};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   561
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   562
/** Fully-Specified Connectionless Push
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   563
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   564
class CWapFullySpecCLPushService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   565
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   566
* Listens for WAP Push messages from a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   567
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   568
* The class is an ECom plug-in interface. Clients use NewL() to request an implementation 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   569
* of the interface, and then call the interface's virtual functions to access 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   570
* the implementation's services. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   571
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   572
* The use of the plug-in architecture allows different implementations to use 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   573
* different underlying WAP stacks.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   574
* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   575
* Functions can return system wide error codes, and also API-specific errors 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   576
* as defined in wapmsgerr.h. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   577
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   578
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   579
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   580
	IMPORT_C static CWapFullySpecCLPushService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   581
	IMPORT_C static CWapFullySpecCLPushService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   582
	IMPORT_C virtual ~CWapFullySpecCLPushService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   583
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   584
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   585
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   586
 	// Opens a socket which is to be used only with a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   587
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   588
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   589
	* Push messages from a specified remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   590
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   591
	* This overload of Connect() allows an IP address associated with a network 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   592
	* interface to be specified. In multihomed systems, this can be used to specify 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   593
	* the network interface to which the endpoint should be bound.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   594
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   595
	* All CWapFullySpecCLPushService implementations must automatically close this 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   596
	* endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   597
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   598
	* @param aRemoteHost	The bearer-dependent address of the remote host with which 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   599
	* 						the data will be exchanged
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   600
	* @param aRemotePort	The port on the remote host to which data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   601
	* @param aBearer		The bearer to listen on. You cannot use EAll.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   602
	* @param aSecure		Security flag to indicate whether WTLS should be used or not
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   603
	* @param aInetAddr		The address of the adapter to use
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   604
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   605
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   606
	virtual TInt Connect(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, Wap::TBearer aBearer, TBool aSecure, TInetAddr aInetAddr)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   607
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   608
	// Opens a socket which is to be used only with a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   609
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   610
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   611
	* Push messages from a specified remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   612
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   613
	* All CWapFullySpecCLPushService implementations must automatically close this 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   614
	* endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   615
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   616
	* @param aRemoteHost	The bearer-dependent address of the remote host with which 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   617
	* 						the data will be exchanged
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   618
	* @param aRemotePort	The port on the remote host to which data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   619
	* @param aBearer		The bearer to listen on. You cannot use EAll.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   620
	* @param aSecure		Security flag to indicate whether WTLS should be used or not
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   621
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   622
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   623
	virtual TInt Connect(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, Wap::TBearer aBearer, TBool aSecure)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   624
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   625
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   626
	* Requests an asynchronous notification upon arrival of the next push message 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   627
	* on the listening connection.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   628
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   629
	* The request completes upon receipt of the message, filling the buffers with 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   630
	* as much received data as possible. A return code indicates whether further 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   631
	* data remains. The call must be re-issued for subsequent messages or to receive 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   632
	* remaining data from a previous push message.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   633
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   634
	* @param aPushHeaders	A client-allocated buffer that, on completion, is filled 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   635
	* 						with the push message's header data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   636
	* @param aPushBody		A client-allocated buffer that, on completion, is filled with 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   637
	* 						the push message's body data
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   638
	* @param aPushIdPckg	On completion, an integer ID that uniquely specifies the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   639
	* 						push message
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   640
	* @param aReqStatus		Asynchronous status word, used by the service provider to 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   641
	* 						notify the client when a push message has arrived.  
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   642
	* 						EMoreData is returned if more pushed data is available.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   643
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   644
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   645
	virtual TInt AwaitPush(TDes8& aPushHeaders, TDes8& aPushBody, TPckgBuf<TUint8>& aPushIdPckg, TRequestStatus& aReqStatus)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   646
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   647
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   648
	* Cancels a previous push message request.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   649
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   650
	* If a push message arrives, the client will not be notified. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   651
	*
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   652
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   653
	virtual void CancelAwaitPush()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   654
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   655
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   656
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   657
	* Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   658
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   659
	* This is useful if the port was chosen automatically. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   660
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   661
	* @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   662
	* @return		KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   663
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   664
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;	// // (out) the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   665
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   666
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   667
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   668
	* Gets the local address of this endpoint. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   669
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   670
	* @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   671
	* 					in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   672
	* 					buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   673
	* @return			KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   674
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   675
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;	// // (out) the address of the local host
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   676
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   677
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   678
	IMPORT_C CWapFullySpecCLPushService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   679
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   680
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   681
private: // ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   682
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   683
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   684
};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   685
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   686
/** Bound Connectionless WSP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   687
*  @released since v8.0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   688
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   689
class CWapBoundCLWSPService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   690
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   691
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   692
	IMPORT_C static CWapBoundCLWSPService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   693
	IMPORT_C static CWapBoundCLWSPService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   694
	IMPORT_C virtual ~CWapBoundCLWSPService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   695
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   696
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   697
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   698
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   699
	 * Connects to the WAP stack, opening an endpoint that can be used for S-Unit-MethodInvoke and 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   700
	 * S-Unit-MethodResult primitives.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   701
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   702
	 * @param aBearer	The bearer to listen on (use EAll for all bearers)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   703
	 * @param aPort		The port to listen on. If set to 0, a local port will be chosen for the 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   704
	 *					client's first MethodInvoke()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   705
	 * @return			KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   706
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   707
	virtual TInt Connect(Wap::TBearer aBearer,Wap::TPort aPort, TBool aSecure)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   708
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   709
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   710
	 * Sends a request to a remote endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   711
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   712
	 * @param aBearer			The bearer to be used, if the bound connection was opened with EAll
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   713
	 * @param aRemoteHost		The address of the remote host to which to send the request. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   714
	 * 							The format of the address is bearer-specific.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   715
	 * @param aRemotePort		The port on the remote host to which the request will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   716
	 * @param aMethod
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   717
	 * @param aURI
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   718
	 * @param aReqHeaders
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   719
	 * @param aReqBody
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   720
	 * @param aTransactionId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   721
	 * @return					KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   722
	 */ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   723
	virtual TInt MethodInvoke(Wap::TBearer aBearer, const TDesC8& aRemoteHost, Wap::TPort aRemotePort, TUint aMethod, const TDesC& aURI, const TDesC8& aReqHeaders, const TDesC8& aReqBody, const TUint8 aTransactionId)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   724
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   725
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   726
	 * Waits for a datagram to be received.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   727
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   728
	 * @param aReqHeaders
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   729
	 * @param aReqBody
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   730
	 * @param aTransactionIdPckg
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   731
	 * @param aWspStatus
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   732
	 * @param aReqStatus			Asynchonrous status word, used to signal when a data size is known
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   733
	 * @param aTimeout
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   734
	 * @return 						KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   735
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   736
	virtual TInt MethodResult(TDes8& aReqHeaders, TDes8& aReqBody, TPckgBuf<TUint8>& aTransactionIdPckg, TWSPStatus& aWspStatus, TRequestStatus& aReqStatus, TUint32 aTimeout)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   737
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   738
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   739
	 * Cancels a previously requested asynchronous MethodResult() notification.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   740
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   741
	 * If a datagram arrives at the local host, it will be discarded.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   742
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   743
	 */	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   744
	virtual void CancelReq()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   745
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   746
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   747
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   748
	 * Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   749
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   750
	 * This is useful if the port was chosen automatically.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   751
 	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   752
 	 * @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   753
	 * @return		KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   754
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   755
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;	// // (out) the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   756
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   757
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   758
	 * Gets the local address of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   759
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   760
	 * @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   761
	 * 						in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   762
	 * 						buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   763
	 * @return				KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   764
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   765
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;	// // (out) the address of the local host
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   766
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   767
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   768
	 * Gets the bearer on which a received datagram arrived.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   769
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   770
	 * Useful when EAll was specified in Connect()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   771
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   772
	 * @param aBearer	On return, the bearer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   773
	 * @return			KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   774
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   775
	virtual TInt GetBearer(Wap::TBearer& /*aBearer*/)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   776
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   777
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   778
	 * Gets the remote server address.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   779
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   780
	 * @param aServerAddress	On return, the address of the remote server. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   781
	 * 							in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   782
	 * 							buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   783
	 * @return					KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   784
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   785
	virtual TInt GetServerAddress(HBufC8*& aServerAddress)=0;	// // (out) the address of the remote server
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   786
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   787
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   788
	IMPORT_C CWapBoundCLWSPService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   789
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   790
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   791
private: // ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   792
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   793
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   794
};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   795
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   796
/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   797
* Fully-Specified Connectionless WSP
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   798
*  @released since v8.0
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   799
*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   800
class CWapFullySpecCLWSPService : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   801
{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   802
public: // creation/deletion
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   803
	IMPORT_C static CWapFullySpecCLWSPService* NewL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   804
	IMPORT_C static CWapFullySpecCLWSPService* NewL(const TUid& aImplementation);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   805
	IMPORT_C virtual ~CWapFullySpecCLWSPService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   806
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   807
public: // API methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   808
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   809
	// Opens a socket which is to be used only with a single, named remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   810
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   811
	* Connects to the WAP stack, opening an endpoint that can be used to listen for 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   812
	* Push messages from a specified remote host.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   813
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   814
	* All CWapFullySpecCLWSPService implementations must automatically close this 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   815
	* endpoint upon destruction.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   816
	* 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   817
	* @param aRemoteHost	The bearer-dependent address of the remote host with which 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   818
	*						the data will be exchanged
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   819
	* @param aRemotePort	The port on the remote host to which data will be sent
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   820
	* @param aBearer		The bearer to listen on. You cannot use EAll.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   821
	* @param aSecure		Security flag to indicate whether WTLS should be used or not
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   822
	* @return				KErrNone on successful completion, or one of the system error codes on failure. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   823
	*/
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   824
	virtual TInt Connect(const TDesC8& aRemoteHost, Wap::TPort aRemotePort, Wap::TBearer aBearer, TBool aSecure)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   825
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   826
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   827
	 * Sends a request to a remote endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   828
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   829
	 * @param aMethod
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   830
	 * @param aURI
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   831
	 * @param aReqHeaders
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   832
	 * @param aReqBody
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   833
	 * @param aTransactionId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   834
	 * @return					KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   835
	 */ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   836
	virtual TInt MethodInvoke(TUint aMethod, const TDesC& aURI, const TDesC8& aReqHeaders, const TDesC8& aReqBody, TUint8 aTransactionId)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   837
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   838
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   839
	 * Waits for a datagram to be received
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   840
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   841
	 * @param aReqHeaders
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   842
	 * @param aReqBody
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   843
	 * @param aTransactionIdPckg
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   844
	 * @param aWspStatus
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   845
	 * @param aReqStatus			Asynchonrous status word, used to signal when a data size is known
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   846
	 * @param aTimeout
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   847
	 * @return						KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   848
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   849
	virtual TInt MethodResult(TDes8& aReqHeaders, TDes8& aReqBody, TPckgBuf<TUint8>& aTransactionIdPckg, TWSPStatus& aWspStatus, TRequestStatus& aReqStatus, TUint32 aTimeout)=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   850
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   851
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   852
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   853
	 * Cancels a previously-requested MethodResult() notification. 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   854
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   855
	 * If a message arrives the client will not be notified.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   856
	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   857
	 */ 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   858
	virtual void CancelReq()=0;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   859
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   860
	/** 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   861
	 * Gets the local port of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   862
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   863
	 * This is useful if the port was chosen automatically.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   864
 	 * 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   865
 	 * @param aPort	On return, the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   866
	 * @return		KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   867
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   868
	virtual TInt GetLocalPort(Wap::TPort& aPort)=0;	// // (out) the port number
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   869
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   870
	/**
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   871
	 * Gets the local address of this endpoint.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   872
	 *
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   873
	 * @param aLocalHost	On return, the address of the local host. Clients must pass 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   874
	 * 						in a reference to a NULL HBufC8 pointer. The function allocates a new HBufC8 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   875
	 * 						buffer to hold the address, and passes ownership of the buffer to the client.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   876
	 * @return				KErrNone on successful completion, or one of the system error codes on failure.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   877
	 */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   878
	virtual TInt GetLocalAddress(HBufC8*& aLocalHost)=0;	// // (out) the address of the local host
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   879
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   880
protected: // methods
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   881
	IMPORT_C CWapFullySpecCLWSPService();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   882
	IMPORT_C void ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   883
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   884
private: // ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   885
	// D'tor Key identification required for ECOM
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   886
	TUid iDtor_ID_Key;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   887
};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   888
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   889
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   890
// Utility class for client/implementation use.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   891
class CWapMessageUtils : public CBase
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   892
/** Utility functions for use with WAP Messaging. */
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   893
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   894
public:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   895
	// // Return a list of all the addresses that are available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   896
	IMPORT_C static TInt GetLocalAddressesL(RArray<Wap::TAddressInfo>& aAddressInfo); 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   897
	};
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   898
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   899
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   900
#endif // __WAPMESSAGE_H__