contentmgmt/contentaccessfwfordrm/source/caf/Supplier.cpp
author andy simpson <andrews@symbian.org>
Fri, 20 Nov 2009 14:25:08 +0000
changeset 18 538fe06033d7
parent 8 35751d3474b7
permissions -rw-r--r--
merged 200945 drop

/*
* Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: 
*
*/


#include <caf/caftypes.h>
#include <caf/metadataarray.h>
#include <caf/supplier.h>
#include "resolver.h"
#include <caf/importfile.h>
#include "agentinfo.h"
#include <caf/agentinterface.h>

#ifndef REMOVE_CAF1
#include <caf/cafmimeheader.h>
#include <apmstd.h> 
#endif // REMOVE_CAF1

using namespace ContentAccess;

EXPORT_C CSupplier* CSupplier::NewLC()
	{
	CSupplier* self = new (ELeave) CSupplier();
	CleanupStack::PushL(self);
	self->ConstructL();
	return self;
	}

EXPORT_C CSupplier* CSupplier::NewL()
	{
	CSupplier* self = NewLC();
	CleanupStack::Pop(self);
	return self;
	}

CSupplier::CSupplier()
	{
	}

CSupplier::~CSupplier()
	{
	delete iAgentResolver;
	delete iOutputDirectory;
	}

void CSupplier::ConstructL()
	{
	iAgentResolver = CAgentResolver::NewL(EFalse);
	iOutputDirectory=HBufC::NewL(0);
	}

EXPORT_C TBool CSupplier::IsImportSupported(const TDesC8& aMimeType)
	{
	TBuf8 <KMaxDataTypeLength> mimeLowerCase;
	if(aMimeType.Length() > KMaxDataTypeLength)
		{
		return EFalse;
		}

	// Convert supplied mime type to lower case
	mimeLowerCase.Copy(aMimeType);
	mimeLowerCase.LowerCase();

	// Search for the mime type in the agents
	for(TInt i = 0; i < iAgentResolver->SupplierMimeTypes().Count(); i++)
		{
		if(mimeLowerCase.Compare(iAgentResolver->SupplierMimeTypes()[i]) == 0)
			{
			return ETrue;
			}
		}
	return EFalse;
	}

EXPORT_C void CSupplier::PrepareHTTPRequestHeaders(RStringPool& aStringPool, RHTTPHeaders& aRequestHeaders) const
	{
	// Ignore errors from any particular agent because we can't
	// let one agent ruin things for everyone else.
	TInt i = 0;
	TInt err = KErrNone;
	CAgentManager* manager = NULL;
	for(i = 0; i < iAgentResolver->AgentInfoCount(); i++)
		{
		TRAP(err, manager = &iAgentResolver->AgentInfo(i).AgentManagerL());
		if(err == KErrNone)
			{
			manager->PrepareHTTPRequestHeaders(aStringPool, aRequestHeaders);
			}	
		}
	}


EXPORT_C void CSupplier::SetOutputDirectoryL(const TDesC &aOutputDirectory)
	{
	HBufC *newOutputDirectory;

	// Make sure the path has a backslash at the end
	TInt pos = aOutputDirectory.LocateReverse(TChar(KPathDelimiter));
	if(pos + 1 != aOutputDirectory.Length())
		{
		// Append a trailing backslash
		newOutputDirectory=HBufC::NewL(aOutputDirectory.Length()+1);
		newOutputDirectory->Des().Append(aOutputDirectory);
		newOutputDirectory->Des().Append(TChar(KPathDelimiter));
		}
	else
		{
		newOutputDirectory=aOutputDirectory.AllocL();
		}

	// replace the existing output path
	delete iOutputDirectory;
	iOutputDirectory = newOutputDirectory;
	}

EXPORT_C CImportFile* CSupplier::ImportFileL(const TDesC8& aMimeType, const CMetaDataArray& aImportMetaData, const TDesC& aSuggestedFileName)
	{
	CAgentInfo& agentInfo = iAgentResolver->ResolveSupplierMimeL(aMimeType);

	TUid agentUid = agentInfo.Agent().ImplementationUid();
	
	// Create import object, agent creates output files
	CImportFile* import = CImportFile::NewL (agentUid, aMimeType, aImportMetaData, *iOutputDirectory, aSuggestedFileName);
	return import;
	}

EXPORT_C CImportFile* CSupplier::ImportFileL(const TDesC8& aMimeType, const CMetaDataArray& aImportMetaData)
	{
	// Create import object, client provides output files
	CAgentInfo& agentInfo = iAgentResolver->ResolveSupplierMimeL(aMimeType);
	
	TUid agentUid = agentInfo.Agent().ImplementationUid();
	
	// Create import object, agent creates output files
	CImportFile* import = CImportFile::NewL (agentUid, aMimeType, aImportMetaData);
	return import;
	}

#ifndef REMOVE_CAF1
EXPORT_C CImportFile *  CSupplier::ImportFileL (CCafMimeHeader &aMimeHeader, const TDesC &aSuggestedFileName)
	{
	TBuf8 <KMaxDataTypeLength> mimeType;

	// string constants used to fill in CMetaDataArray
	_LIT8(KContentType, "Content-Type");
	_LIT8(KContentLength, "Content-Length");
	_LIT8(KContentId, "Content-Id");
	_LIT8(KContentTransferEncoding, "Content-Tranfer-Encoding");
	_LIT8(KBoundary, "Content-Boundary");

	// create new CMetaDataArray to hold the information previously supplied in CCafMimeHeader
	CMetaDataArray *array = CMetaDataArray::NewLC();

	// Copy "standard mime data" to the CMetaDataArray
	if(aMimeHeader.StandardMimeData(EContentType).Length() != 0)
		{
		array->AddL(KContentType(),aMimeHeader.StandardMimeData(EContentType));
		mimeType.Append(aMimeHeader.StandardMimeData(EContentType));
		}
	if(aMimeHeader.StandardMimeData(EContentLength).Length() != 0)
		{
		array->AddL(KContentLength(),aMimeHeader.StandardMimeData(EContentLength));
		}
	if(aMimeHeader.StandardMimeData(EContentLength).Length() != 0)
		{
		array->AddL(KContentLength(),aMimeHeader.StandardMimeData(EContentLength));
		}
	if(aMimeHeader.StandardMimeData(EContentId).Length() != 0)
		{
		array->AddL(KContentId(),aMimeHeader.StandardMimeData(EContentId));
		}
	if(aMimeHeader.StandardMimeData(EContentTransferEncoding).Length() != 0)
		{
		array->AddL(KContentTransferEncoding(),aMimeHeader.StandardMimeData(EContentTransferEncoding));
		}
	if(aMimeHeader.StandardMimeData(EBoundary).Length() != 0)
		{
		array->AddL(KBoundary(),aMimeHeader.StandardMimeData(EBoundary));
		}

	// Add "non-standard" mime fields to CMetaDataArray
	TInt count = aMimeHeader.NonStandardMimeCount();
	for( TInt i = 0; i < count; i++)
		{
		array->AddL(aMimeHeader.NonStandardMimeField(i), aMimeHeader.NonStandardMimeData(i));
		}

	// Create new CImportFile object
	CImportFile *importFile = ImportFileL(mimeType, *array, aSuggestedFileName);
	CleanupStack::PopAndDestroy(array);
	return importFile;
	}

#endif // REMOVE_CAF1