datacommsserver/esockserver/inc/ss_nodemessages_availability.h
author Fionntina Carville <fionntinac@symbian.org>
Wed, 17 Nov 2010 16:18:58 +0000
branchRCL_3
changeset 88 077156ad1d4e
parent 0 dfb7c4ff071f
permissions -rw-r--r--
Bug 2675. Take default commdb from ipconnmgmt instead.

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

/**
 @file
 @publishedPartner
 @released since 9.5
*/

#ifndef SYMBIAN_NODEMESSAGES_AVAILABILITY_H
#define SYMBIAN_NODEMESSAGES_AVAILABILITY_H

#include <comms-infras/ss_nodemessages.h>
#include <comms-infras/ss_nodemessages_selector.h>

namespace ESock
{

/**
Message interface for availability provider nodes.
Nodes wishing to implement this interface must implement all message protocols in the interface.
*/
class TCFAvailabilityProvider
	{
private:
  	enum
 	{
	ECFAvailabilityNotificationRegistration	= 1,
	};
	
protected:

public:
    enum { ERealmId = 0x10285F3E }; //UID allocated on 4/6/08 from KUidNodeMessageRealms 

    /**
	Sent by an availability subscriber (usually a control client of a meta provider) to its
    availability providers registering for availability notifications.
	This message will kick off an availability monitoring activity on its recipient. This
	activity will run forever unless an error occurs or it is cancelled.

       @li Type: Request for TAvailabilityNotification.
	   @li Fallible: Yes

	@param iSubscriptionOptions properties of the registration request.
    */
 	typedef TMessageSigAvailabilitySubscriptionOptions<ECFAvailabilityNotificationRegistration, TCFAvailabilityProvider::ERealmId> TAvailabilityNotificationRegistration;
	};

/**
Message interface for availability client nodes.
Nodes wishing to implement this interface must implement all message protocols in the interface.
*/
class TCFAvailabilityControlClient
	{
  private:
  	enum
 	{
 	ECFAvailabilityNotification		= 1,
	};
protected:

public:
    enum { ERealmId = 0x10285F3D }; //UID allocated on 4/6/08 from KUidNodeMessageRealms
    /**
	Response/Notification sent by an availability provider (usually a meta provider)
	to its availability subscribers registered for availability notifications.
	First TAvailabilityNotification message is an expected response.
	Subsequent TAvailabilityNotification messages are notifications.

	   @li Type: Response/Notification for TAvailabilityNotificationRegistration.
	   @li Fallible:  No

	@param iAvailabilityStatus availability score etc as per TAvailabilityNotificationRegistration.
	*/
 	typedef TMessageSigAvailabilityStatus<ECFAvailabilityNotification, TCFAvailabilityControlClient::ERealmId> TAvailabilityNotification;

	};

} //namespace ESock

#endif //SYMBIAN_NODEMESSAGES_AVAILABILITY_H