commands/iap/iap.cpp
author Tom Sutcliffe <thomas.sutcliffe@accenture.com>
Wed, 25 Aug 2010 18:03:34 +0100
changeset 47 e7ccdc7f7dbe
parent 0 7f656887cf89
permissions -rw-r--r--
tidyup

// iap.cpp
// 
// Copyright (c) 2008 - 2010 Accenture. All rights reserved.
// This component and the accompanying materials are made available
// under the terms of the "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:
// Accenture - Initial contribution
//

#include <commsdattypesv1_1.h>
#include <fshell/ioutils.h>

using namespace CommsDat;
using namespace IoUtils;

class CCmdIap : public CCommandBase
	{
public:
	static CCommandBase* NewLC();
	~CCmdIap();
private: // From CCommandBase.
	virtual const TDesC& Name() const;
	virtual void DoRunL();
	virtual void OptionsL(RCommandOptionList& aOptions);
private:
	CCmdIap();
	void ListIapsL();
	void AddWinsockprtIapL();
	void DoAddWinsockprtIapL(CMDBSession& aDbSession);
private:
	TBool iAddWinsockprtIap;
	};

	
CCommandBase* CCmdIap::NewLC()
	{
	CCmdIap* self = new (ELeave) CCmdIap();
	CleanupStack::PushL(self);
	self->BaseConstructL();
	return self;
	}

CCmdIap::~CCmdIap()
	{
	}
	
CCmdIap::CCmdIap()
	{
	}

const TDesC& CCmdIap::Name() const
	{
	_LIT(KName, "iap");
	return KName;
	}

void CCmdIap::DoRunL()
	{
	if (iAddWinsockprtIap)
		{
		AddWinsockprtIapL();
		}
	else
		{
		ListIapsL();
		}
	}

void CCmdIap::ListIapsL()
	{
	CMDBSession* session = CMDBSession::NewL(CMDBSession::LatestVersion());
	CleanupStack::PushL(session);
	CMDBRecordSet<CCDIAPRecord>* iapRecordSet = new (ELeave) CMDBRecordSet<CCDIAPRecord>(KCDTIdIAPRecord);
	CleanupStack::PushL(iapRecordSet);
	iapRecordSet->LoadL(*session);
	const TInt maxCount = iapRecordSet->iRecords.Count();
	if (maxCount == 0)
		{
		Printf(_L("No IAP records present.\r\n"));
		}
	else
		{
		IoUtils::CTextFormatter* formatter = CTextFormatter::NewLC(Stdout());
		IoUtils::CTextBuffer* buf = IoUtils::CTextBuffer::NewLC(0x100);
		buf->AppendFormatL(_L("Name\tType\tIdentifier\r\n"));
		for (TInt count = 0 ; count < maxCount ; count++)
			{
			// print to stdout details on this particular IAP record
			CCDIAPRecord& rec = *((*iapRecordSet)[count]);
			TPtrC ptr(static_cast<const TDesC&>(rec.iRecordName));
			TPtrC iapServiceType(rec.iServiceType);
			buf->AppendFormatL(_L("%S\t%S\t%d\r\n"), &ptr, &iapServiceType, rec.RecordId());
			}
		formatter->TabulateL(0, 2, buf->Descriptor());
		Write(formatter->Descriptor());
		CleanupStack::PopAndDestroy(2, formatter);
		}
	CleanupStack::PopAndDestroy(2); // iaprecordSet, session
	}

void CCmdIap::OptionsL(RCommandOptionList& aOptions)
	{
	_LIT(KOptWinsockprt, "winsockprt");
	aOptions.AppendBoolL(iAddWinsockprtIap, KOptWinsockprt);
	}

void CCmdIap::AddWinsockprtIapL()
	{
	CMDBSession* session = CMDBSession::NewL(CMDBSession::LatestVersion());
	CleanupStack::PushL(session);
	session->OpenTransactionL();

	TRAPD(err, DoAddWinsockprtIapL(*session));

	if (err == KErrNone)
		{
		session->CommitTransactionL();
		}
	else
		{
		PrintError(err, _L("Unable to add WinSockPrt IAP, rolling back..."));
		session->RollbackTransactionL();
		}

	CleanupStack::PopAndDestroy(session);
	}

void CCmdIap::DoAddWinsockprtIapL(CMDBSession& aDbSession)
	{
	_LIT(KIapName, "WinSockPrt");
	_LIT(KIspType, "DialOutISP");
	_LIT(KNifName, "nullnif");
	_LIT(KAgentName, "nullagt.agt");
	_LIT(KBearerType, "ModemBearer");
	_LIT(KDescription, "A dummy IAP for use with WinSockPrt.");
	_LIT(KNetwork, "ip");

	CCDIAPRecord* iapRecord = static_cast<CCDIAPRecord*>(CCDRecordBase::RecordFactoryL(KCDTIdIAPRecord));
	CleanupStack::PushL(iapRecord);
	iapRecord->iRecordName.SetL(KIapName);
	if (iapRecord->FindL(aDbSession))
		{
		iapRecord->DeleteL(aDbSession);
		}

	CCDDialOutISPRecord* ispRecord = static_cast<CCDDialOutISPRecord*>(CCDRecordBase::RecordFactoryL(KCDTIdDialOutISPRecord));
	CleanupStack::PushL(ispRecord);
	ispRecord->iRecordName.SetL(KIapName);
	if (ispRecord->FindL(aDbSession))
		{
		ispRecord->DeleteL(aDbSession);
		}
	ispRecord->SetRecordId(KCDNewRecordRequest);
	ispRecord->iDescription.SetL(KDescription);
	ispRecord->iUseLoginScript = EFalse;
	ispRecord->iPromptForLogin = EFalse;
	ispRecord->iIfNetworks.SetL(KNetwork);
	ispRecord->StoreL(aDbSession);

	CCDModemBearerRecord* bearerRecord = static_cast<CCDModemBearerRecord*>(CCDRecordBase::RecordFactoryL(KCDTIdModemBearerRecord));
	CleanupStack::PushL(bearerRecord);
	bearerRecord->iRecordName.SetL(KIapName);
	if (bearerRecord->FindL(aDbSession))
		{
		bearerRecord->DeleteL(aDbSession);
		}
	bearerRecord->SetRecordId(KCDNewRecordRequest);
	bearerRecord->iBearerAgent.SetL(KAgentName);
	bearerRecord->iNifName.SetL(KNifName);
	bearerRecord->StoreL(aDbSession);

	CCDNetworkRecord* networkRecord = static_cast<CCDNetworkRecord*>(CCDRecordBase::RecordFactoryL(KCDTIdNetworkRecord));
	CleanupStack::PushL(networkRecord);
	networkRecord->iRecordName.SetL(KIapName);
	if (networkRecord->FindL(aDbSession))
		{
		networkRecord->DeleteL(aDbSession);
		}
	networkRecord->SetRecordId(KCDNewRecordRequest);
	networkRecord->StoreL(aDbSession);

	iapRecord->SetRecordId(KCDNewRecordRequest);
	iapRecord->iRecordName.SetL(KIapName);
	iapRecord->iServiceType.SetL(KIspType);
	iapRecord->iService.SetL(ispRecord->RecordId());
	iapRecord->iBearerType.SetL(KBearerType);
	iapRecord->iBearer.SetL(bearerRecord->RecordId());
	iapRecord->iNetwork.SetL(networkRecord->RecordId());
	iapRecord->StoreL(aDbSession);

	CleanupStack::PopAndDestroy(4, iapRecord);
	}

EXE_BOILER_PLATE(CCmdIap)