sl@0: // Copyright (c) 2006-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: //
"KMinInt=Not Recognized"
to "KMaxInt=Certain"
).
sl@0: // The implementation of DRM presents a problem when determinining the MIME type. Usually, a DRM
sl@0: // file stores one or more content objects. For example, an OMA file with
sl@0: // MIME type application/vnd.oma.drm.content
might store an image file with
sl@0: // MIME type image/jpeg
. Apparc expects only one MIME type to be returned, not two.
sl@0: // The CAF recognizer RECCAF.DLL
uses the
sl@0: // to determine whether or not a file is recognized by the content access framework and
sl@0: // if so retrieves these two MIME types.
sl@0: // The mapping of these two MIME types returned by CAF to a single MIME type follows these rules:
sl@0: // File MIME Type | Content MIME Type | Apparc MIME Type |
---|---|---|
Present | Present | x-caf-ContentMimeType |
Present | Not Present | FileMimeType |
Present | application/x-caf | application/x-caf |
CApaDataRecognizerType::DoRecognizeL()
sl@0: // implementations. These two parameters can be passed to the ContentAccess::CAgentResolver::DoRecognize()
sl@0: // function to determine whether one of the Content Access Agents recognizes the file.
sl@0: // CApaDataRecognizer::DoRecognize(TDesC& aFilename, TDesC8& aBuffer)
sl@0: // TBool recognized;
sl@0: // CAgentResolver *resolver = CAgentResolver::NewL();
sl@0: // recognized = resolver->DoRecognize(filename, buffer, fileMimeType, contentMimeType);
sl@0: // ContentAccess::CAgentResolver::DoRecognize()
passes the filename and buffer to each of the
sl@0: // agents in turn. The agents perform the recognition, and the result is returned
sl@0: // as either \c ETrue if the file was recognized, or \c EFalse if it was not. If the file
sl@0: // is recognized, the \c fileMimeType and \c contentMimeType parameters are populated
sl@0: // with the correct MIME types.
sl@0: // The recognition is distributed to the agents because they are able to recognize
sl@0: // a file belonging to their agent. They are also able to examine the contents to
sl@0: // work out the content MIME type. This allows one generic CAF recognizer to be used
sl@0: // for all the agents implemented with the content access framework.
sl@0: // CApaCafRecognizer::SupportedDataTypeL()
fuction.
sl@0: // image/jpeg
sl@0: // image/gif
sl@0: // text/plain
sl@0: // text/html
sl@0: // ... etc
sl@0: // If this file is replaced (to support new content types), the recognizer
sl@0: // will only implement the changes during the next power on. Similarly if a new agent
sl@0: // is added, the recognizer will only rebuild its list of agents after the next power on.
sl@0: // AppName_reg.rss
) to include the new CAF MIME types. For example, in the past an image
sl@0: // viewer may have only included image/jpeg
in the list of MIME types it could open.
sl@0: // If the application is updated to use the Content Access Framework, it should support
sl@0: // image/jpeg
and x-caf-image/jpeg
in order to support
sl@0: // unprotected and protected content respectively. See the registration file examples below.
sl@0: // All file operations should be conducted through the CAF framework, so that the
sl@0: // application will not need to know anything about a specific DRM scheme.
sl@0: // Registration file that doesn't use CAF
sl@0: // datatype_list =
sl@0: // DATATYPE { priority= EDataTypePriorityHigh ; type="image/jpeg"; },
sl@0: // Registration file that does use CAF
sl@0: // datatype_list =
sl@0: // DATATYPE { priority= EDataTypePriorityHigh ; type="image/jpeg"; },
sl@0: // DATATYPE { priority= EDataTypePriorityHigh ; type="x-caf-image/jpeg"; },
sl@0: // ContentAccess::CAgentResolver::DoRecognize()
function @ref DoRecognize "(see below)"
sl@0: @li Users and applications will be interested in the MIME type of the content within a file not the packaging. CAF abstracts the packaging.
sl@0: @li If the content is recognized with only the MIME type of the content within the file, it would confuse legacy applications who thought the entire file was that MIME type
sl@0: @li Prefixing the content type with "x-caf-"
shows it is a file that can be opened by CAF to read that content type without confusing legacy applications
sl@0: @li A file that needs to be passed through the supplier interface before it can be used will just be recognized as the file MIME type, the content type is irrelevant before the supply operation.
sl@0: @li A file containing many content objects should just be recognized as application/x-caf
since the packaging of the archive is irrelevant. CAF abstracts the packaging.
sl@0: @note The concept of "confidence" has also been eliminated for the files within the Content
sl@0: @section DoRecognize How to determine the file and content MIME types of a DRM file
sl@0: @code
sl@0: @endcode
sl@0: @image html recognizer.gif
sl@0: @section ConfigFile CAF Recognizer Configuration File
sl@0: @code
sl@0: @endcode
sl@0: @section AppRegFiles Application Registration files
sl@0: @code
sl@0: @endcode
sl@0: @code
sl@0: @endcode
sl@0: */