/**************************************************************
 * 
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 * 
 *   http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 * 
 *************************************************************/



#ifndef ODMA_PROVIDER_HXX
#define ODMA_PROVIDER_HXX

#include <ucbhelper/providerhelper.hxx>
#include "odma_lib.hxx"

#include "rtl/ref.hxx"

#include <map>
#include "odma_contentprops.hxx"

namespace odma {

//=========================================================================

// UNO service name for the provider. This name will be used by the UCB to
// create instances of the provider.
#define ODMA_CONTENT_PROVIDER_SERVICE_NAME \
				"com.sun.star.ucb.OdmaContentProvider"
//	#define ODMA_CONTENT_PROVIDER_SERVICE_NAME_LENGTH	34

// URL scheme. This is the scheme the provider will be able to create
// contents for. The UCB will select the provider ( i.e. in order to create
// contents ) according to this scheme.
#define ODMA_URL_ODMAID			"::ODMA"
#define ODMA_URL_SCHEME			"vnd.sun.star.odma"
#define ODMA_URL_SCHEME_SHORT	"odma"
#define ODMA_URL_SHORT			":"
#define ODMA_URL_SHORT_LGTH		5
#define ODMA_URL_LGTH			18
#define ODMA_URL_ODMAID_LGTH	6

// UCB Content Type.
#define ODMA_CONTENT_TYPE 		"application/" ODMA_URL_SCHEME "-content"
#define ODMA_ODMA_REGNAME		"sodma"
#define ODM_NAME_MAX			64		// Max length of a name document including
										// the terminating NULL character.

//=========================================================================
class ContentProperties;
class ContentProvider : public ::ucbhelper::ContentProviderImplHelper
{
	typedef ::std::map< ::rtl::OString, ::rtl::Reference<ContentProperties> > ContentsMap;
	ContentsMap		 m_aContents;  // contains all ContentProperties
	static ODMHANDLE m_aOdmHandle; // the one and only ODMA handle to our DMS

	/** fillDocumentProperties fills the given _rProp with ODMA properties
		@param	_rProp	the ContentProperties
	*/
	void fillDocumentProperties(const ::rtl::Reference<ContentProperties>& _rProp);

	/**
	*/
	::rtl::Reference<ContentProperties> getContentProperty(const ::rtl::OUString& _sName,
													   const ContentPropertiesMemberFunctor& _aFunctor) const;
public:
	ContentProvider( const ::com::sun::star::uno::Reference<
						::com::sun::star::lang::XMultiServiceFactory >& rSMgr );
	virtual ~ContentProvider();

	// XInterface
	XINTERFACE_DECL()

	// XTypeProvider
	XTYPEPROVIDER_DECL()

    // XServiceInfo
	XSERVICEINFO_DECL()

	// XContentProvider
	virtual ::com::sun::star::uno::Reference<
				::com::sun::star::ucb::XContent > SAL_CALL
	queryContent( const ::com::sun::star::uno::Reference<
					::com::sun::star::ucb::XContentIdentifier >& Identifier )
		throw( ::com::sun::star::ucb::IllegalIdentifierException,
			   ::com::sun::star::uno::RuntimeException );

	//////////////////////////////////////////////////////////////////////
	// Additional interfaces
	//////////////////////////////////////////////////////////////////////

	//////////////////////////////////////////////////////////////////////
	// Non-interface methods.
	//////////////////////////////////////////////////////////////////////
	static ODMHANDLE getHandle(); 

	/** append add an entry to the internal map
		@param	_rProp	the content properties
	*/
	void append(const ::rtl::Reference<ContentProperties>& _rProp);
	
	/** closeDocument closes the document
		@param	_sDocumentId	the id of the document
	*/
	void closeDocument(const ::rtl::OString& _sDocumentId);
	
	/** saveDocument saves the document in DMS 
		@param	_sDocumentId	the id of the document
	*/
	void saveDocument(const ::rtl::OString& _sDocumentId);

	/** queryContentProperty query in the DMS for a content which document name is equal to _sDocumentName
		@param	_sDocumentName	the document to query for

		@return	the content properties for this content or an empty refernce
	*/
	::rtl::Reference<ContentProperties> queryContentProperty(const ::rtl::OUString& _sDocumentName);

	/** getContentProperty returns the ContentProperties for the first content with that title
		@param	_sTitle	the title of the document

		@return	the content properties
	*/
	::rtl::Reference<ContentProperties> getContentPropertyWithTitle(const ::rtl::OUString& _sTitle) const;

	/** getContentProperty returns the ContentProperties for the first content with that SavedAsName
		@param	_sSaveAsName	the SavedAsName of the document

		@return	the content properties
	*/
	::rtl::Reference<ContentProperties> getContentPropertyWithSavedAsName(const ::rtl::OUString& _sSaveAsName) const;

	/** openDoc returns the URL for the temporary file for the specific Content and opens it
		@param	_rProp	used for check if already open, the member m_sFileURL will be set if is wan't opened yet

		@return the URL of the temporary file
	*/
	static ::rtl::OUString openDoc(const ::rtl::Reference<ContentProperties>& _rProp) throw (::com::sun::star::uno::Exception);
	
	/** convertURL converts a normal URL into an ODMA understandable name
		@param	_sCanonicURL	the URL from ContentIndentifier

		@return	the ODMA name 
	*/
	static ::rtl::OUString convertURL(const ::rtl::OUString& _sCanonicURL);

	/** deleteDocument deletes the document inside the DMS and remove the content properties from inside list
		@param	_rProp	the ContentProperties

		@return true when successful
	*/
	sal_Bool deleteDocument(const ::rtl::Reference<ContentProperties>& _rProp);
};

}

#endif