contentmgmt/contentaccessfwfordrm/source/caf/agentinfo.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 31 Aug 2010 17:00:08 +0300
branchRCL_3
changeset 61 641f389e9157
parent 8 35751d3474b7
permissions -rw-r--r--
Revision: 201035 Kit: 201035

/*
* 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: 
*
*/


/**
 @file
 @internalComponent
 @released
*/


#ifndef __AGENTINFO_H__
#define __AGENTINFO_H__

#include <e32base.h>

class CImplementationInformation;

#include <caf/agent.h>

namespace ContentAccess
	{
	class CAgentFactory;
	class CAgentManager;

	/**
	 Holds information about a Content Access Agent implementation. 
	
	The metadata is supplied in the agents resource file so the information can be 
	obtained without the need to construct the agent.
	
	The AgentFactoryL() function is used by other CAF classes to access the 
	agent's CAgentFactory implementation.
	
	@internalComponent
	@released
	*/
	class CAgentInfo : public CBase
		{
	public:
		/** 
		Constructs a new CAgentInfo object from an ECOM CImplementationInfo.
		
		@param aImplInfo	An ECOM Implementation from REComSession::ListImplementationsL().
		@return				A new instance of a CAgentInfo object.
		*/
		static CAgentInfo* NewLC(const CImplementationInformation& aImplInfo);

		virtual ~CAgentInfo();

		/** 
		Determines whether this agent recognizes the supplier MIME type.
		
		@param aSupplierMime	The supplier MIME type to check.
		@return					ETrue, if the MIME type is a supported supplier MIME type.
		*/
		TBool IsSupportedSupplier(const TDesC8& aSupplierMime) const;

		/** 
		Determines whether this agent recognizes the consumer MIME type.
		
		@note Scheduled to be removed from the CAF API
		recognizer uses MIME types based upon the content type, not the mime type
		of the file itself. There will be no Consumer MIME types, only modified 
		content types.
		 
		@param aConsumerMime	The consumer mime type to check.
		@return					ETrue, if the MIME type is a supported consumer MIME type.
		*/
		TBool IsSupportedConsumer(const TDesC8& aConsumerMime) const;

		/** 
		* Exposes the array of supplier MIME types supported by this agent.
		*
		* @return	The array of supplier MIME types.
		*/
		const RPointerArray<HBufC8>& SupplierMimeTypes() const;

		/** 
		Exposes the array of consumer MIME types supported by this agent.
		
		@note Scheduled to be removed from the CAF API
		recognizer uses MIME types based upon the content type, not the 
		mime type of the file itself. There will be no Consumer mime types, 
		only modified content types.
		
		@return 	A reference to the array of consumer mime types.
		*/
		const RPointerArray<HBufC8>& ConsumerMimeTypes() const;
		
		/** 
		* Gets the preferred buffer size for this agent to recognize 
		* DRM files with the ContentAccess::CAgentResolver::DoRecognize() function.
		*
		* @return	The preferred buffer size.
		*/
		TInt PreferredBufferSize() const;

		/** The private server directory managed by this agent 

		This function returns the directory under C:\\private\\ used by this 
		agent. This is specified in the agents resource file in the opaque_data
		field. 
		
		If the agent does not use a private directory the return value will be
		KNullDesC()

		@return The directory name
		*/
		const TDesC& PrivateDirectoryName() const;
		
		/** The agent 
		
		@return A reference to this agent
		*/
		TAgent& Agent(); 

		/**
		Accessor for agent factory.
		
		Allows the factory to be constructed once and used many times. 
		DOES NOT transfer ownership of the CAgentFactory to the caller. 

		@return The CAgentFactory for this particular agent
		*/
		CAgentFactory& AgentFactoryL();

		/**
		Accessor to the agent manager. 
		
		The agent manager is stateless and this method allows it to be 
		constructed once and used several times. DOES NOT transfer ownership 
		of the CAgentManager to the caller. 

		@return The CAgentManager for this particular agent
		*/
		CAgentManager& AgentManagerL();


	private:
		CAgentInfo();
		void ConstructL(const CImplementationInformation& aImplInfo);

		// Helper function to parse MIME types of the form:
		// <mime1>,<mime2>,<mime3>
		void ParseMimeTypesL(const TDesC8& aBuf, RPointerArray<HBufC8>& aMimeTypes);

		// Helper to add descriptor to RPointerArray
		void AddToArrayL(const TDesC8& aElement, RPointerArray<HBufC8>& aArray);

	private:
		TInt iPreferredBufferSize;
		RPointerArray<HBufC8> iSupplierMimeTypes;
		RPointerArray<HBufC8> iConsumerMimeTypes;

		CAgentFactory* iAgentFactory;
		CAgentManager* iAgentManager;

		// Holds the agent name and Implementation UID
		TAgent iAgent;
		
		// Agent private directory is a SID
		TBuf <KMaxSIDLength> iPrivateDirectoryName;
		};
	}

#endif