First public contribution.
2 * Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of the License "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
19 #include <caf/caftypes.h>
20 #include <caf/metadataarray.h>
21 #include <caf/supplier.h>
23 #include <caf/importfile.h>
24 #include "agentinfo.h"
25 #include <caf/agentinterface.h>
28 #include <caf/cafmimeheader.h>
32 using namespace ContentAccess;
34 EXPORT_C CSupplier* CSupplier::NewLC()
36 CSupplier* self = new (ELeave) CSupplier();
37 CleanupStack::PushL(self);
42 EXPORT_C CSupplier* CSupplier::NewL()
44 CSupplier* self = NewLC();
45 CleanupStack::Pop(self);
49 CSupplier::CSupplier()
53 CSupplier::~CSupplier()
55 delete iAgentResolver;
56 delete iOutputDirectory;
59 void CSupplier::ConstructL()
61 iAgentResolver = CAgentResolver::NewL(EFalse);
62 iOutputDirectory=HBufC::NewL(0);
65 EXPORT_C TBool CSupplier::IsImportSupported(const TDesC8& aMimeType)
67 TBuf8 <KMaxDataTypeLength> mimeLowerCase;
68 if(aMimeType.Length() > KMaxDataTypeLength)
73 // Convert supplied mime type to lower case
74 mimeLowerCase.Copy(aMimeType);
75 mimeLowerCase.LowerCase();
77 // Search for the mime type in the agents
78 for(TInt i = 0; i < iAgentResolver->SupplierMimeTypes().Count(); i++)
80 if(mimeLowerCase.Compare(iAgentResolver->SupplierMimeTypes()[i]) == 0)
88 EXPORT_C void CSupplier::PrepareHTTPRequestHeaders(RStringPool& aStringPool, RHTTPHeaders& aRequestHeaders) const
90 // Ignore errors from any particular agent because we can't
91 // let one agent ruin things for everyone else.
94 CAgentManager* manager = NULL;
95 for(i = 0; i < iAgentResolver->AgentInfoCount(); i++)
97 TRAP(err, manager = &iAgentResolver->AgentInfo(i).AgentManagerL());
100 manager->PrepareHTTPRequestHeaders(aStringPool, aRequestHeaders);
106 EXPORT_C void CSupplier::SetOutputDirectoryL(const TDesC &aOutputDirectory)
108 HBufC *newOutputDirectory;
110 // Make sure the path has a backslash at the end
111 TInt pos = aOutputDirectory.LocateReverse(TChar(KPathDelimiter));
112 if(pos + 1 != aOutputDirectory.Length())
114 // Append a trailing backslash
115 newOutputDirectory=HBufC::NewL(aOutputDirectory.Length()+1);
116 newOutputDirectory->Des().Append(aOutputDirectory);
117 newOutputDirectory->Des().Append(TChar(KPathDelimiter));
121 newOutputDirectory=aOutputDirectory.AllocL();
124 // replace the existing output path
125 delete iOutputDirectory;
126 iOutputDirectory = newOutputDirectory;
129 EXPORT_C CImportFile* CSupplier::ImportFileL(const TDesC8& aMimeType, const CMetaDataArray& aImportMetaData, const TDesC& aSuggestedFileName)
131 CAgentInfo& agentInfo = iAgentResolver->ResolveSupplierMimeL(aMimeType);
133 TUid agentUid = agentInfo.Agent().ImplementationUid();
135 // Create import object, agent creates output files
136 CImportFile* import = CImportFile::NewL (agentUid, aMimeType, aImportMetaData, *iOutputDirectory, aSuggestedFileName);
140 EXPORT_C CImportFile* CSupplier::ImportFileL(const TDesC8& aMimeType, const CMetaDataArray& aImportMetaData)
142 // Create import object, client provides output files
143 CAgentInfo& agentInfo = iAgentResolver->ResolveSupplierMimeL(aMimeType);
145 TUid agentUid = agentInfo.Agent().ImplementationUid();
147 // Create import object, agent creates output files
148 CImportFile* import = CImportFile::NewL (agentUid, aMimeType, aImportMetaData);
153 EXPORT_C CImportFile * CSupplier::ImportFileL (CCafMimeHeader &aMimeHeader, const TDesC &aSuggestedFileName)
155 TBuf8 <KMaxDataTypeLength> mimeType;
157 // string constants used to fill in CMetaDataArray
158 _LIT8(KContentType, "Content-Type");
159 _LIT8(KContentLength, "Content-Length");
160 _LIT8(KContentId, "Content-Id");
161 _LIT8(KContentTransferEncoding, "Content-Tranfer-Encoding");
162 _LIT8(KBoundary, "Content-Boundary");
164 // create new CMetaDataArray to hold the information previously supplied in CCafMimeHeader
165 CMetaDataArray *array = CMetaDataArray::NewLC();
167 // Copy "standard mime data" to the CMetaDataArray
168 if(aMimeHeader.StandardMimeData(EContentType).Length() != 0)
170 array->AddL(KContentType(),aMimeHeader.StandardMimeData(EContentType));
171 mimeType.Append(aMimeHeader.StandardMimeData(EContentType));
173 if(aMimeHeader.StandardMimeData(EContentLength).Length() != 0)
175 array->AddL(KContentLength(),aMimeHeader.StandardMimeData(EContentLength));
177 if(aMimeHeader.StandardMimeData(EContentLength).Length() != 0)
179 array->AddL(KContentLength(),aMimeHeader.StandardMimeData(EContentLength));
181 if(aMimeHeader.StandardMimeData(EContentId).Length() != 0)
183 array->AddL(KContentId(),aMimeHeader.StandardMimeData(EContentId));
185 if(aMimeHeader.StandardMimeData(EContentTransferEncoding).Length() != 0)
187 array->AddL(KContentTransferEncoding(),aMimeHeader.StandardMimeData(EContentTransferEncoding));
189 if(aMimeHeader.StandardMimeData(EBoundary).Length() != 0)
191 array->AddL(KBoundary(),aMimeHeader.StandardMimeData(EBoundary));
194 // Add "non-standard" mime fields to CMetaDataArray
195 TInt count = aMimeHeader.NonStandardMimeCount();
196 for( TInt i = 0; i < count; i++)
198 array->AddL(aMimeHeader.NonStandardMimeField(i), aMimeHeader.NonStandardMimeData(i));
201 // Create new CImportFile object
202 CImportFile *importFile = ImportFileL(mimeType, *array, aSuggestedFileName);
203 CleanupStack::PopAndDestroy(array);
207 #endif // REMOVE_CAF1