sl@0: /* sl@0: * Copyright (c) 2003-2009 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of the License "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: sl@0: /** sl@0: @file sl@0: @internalComponent sl@0: @released sl@0: */ sl@0: sl@0: #ifndef __F32AGENTMANAGER_H__ sl@0: #define __F32AGENTMANAGER_H__ sl@0: sl@0: #include sl@0: sl@0: namespace ContentAccess sl@0: { sl@0: class CF32AgentUi; sl@0: sl@0: /** sl@0: * CF32AgentManager is an Ecom implementation of interface CAgentManager, sl@0: * and provides a fall-back agent for content which is not restricted sl@0: * (i.e. backward compatibility for clients switching to sl@0: * Content-Access-Framework APIs). sl@0: * sl@0: * Essentially, if the CA framework does not identify a piece of sl@0: * content as restricted (or rights managed) then this agent sl@0: * implementation is created to handle access to the content. As such the sl@0: * content will be treated as a plaintext file. sl@0: * sl@0: * @internalComponent sl@0: * @released sl@0: */ sl@0: class CF32AgentManager : public CAgentManager sl@0: { sl@0: public: sl@0: /** sl@0: * Standard C-Class NewL() constructor sl@0: */ sl@0: static CF32AgentManager* NewL(); sl@0: sl@0: ~CF32AgentManager(void); sl@0: sl@0: sl@0: public: sl@0: virtual TInt DeleteFile(const TDesC &aFileName); sl@0: virtual TInt CopyFile(const TDesC& aSource, const TDesC& aDestination); sl@0: virtual TInt CopyFile(RFile& aSource, const TDesC& aDestination); sl@0: virtual TInt RenameFile(const TDesC& aSource, const TDesC& aDestination); sl@0: virtual TInt MkDir(const TDesC& aPath); sl@0: virtual TInt MkDirAll(const TDesC& aPath); sl@0: virtual TInt RmDir(const TDesC& aPath); sl@0: virtual TInt GetDir(const TDesC& aName,TUint aEntryAttMask,TUint aEntrySortKey, CDir*& aEntryList) const; sl@0: virtual TInt GetDir(const TDesC& aName,TUint aEntryAttMask,TUint aEntrySortKey, CDir*& aEntryList,CDir*& aDirList) const; sl@0: virtual TInt GetDir(const TDesC& aName,const TUidType& aEntryUid,TUint aEntrySortKey, CDir*& aFileList) const; sl@0: virtual TInt GetAttribute(TInt aAttribute, TInt& aValue, const TVirtualPathPtr& aVirtualPath); sl@0: virtual TInt GetAttributeSet(RAttributeSet& aAttributeSet, const TVirtualPathPtr& aVirtualPath); sl@0: virtual TInt GetStringAttributeSet(RStringAttributeSet& aAttributeSet, const TVirtualPathPtr& aVirtualPath); sl@0: virtual TInt GetStringAttribute(TInt aAttribute, TDes& aValue, const TVirtualPathPtr& aVirtualPath); sl@0: virtual TInt GetAttribute(TInt aAttribute, TInt& aValue, RFile& aFile, const TDesC& aUniqueId); sl@0: virtual TInt GetAttributeSet(RAttributeSet& aAttributeSet, RFile& aFile, const TDesC& aUniqueId); sl@0: virtual TInt GetStringAttributeSet(RStringAttributeSet& aStringAttributeSet, RFile& aFile, const TDesC& aUniqueId); sl@0: virtual TInt GetStringAttribute(TInt aAttribute, TDes& aValue, RFile& aFile, const TDesC& aUniqueId); sl@0: virtual void NotifyStatusChange(const TDesC& aURI, TEventMask aMask, TRequestStatus& aStatus); sl@0: virtual TInt CancelNotifyStatusChange(const TDesC& aURI, TRequestStatus& aStatus); sl@0: virtual TInt SetProperty(TAgentProperty aProperty, TInt aValue); sl@0: virtual void DisplayInfoL(TDisplayInfo aInfo, const TVirtualPathPtr& aVirtualPath); sl@0: virtual void DisplayInfoL(TDisplayInfo aInfo, RFile& aFile, const TDesC& aUniqueId); sl@0: virtual TBool IsRecognizedL(const TDesC& aURI, TContentShareMode aShareMode) const; sl@0: virtual TBool IsRecognizedL(RFile& aFile) const; sl@0: virtual TBool RecognizeFileL(const TDesC& aFileName, const TDesC8& aBuffer, TDes8& aFileMimeType, TDes8& aContentMimeType) const; sl@0: virtual TInt AgentSpecificCommand(TInt aCommand, const TDesC8& aInputBuffer, TDes8& aOutputBuffer); sl@0: virtual void AgentSpecificCommand(TInt aCommand, const TDesC8& aInputBuffer, TDes8& aOutputBuffer, TRequestStatus& aStatus); sl@0: virtual void DisplayManagementInfoL(); sl@0: virtual void PrepareHTTPRequestHeaders(RStringPool& aStringPool, RHTTPHeaders& aRequestHeaders) const; sl@0: virtual TInt RenameDir(const TDesC& aOldName, const TDesC& aNewName); sl@0: sl@0: #ifdef SYMBIAN_ENABLE_SDP_WMDRM_SUPPORT sl@0: virtual TBool IsRecognizedL(const TDesC8& aHeaderData) const; sl@0: virtual TBool RecognizeContentL(const TDesC8& aHeaderData, TDes8& aFileMimeType, TDes8& aContentMimeType) const; sl@0: virtual TInt GetAttribute(const TDesC8& aHeaderData, TInt aAttribute, TInt& aValue); sl@0: virtual TInt GetAttributeSet(const TDesC8& aHeaderData, RAttributeSet& aAttributeSet); sl@0: virtual TInt GetStringAttributeSet(const TDesC8& aHeaderData, RStringAttributeSet& aAttributeSet); sl@0: virtual TInt GetStringAttribute(const TDesC8& aHeaderData, TInt aAttribute, TDes& aValue); sl@0: #endif // SYMBIAN_ENABLE_SDP_WMDRM_SUPPORT sl@0: sl@0: protected: sl@0: CF32AgentManager(); sl@0: sl@0: private: sl@0: /** sl@0: * Second stage in two-phase create. Parameters may also be sl@0: * passed to a new Agent implementation. sl@0: * sl@0: * @param aParams A parameter structure containing sl@0: * any necessary agent parameters. sl@0: */ sl@0: void ConstructL(); sl@0: sl@0: CF32AgentUi& AgentUiL(); sl@0: sl@0: private: sl@0: RFs iFs; sl@0: CFileMan *iFileMan; sl@0: CF32AgentUi *iAgentUi; sl@0: }; sl@0: } // namespace ContentAccess sl@0: #endif // __F32AGENTMANAGER_H__