blob: 02f96a0883fc6e693f1510f439cd7a8d2abc16b5 [file] [log] [blame]
/**************************************************************
*
* 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