servicediscoveryandcontrol/pnp/inc/rpnpservicepublisher.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 11 Jun 2010 14:30:51 +0300
changeset 12 78fbd574edf4
parent 0 f5a58ecadc66
permissions -rw-r--r--
Revision: 201022 Kit: 2010123

// 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:
//


#ifndef __RPNPPSERVICEPUBLISHER_H__
#define __RPNPPSERVICEPUBLISHER_H__

#include <e32base.h>

class RControlChannel;
class CPnPServicePublisherBase;
class RPnPParameterBundle;


/**
A generic class which provides the functionality, to be implemented by a service point to service the remote clients.
@publishedPartner
@prototype
*/
class RPnPServicePublisher
   {
	public:
	/**
	Default constructor
	*/
	IMPORT_C RPnPServicePublisher ( );

	/**
	Resolves the access point.
	@param aTierID implementation UID. Identifies technology for which service discovery is requested.
	@return KErrNone if successful. Returns system wide error codes on failure
	*/
	IMPORT_C TInt Open (TUint aTierId );

	/**
	Publishes service notifications to remote clients. The technology specific service information
	is packed in aServiceInfo.
	Note that a service point will only publish a single device or service.Consequently only one
	parameter set must be sent in the bundle.Also once published,the service point must be closed
	before another publish is done.
	

	When the responses are received, MPnPObserver::OnPnPEventL is called for each response and calling clients
	must provide the implementation to handle the responses.

	In case of corrupted uris or value fields or low memory conditions, MPnPObserver::OnPnPError is called
	synchronously which must be handled by the client

	@param Parameter bundle containing service information.		
	*/
	IMPORT_C void Publish ( const RPnPParameterBundle& aServiceInfo );

	/**
	Sends service notification to remote clients who've subscribed to the service/device

	No responses are received in MPnPObserver::OnPnPEventL and MPnPObserver::OnPnPError is also not called
	@param Parameter bundle contains the technology specific information.	
	*/
	IMPORT_C void SendNotify ( const  RPnPParameterBundle & aServiceInfo );

	/**	  
	 It enables to send and receive messages.
	 @return KErrNone if successful. Returns system wide error codes on failure.	 
	 */
	IMPORT_C TInt InitiateControl ( RControlChannel& aControlChannel );

	/**
	Close technology specific session.
	*/
	IMPORT_C void Close ( );

	private:
		 CPnPServicePublisherBase* iPnPServicePublisherImpl;		 
    };

#endif /*__RPNPPSERVICEPUBLISHER_H__*/