/************************************************************************* * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * Copyright 2000, 2010 Oracle and/or its affiliates. * * OpenOffice.org - a multi-platform office productivity suite * * This file is part of OpenOffice.org. * * OpenOffice.org is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License version 3 * only, as published by the Free Software Foundation. * * OpenOffice.org is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU Lesser General Public License version 3 for more details * (a copy is included in the LICENSE file that accompanied this code). * * You should have received a copy of the GNU Lesser General Public License * version 3 along with OpenOffice.org. If not, see * * for a copy of the LGPLv3 License. * ************************************************************************/ #ifndef ODMA_PROVIDER_HXX #define ODMA_PROVIDER_HXX #include #include #include #include "odma_lib.hxx" #include "rtl/ref.hxx" #include #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 > 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& _rProp); /** */ ::rtl::Reference 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& _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 queryContentProperty(const ::rtl::OUString& _sDocumentName); /** getContentPropertyWithTitle returns the ContentProperties for the first content with that title @param _sTitle the title of the document @return the content properties */ ::rtl::Reference getContentPropertyWithTitle(const ::rtl::OUString& _sTitle) const; /** getContentPropertyWithDocumentId returns the ContentProperties for the first content with that title @param _sTitle the title of the document @return the content properties */ ::rtl::Reference getContentPropertyWithDocumentId(const ::rtl::OUString& _sDocumentId) const; /** getContentPropertyWithSavedAsName returns the ContentProperties for the first content with that SavedAsName @param _sSaveAsName the SavedAsName of the document @return the content properties */ ::rtl::Reference 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& _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& _rProp); }; } #endif