datacommsserver/esockserver/test/providers/dummy/src/dummypr_mcprpubsubsubscriber.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 18 Jan 2010 21:26:35 +0200
changeset 2 dee179edb159
parent 1 21d2ab05f085
child 13 0b0e9fce0b58
permissions -rw-r--r--
Revision: 201003 Kit: 201003

// Copyright (c) 2007-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
 @internalTechnology
 @prototype
*/


#include "dummypr_mcprpubsubsubscriber.h"

#include <comms-infras/ss_log.h>
#include <comms-infras/coremcpractivities.h>
#include <comms-infras/ss_nodemessages_availability.h>

// Panic category for "absolutely impossible!" vanilla ASSERT()-type panics from this module
// (if it could happen through user error then you should give it an explicit, documented, category + code)
_LIT(KSpecAssert_DummyPrStopSubsc, "DummyPrStopSubsc");


#define KDummyMCprTag KESockMetaConnectionTag
_LIT8(KDummyMCprSubTag, "dummymcpr");


using namespace Messages;
using namespace ESock;

CMCPrPubSubSubscriber* CMCPrPubSubSubscriber::NewL(const ESock::CMetaConnectionProviderBase& aProvBase, TUint aStopCode)
	{
	CMCPrPubSubSubscriber* self = new (ELeave) CMCPrPubSubSubscriber(aProvBase,aStopCode);
	CleanupStack::PushL(self);
	self->StartL();
	CleanupStack::Pop(self);
	return self;
	}

CMCPrPubSubSubscriber::CMCPrPubSubSubscriber(const ESock::CMetaConnectionProviderBase& aProvBase, TUint aStopCode)
:	CActive(EPriorityNormal),
	iNode(aProvBase),
	iStopCode(aStopCode)
	{
	}

void CMCPrPubSubSubscriber::StartAvailabilityMonitoringL(const Messages::TNodeCtxId& aAvailabilityActivity)
    {
    iAvailabilityActivity = aAvailabilityActivity;
    TInt score = TAvailabilityStatus::EUnknownAvailabilityScore;
    
    TInt result = iProperty.Attach(TUid::Uid(EAvailabilityTestingPubSubUid), iNode.ProviderInfo().APId());
    if(result != KErrNone)
        {
        User::LeaveIfError(iProperty.Define(TUid::Uid(EAvailabilityTestingPubSubUid), iNode.ProviderInfo().APId(), RProperty::EInt));
        User::LeaveIfError(iProperty.Attach(TUid::Uid(EAvailabilityTestingPubSubUid), iNode.ProviderInfo().APId()));
        }

    iProperty.Subscribe(iStatus);
    SetActive();
    iProperty.Get(score); //If Get() is unsuccessful score must not be modified!
    
    if (score != TAvailabilityStatus::EUnknownAvailabilityScore)
        {
        //Send the intial availability status.
        TAvailabilityStatus status(score);
        RClientInterface::OpenPostMessageClose(NodeId(), iAvailabilityActivity,
                TCFAvailabilityControlClient::TAvailabilityNotification(status).CRef());
        }
    }

void CMCPrPubSubSubscriber::CancelAvailabilityMonitoring()
    {
    iAvailabilityActivity = Messages::TNodeCtxId::NullId();
    }

void CMCPrPubSubSubscriber::StartL()
	{
	__CFLOG_VAR((KDummyMCprTag, KDummyMCprSubTag, _L8("CMCPrPubSubSubscriber::StartL")));
	CActiveScheduler::Add(this);
	}

void CMCPrPubSubSubscriber::RunL()
	{
	__CFLOG_VAR((KDummyMCprTag, KDummyMCprSubTag, _L8("CMCPrPubSubSubscriber::RunL")));
	User::LeaveIfError(iStatus.Int());

	// resubscribe immediately
	iProperty.Subscribe(iStatus);
	SetActive();

    // then process
	TInt value;
	User::LeaveIfError(iProperty.Get(value));
	__CFLOG_VAR((KDummyMCprTag, KDummyMCprSubTag, _L8("CMCPrPubSubSubscriber subscribed value now %d"),value));

    ASSERT(!iAvailabilityActivity.IsNull()); //maybe a bit defensive, but this is test code after all. The test changes availability when nobody is listenning; Surely test is wrong?
    RClientInterface::OpenPostMessageClose(Id(), iAvailabilityActivity,
        TCFAvailabilityControlClient::TAvailabilityNotification(value).CRef());
	}

TInt CMCPrPubSubSubscriber::RunError(TInt /*aError*/)
	{
	//path uncovered.
	__ASSERT_DEBUG(EFalse, User::Panic(KSpecAssert_DummyPrStopSubsc, 0));
	return 0;
	}

void CMCPrPubSubSubscriber::DoCancel()
	{
	iProperty.Cancel();
	}

/*virtual*/ CMCPrPubSubSubscriber::~CMCPrPubSubSubscriber()
	{
	this->Cancel(); // object must be stoppable by destcruction due to cleanup restrictions
	iProperty.Close();
	}