commands/iap/iap.cpp
changeset 0 7f656887cf89
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/commands/iap/iap.cpp	Wed Jun 23 15:52:26 2010 +0100
@@ -0,0 +1,197 @@
+// 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)