/************************************************************** * * 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. * *************************************************************/ #if ! defined INCLUDED_DP_BACKENDDB_HXX #define INCLUDED_DP_BACKENDDB_HXX #include "rtl/ustring.hxx" #include #include namespace css = ::com::sun::star; namespace com { namespace sun { namespace star { namespace uno { class XComponentContext; } namespace xml { namespace dom { class XDocument; class XNode; }} namespace xml { namespace xpath { class XXPathAPI; }} }}} namespace dp_registry { namespace backend { class BackendDb { private: css::uno::Reference m_doc; css::uno::Reference m_xpathApi; BackendDb(BackendDb const &); BackendDb & operator = (BackendDb const &); protected: const css::uno::Reference m_xContext; ::rtl::OUString m_urlDb; protected: /* caller must make sure that only one thread accesses the function */ css::uno::Reference getDocument(); /* the namespace prefix is "reg" (without quotes) */ css::uno::Reference getXPathAPI(); void save(); void removeElement(::rtl::OUString const & sXPathExpression); css::uno::Reference getKeyElement( ::rtl::OUString const & url); void writeSimpleList( ::std::list< ::rtl::OUString> const & list, ::rtl::OUString const & sListTagName, ::rtl::OUString const & sMemberTagName, css::uno::Reference const & xParent); void writeVectorOfPair( ::std::vector< ::std::pair< ::rtl::OUString, ::rtl::OUString > > const & vecPairs, ::rtl::OUString const & sVectorTagName, ::rtl::OUString const & sPairTagName, ::rtl::OUString const & sFirstTagName, ::rtl::OUString const & sSecondTagName, css::uno::Reference const & xParent); void writeSimpleElement( ::rtl::OUString const & sElementName, ::rtl::OUString const & value, css::uno::Reference const & xParent); css::uno::Reference writeKeyElement( ::rtl::OUString const & url); ::rtl::OUString readSimpleElement( ::rtl::OUString const & sElementName, css::uno::Reference const & xParent); ::std::vector< ::std::pair< ::rtl::OUString, ::rtl::OUString > > readVectorOfPair( css::uno::Reference const & parent, ::rtl::OUString const & sListTagName, ::rtl::OUString const & sPairTagName, ::rtl::OUString const & sFirstTagName, ::rtl::OUString const & sSecondTagName); ::std::list< ::rtl::OUString> readList( css::uno::Reference const & parent, ::rtl::OUString const & sListTagName, ::rtl::OUString const & sMemberTagName); /* returns the values of one particularly child element of all key elements. */ ::std::list< ::rtl::OUString> getOneChildFromAllEntries( ::rtl::OUString const & sElementName); /* returns the namespace which is to be written as xmlns attribute into the root element. */ virtual ::rtl::OUString getDbNSName()=0; /* return the namespace prefix which is to be registered with the XPath API. The prefix can then be used in XPath expressions. */ virtual ::rtl::OUString getNSPrefix()=0; /* returns the name of the root element without any namespace prefix. */ virtual ::rtl::OUString getRootElementName()=0; /* returns the name of xml element for each entry */ virtual ::rtl::OUString getKeyElementName()=0; public: BackendDb(css::uno::Reference const & xContext, ::rtl::OUString const & url); virtual ~BackendDb() {}; void removeEntry(::rtl::OUString const & url); /* This is called to write the "revoked" attribute to the entry. This is done when XPackage::revokePackage is called. */ void revokeEntry(::rtl::OUString const & url); /* returns false if the entry does not exist yet. */ bool activateEntry(::rtl::OUString const & url); bool hasActiveEntry(::rtl::OUString const & url); }; class RegisteredDb: public BackendDb { public: RegisteredDb( css::uno::Reference const & xContext, ::rtl::OUString const & url); virtual ~RegisteredDb() {}; virtual void addEntry(::rtl::OUString const & url); virtual bool getEntry(::rtl::OUString const & url); }; } } #endif