diff options
author | Cédric Bosdonnat <cedric.bosdonnat@free.fr> | 2012-09-14 13:44:44 +0200 |
---|---|---|
committer | Cédric Bosdonnat <cedric.bosdonnat@free.fr> | 2012-09-14 13:57:03 +0200 |
commit | 27264b1e940ceea616788e708c20b6fd9c0190c5 (patch) | |
tree | 0959bf5b0fa00cd98bbd1b06d9e19a25ffed2c6a | |
parent | 24c66413176cdb64eccb21e204bc61c933f2732d (diff) |
updated libcmis to 0.3.0
Change-Id: Ied3f21fa021ad0dbe044ae05941389810462d821
-rw-r--r-- | configure.in | 4 | ||||
-rw-r--r-- | libcmis/Package_libcmis.mk | 8 | ||||
-rw-r--r-- | libcmis/StaticLibrary_cmis.mk | 19 | ||||
-rw-r--r-- | libcmis/UnpackedTarball_cmis.mk | 5 | ||||
-rw-r--r-- | libcmis/boost-win.patch | 61 | ||||
-rw-r--r-- | libcmis/libcmis-0.2.3-backports.patch | 1471 | ||||
-rw-r--r-- | libcmis/libcmis-0.2.3.patch | 33 | ||||
-rw-r--r-- | ucb/source/ucp/cmis/cmis_content.cxx | 191 | ||||
-rw-r--r-- | ucb/source/ucp/cmis/cmis_content.hxx | 17 | ||||
-rw-r--r-- | ucb/source/ucp/cmis/cmis_repo_content.cxx | 7 | ||||
-rw-r--r-- | ucb/source/ucp/cmis/cmis_url.cxx | 11 | ||||
-rw-r--r-- | ucb/source/ucp/cmis/cmis_url.hxx | 1 |
12 files changed, 168 insertions, 1660 deletions
diff --git a/configure.in b/configure.in index 64cba655a74f..c90a3661fa7e 100644 --- a/configure.in +++ b/configure.in @@ -6704,11 +6704,11 @@ AC_MSG_CHECKING([which libcmis to use]) if test "$with_system_libcmis" = "yes"; then AC_MSG_RESULT([external]) SYSTEM_LIBCMIS=YES - PKG_CHECK_MODULES( CMIS, libcmis-0.2 >= 0.2.1 ) + PKG_CHECK_MODULES( CMIS, libcmis-0.3 >= 0.3.0 ) else AC_MSG_RESULT([internal]) SYSTEM_LIBCMIS=NO - CMIS_TARBALL=0d2dcdfbf28d6208751b33057f5361f0-libcmis-0.2.3.tar.gz + CMIS_TARBALL=b2371dc7cf4811c9d32146eec913d296-libcmis-0.3.0.tar.gz fi AC_SUBST(SYSTEM_LIBCMIS) AC_SUBST(CMIS_CFLAGS) diff --git a/libcmis/Package_libcmis.mk b/libcmis/Package_libcmis.mk index 6039aadd45ff..c8c8fbefeb56 100644 --- a/libcmis/Package_libcmis.mk +++ b/libcmis/Package_libcmis.mk @@ -13,13 +13,6 @@ $(eval $(call gb_Package_use_unpacked,libcmis_inc,cmis)) $(eval $(call gb_Package_add_files,libcmis_inc,inc/external/libcmis,\ allowable-actions.hxx \ - atom-document.hxx \ - atom-folder.hxx \ - atom-object-type.hxx \ - atom-object.hxx \ - atom-session.hxx \ - atom-utils.hxx \ - atom-workspace.hxx \ document.hxx \ exception.hxx \ folder.hxx \ @@ -30,7 +23,6 @@ $(eval $(call gb_Package_add_files,libcmis_inc,inc/external/libcmis,\ repository.hxx \ session-factory.hxx \ session.hxx \ - test-helpers.hxx \ xml-utils.hxx \ xmlserializable.hxx \ )) diff --git a/libcmis/StaticLibrary_cmis.mk b/libcmis/StaticLibrary_cmis.mk index 01aa3723673a..23b600d59717 100644 --- a/libcmis/StaticLibrary_cmis.mk +++ b/libcmis/StaticLibrary_cmis.mk @@ -27,11 +27,28 @@ $(eval $(call gb_StaticLibrary_add_generated_exception_objects,cmislib,\ UnpackedTarball/cmis/src/libcmis/atom-object-type \ UnpackedTarball/cmis/src/libcmis/atom-object \ UnpackedTarball/cmis/src/libcmis/atom-session \ - UnpackedTarball/cmis/src/libcmis/atom-utils \ UnpackedTarball/cmis/src/libcmis/atom-workspace \ + UnpackedTarball/cmis/src/libcmis/base-session \ + UnpackedTarball/cmis/src/libcmis/document \ + UnpackedTarball/cmis/src/libcmis/folder \ + UnpackedTarball/cmis/src/libcmis/object \ + UnpackedTarball/cmis/src/libcmis/object-type \ UnpackedTarball/cmis/src/libcmis/property-type \ UnpackedTarball/cmis/src/libcmis/property \ + UnpackedTarball/cmis/src/libcmis/repository \ UnpackedTarball/cmis/src/libcmis/session-factory \ + UnpackedTarball/cmis/src/libcmis/ws-document \ + UnpackedTarball/cmis/src/libcmis/ws-folder \ + UnpackedTarball/cmis/src/libcmis/ws-navigationservice \ + UnpackedTarball/cmis/src/libcmis/ws-object \ + UnpackedTarball/cmis/src/libcmis/ws-object-type \ + UnpackedTarball/cmis/src/libcmis/ws-objectservice \ + UnpackedTarball/cmis/src/libcmis/ws-relatedmultipart \ + UnpackedTarball/cmis/src/libcmis/ws-repositoryservice \ + UnpackedTarball/cmis/src/libcmis/ws-requests \ + UnpackedTarball/cmis/src/libcmis/ws-session \ + UnpackedTarball/cmis/src/libcmis/ws-soap \ + UnpackedTarball/cmis/src/libcmis/ws-versioningservice \ UnpackedTarball/cmis/src/libcmis/xml-utils \ )) diff --git a/libcmis/UnpackedTarball_cmis.mk b/libcmis/UnpackedTarball_cmis.mk index 061b02b50867..57864742c62d 100644 --- a/libcmis/UnpackedTarball_cmis.mk +++ b/libcmis/UnpackedTarball_cmis.mk @@ -13,11 +13,6 @@ $(eval $(call gb_UnpackedTarball_set_tarball,cmis,$(CMIS_TARBALL))) $(eval $(call gb_UnpackedTarball_set_patchlevel,cmis,0)) -$(eval $(call gb_UnpackedTarball_add_patches,cmis,\ - libcmis/libcmis-0.2.3.patch \ - libcmis/libcmis-0.2.3-backports.patch \ -)) - ifeq ($(OS)$(COM),WNTMSC) $(eval $(call gb_UnpackedTarball_add_patches,cmis,libcmis/boost-win.patch)) endif diff --git a/libcmis/boost-win.patch b/libcmis/boost-win.patch index 76681829d413..7d9508bea071 100644 --- a/libcmis/boost-win.patch +++ b/libcmis/boost-win.patch @@ -1,7 +1,9 @@ ---- src/libcmis/atom-object.cxx 2012-06-01 07:44:26.000000000 -0600 -+++ src/libcmis/atom-object.cxx 2012-06-04 07:52:24.131190200 -0600 -@@ -29,6 +29,9 @@ - #include <algorithm> +diff --git src/libcmis/atom-object.cxx src/libcmis/atom-object.cxx +index ce21384..eef8102 100644 +--- src/libcmis/atom-object.cxx ++++ src/libcmis/atom-object.cxx +@@ -30,6 +30,9 @@ + #include <locale> #include <sstream> +#ifndef BOOST_DATE_TIME_NO_LIB @@ -9,21 +11,25 @@ +#endif #include <boost/date_time/posix_time/posix_time.hpp> - #include "atom-object.hxx" ---- src/libcmis/object.hxx 2012-06-01 07:38:36.000000000 -0600 -+++ src/libcmis/object.hxx 2012-06-04 07:52:21.900386200 -0600 -@@ -32,6 +32,9 @@ - #include <map> - #include <string> + #include "atom-document.hxx" +diff --git src/libcmis/object.hxx src/libcmis/object.hxx +index 449bb22..c320f06 100644 +--- src/libcmis/object.hxx ++++ src/libcmis/object.hxx +@@ -36,6 +36,9 @@ + #include <stdbool.h> + #endif +#ifndef BOOST_DATE_TIME_NO_LIB +#define BOOST_DATE_TIME_NO_LIB +#endif #include <boost/date_time.hpp> #include <boost/shared_ptr.hpp> - ---- src/libcmis/property-type.hxx 2012-02-17 08:00:50.000000000 -0700 -+++ src/libcmis/property-type.hxx 2012-06-04 07:52:17.157977900 -0600 + #include <libxml/tree.h> +diff --git src/libcmis/property-type.hxx src/libcmis/property-type.hxx +index 1a8bee9..6ac946c 100644 +--- src/libcmis/property-type.hxx ++++ src/libcmis/property-type.hxx @@ -28,6 +28,9 @@ #ifndef _PROPERTY_TYPE_HXX_ #define _PROPERTY_TYPE_HXX_ @@ -34,8 +40,10 @@ #include <boost/date_time.hpp> #include <libxml/tree.h> ---- src/libcmis/property.hxx 2012-02-17 06:38:33.000000000 -0700 -+++ src/libcmis/property.hxx 2012-06-04 07:52:19.388781800 -0600 +diff --git src/libcmis/property.hxx src/libcmis/property.hxx +index f9be04a..2977fb3 100644 +--- src/libcmis/property.hxx ++++ src/libcmis/property.hxx @@ -31,6 +31,9 @@ #include <libxml/tree.h> #include <libxml/xmlwriter.h> @@ -46,10 +54,26 @@ #include <boost/date_time.hpp> #include <boost/shared_ptr.hpp> ---- src/libcmis/xml-utils.hxx 2012-05-30 06:17:12.000000000 -0600 -+++ src/libcmis/xml-utils.hxx 2012-06-04 07:52:10.621566400 -0600 -@@ -30,6 +30,9 @@ +diff --git src/libcmis/ws-session.cxx src/libcmis/ws-session.cxx +index b906a5a..bf50644 100644 +--- src/libcmis/ws-session.cxx ++++ src/libcmis/ws-session.cxx +@@ -28,6 +28,9 @@ + + #include <sstream> ++#ifndef BOOST_DATE_TIME_NO_LIB ++#define BOOST_DATE_TIME_NO_LIB ++#endif + #include <boost/date_time.hpp> + #include <libxml/parser.h> + #include <libxml/tree.h> +diff --git src/libcmis/xml-utils.hxx src/libcmis/xml-utils.hxx +index 52853e2..2f80b91 100644 +--- src/libcmis/xml-utils.hxx ++++ src/libcmis/xml-utils.hxx +@@ -33,6 +33,9 @@ + #include <sstream> #include <string> +#ifndef BOOST_DATE_TIME_NO_LIB @@ -57,3 +81,4 @@ +#endif #include <boost/date_time.hpp> #include <libxml/tree.h> + #include <libxml/xpathInternals.h> diff --git a/libcmis/libcmis-0.2.3-backports.patch b/libcmis/libcmis-0.2.3-backports.patch deleted file mode 100644 index f0fbc9d9e85e..000000000000 --- a/libcmis/libcmis-0.2.3-backports.patch +++ /dev/null @@ -1,1471 +0,0 @@ ---- src/cmis-client.cxx 2012-06-01 15:50:49.000000000 +0200 -+++ src/cmis-client.cxx 2012-07-05 11:21:22.316674741 +0200 -@@ -163,16 +163,13 @@ - if ( "list-repos" == command ) - { - map< int, string > params = getSessionParams( ); -- list< string > ids = libcmis::SessionFactory::getRepositories( params ); -+ list< libcmis::RepositoryPtr > repos = libcmis::SessionFactory::getRepositories( params ); - - cout << "Repositories: "; -- for ( list< string >::iterator it = ids.begin(); it != ids.end(); it++ ) -+ for ( list< libcmis::RepositoryPtr >::iterator it = repos.begin(); it != repos.end(); it++ ) - { -- if ( it != ids.begin() ) -- cout << ", "; -- cout << *it; -+ cout << "\t" << ( *it )->getName() << " (" << ( *it )->getId( ) << ")" << endl; - } -- cout << endl; - } - else if ( "show-root" == command ) - { ---- src/libcmis/allowable-actions.cxx 2012-02-01 12:02:56.000000000 +0100 -+++ src/libcmis/allowable-actions.cxx 2012-07-05 11:21:22.314674740 +0200 -@@ -28,14 +28,122 @@ - - #include "allowable-actions.hxx" - #include "object.hxx" -+#include "xml-utils.hxx" - - using namespace std; - - namespace libcmis - { -- AllowableActions::AllowableActions( ) : -+ ObjectAction::ObjectAction( xmlNodePtr node ) : -+ m_type( ObjectAction::DeleteObject ), -+ m_enabled( false ), -+ m_valid( false ) -+ { -+ try -+ { -+ m_type = parseType( string( ( char* ) node->name ) ); -+ m_valid = true; -+ } -+ catch ( const Exception& ) -+ { -+ m_valid = false; -+ } -+ -+ // Invalid xsd:bool will be mean false... not sure what the spec says -+ try -+ { -+ xmlChar* content = xmlNodeGetContent( node ); -+ m_enabled = parseBool( string( ( char* )content ) ); -+ xmlFree( content ); -+ } -+ catch ( const Exception& ) -+ { -+ m_enabled = false; -+ } -+ } -+ -+ ObjectAction::Type ObjectAction::parseType( string type ) throw ( Exception ) -+ { -+ Type value = DeleteObject; -+ if ( type == "canDeleteObject" ) -+ value = DeleteObject; -+ else if ( type == "canUpdateProperties" ) -+ value = UpdateProperties; -+ else if ( type == "canGetFolderTree" ) -+ value = GetFolderTree; -+ else if ( type == "canGetProperties" ) -+ value = GetProperties; -+ else if ( type == "canGetObjectRelationships" ) -+ value = GetObjectRelationships; -+ else if ( type == "canGetObjectParents" ) -+ value = GetObjectParents; -+ else if ( type == "canGetFolderParent" ) -+ value = GetFolderParent; -+ else if ( type == "canGetDescendants" ) -+ value = GetDescendants; -+ else if ( type == "canMoveObject" ) -+ value = MoveObject; -+ else if ( type == "canDeleteContentStream" ) -+ value = DeleteContentStream; -+ else if ( type == "canCheckOut" ) -+ value = CheckOut; -+ else if ( type == "canCancelCheckOut" ) -+ value = CancelCheckOut; -+ else if ( type == "canCheckIn" ) -+ value = CheckIn; -+ else if ( type == "canSetContentStream" ) -+ value = SetContentStream; -+ else if ( type == "canGetAllVersions" ) -+ value = GetAllVersions; -+ else if ( type == "canAddObjectToFolder" ) -+ value = AddObjectToFolder; -+ else if ( type == "canRemoveObjectFromFolder" ) -+ value = RemoveObjectFromFolder; -+ else if ( type == "canGetContentStream" ) -+ value = GetContentStream; -+ else if ( type == "canApplyPolicy" ) -+ value = ApplyPolicy; -+ else if ( type == "canGetAppliedPolicies" ) -+ value = GetAppliedPolicies; -+ else if ( type == "canRemovePolicy" ) -+ value = RemovePolicy; -+ else if ( type == "canGetChildren" ) -+ value = GetChildren; -+ else if ( type == "canCreateDocument" ) -+ value = CreateDocument; -+ else if ( type == "canCreateFolder" ) -+ value = CreateFolder; -+ else if ( type == "canCreateRelationship" ) -+ value = CreateRelationship; -+ else if ( type == "canDeleteTree" ) -+ value = DeleteTree; -+ else if ( type == "canGetRenditions" ) -+ value = GetRenditions; -+ else if ( type == "canGetACL" ) -+ value = GetACL; -+ else if ( type == "canApplyACL" ) -+ value = ApplyACL; -+ else -+ throw Exception( "Invalid AllowableAction type: " + type ); -+ -+ return value; -+ } -+ -+ AllowableActions::AllowableActions( xmlNodePtr node ) : - m_states( ) - { -+ for ( xmlNodePtr child = node->children; child; child = child->next ) -+ { -+ // Check for non text children... "\n" is also a node ;) -+ if ( !xmlNodeIsText( child ) ) -+ { -+ ObjectAction action( child ); -+ if ( action.isValid( ) ) -+ m_states.insert( pair< libcmis::ObjectAction::Type, bool >( -+ action.getType( ), -+ action.isEnabled() ) ); -+ } -+ } - } - - AllowableActions::AllowableActions( const AllowableActions& copy ) : ---- src/libcmis/allowable-actions.hxx 2012-02-01 12:02:56.000000000 +0100 -+++ src/libcmis/allowable-actions.hxx 2012-07-05 11:21:22.314674740 +0200 -@@ -29,6 +29,11 @@ - #define _ALLOWABLE_ACTIONS_HXX_ - - #include <map> -+#include <string> -+ -+#include <libxml/tree.h> -+ -+#include "exception.hxx" - - namespace libcmis - { -@@ -37,8 +42,6 @@ - class ObjectAction - { - public: -- virtual ~ObjectAction( ){ } -- - enum Type - { - DeleteObject, -@@ -71,6 +74,25 @@ - GetACL, - ApplyACL - }; -+ -+ private: -+ Type m_type; -+ bool m_enabled; -+ bool m_valid; -+ -+ public: -+ ObjectAction( xmlNodePtr node ); -+ virtual ~ObjectAction( ){ } -+ -+ Type getType( ) { return m_type; } -+ bool isEnabled( ) { return m_enabled; } -+ bool isValid( ) { return m_valid; } -+ -+ /** Parses the permission name into one of the enum values or throws -+ an exception for invalid input strings. -+ */ -+ static Type parseType( std::string type ) throw ( Exception ); -+ - }; - - /** Class providing access to the allowed actions on an object. -@@ -81,7 +103,7 @@ - std::map< ObjectAction::Type, bool > m_states; - - public: -- AllowableActions( ); -+ AllowableActions( xmlNodePtr node ); - AllowableActions( const AllowableActions& copy ); - virtual ~AllowableActions( ); - ---- src/libcmis/atom-allowable-actions.cxx 2012-05-29 10:50:50.000000000 +0200 -+++ src/libcmis/atom-allowable-actions.cxx 1970-01-01 01:00:00.000000000 +0100 -@@ -1,237 +0,0 @@ --/* libcmis -- * Version: MPL 1.1 / GPLv2+ / LGPLv2+ -- * -- * The contents of this file are subject to the Mozilla Public License Version -- * 1.1 (the "License"); you may not use this file except in compliance with -- * the License or as specified alternatively below. You may obtain a copy of -- * the License at http://www.mozilla.org/MPL/ -- * -- * Software distributed under the License is distributed on an "AS IS" basis, -- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -- * for the specific language governing rights and limitations under the -- * License. -- * -- * Major Contributor(s): -- * Copyright (C) 2011 SUSE <cbosdonnat@suse.com> -- * -- * -- * All Rights Reserved. -- * -- * For minor contributions see the git repository. -- * -- * Alternatively, the contents of this file may be used under the terms of -- * either the GNU General Public License Version 2 or later (the "GPLv2+"), or -- * the GNU Lesser General Public License Version 2 or later (the "LGPLv2+"), -- * in which case the provisions of the GPLv2+ or the LGPLv2+ are applicable -- * instead of those above. -- */ -- --#include <libxml/xpathInternals.h> -- --#include "atom-allowable-actions.hxx" --#include "atom-utils.hxx" --#include "xml-utils.hxx" -- --using namespace std; -- --namespace atom --{ -- class ObjectAction : libcmis::ObjectAction -- { -- private: -- libcmis::ObjectAction::Type m_type; -- bool m_enabled; -- bool m_valid; -- -- public: -- ObjectAction( xmlNodePtr node ); -- -- libcmis::ObjectAction::Type getType( ) { return m_type; } -- bool isEnabled( ) { return m_enabled; } -- bool isValid( ) { return m_valid; } -- -- /** Parses the atom permission name into one of the enum values or throws -- an exception for invalid input strings. -- */ -- static libcmis::ObjectAction::Type parseType( string type ) throw ( libcmis::Exception ); -- }; -- -- ObjectAction::ObjectAction( xmlNodePtr node ) : -- m_type( libcmis::ObjectAction::DeleteObject ), -- m_enabled( false ), -- m_valid( false ) -- { -- try -- { -- m_type = parseType( string( ( char* ) node->name ) ); -- m_valid = true; -- } -- catch ( const libcmis::Exception& e ) -- { -- m_valid = false; -- } -- -- // Invalid xsd:bool will be mean false... not sure what the spec says -- try -- { -- xmlChar* content = xmlNodeGetContent( node ); -- m_enabled = libcmis::parseBool( string( ( char* )content ) ); -- xmlFree( content ); -- } -- catch ( const libcmis::Exception& e ) -- { -- m_enabled = false; -- } -- } -- -- libcmis::ObjectAction::Type ObjectAction::parseType( string type ) throw ( libcmis::Exception ) -- { -- libcmis::ObjectAction::Type value = libcmis::ObjectAction::DeleteObject; -- if ( type == "canDeleteObject" ) -- value = libcmis::ObjectAction::DeleteObject; -- else if ( type == "canUpdateProperties" ) -- value = libcmis::ObjectAction::UpdateProperties; -- else if ( type == "canGetFolderTree" ) -- value = libcmis::ObjectAction::GetFolderTree; -- else if ( type == "canGetProperties" ) -- value = libcmis::ObjectAction::GetProperties; -- else if ( type == "canGetObjectRelationships" ) -- value = libcmis::ObjectAction::GetObjectRelationships; -- else if ( type == "canGetObjectParents" ) -- value = libcmis::ObjectAction::GetObjectParents; -- else if ( type == "canGetFolderParent" ) -- value = libcmis::ObjectAction::GetFolderParent; -- else if ( type == "canGetDescendants" ) -- value = libcmis::ObjectAction::GetDescendants; -- else if ( type == "canMoveObject" ) -- value = libcmis::ObjectAction::MoveObject; -- else if ( type == "canDeleteContentStream" ) -- value = libcmis::ObjectAction::DeleteContentStream; -- else if ( type == "canCheckOut" ) -- value = libcmis::ObjectAction::CheckOut; -- else if ( type == "canCancelCheckOut" ) -- value = libcmis::ObjectAction::CancelCheckOut; -- else if ( type == "canCheckIn" ) -- value = libcmis::ObjectAction::CheckIn; -- else if ( type == "canSetContentStream" ) -- value = libcmis::ObjectAction::SetContentStream; -- else if ( type == "canGetAllVersions" ) -- value = libcmis::ObjectAction::GetAllVersions; -- else if ( type == "canAddObjectToFolder" ) -- value = libcmis::ObjectAction::AddObjectToFolder; -- else if ( type == "canRemoveObjectFromFolder" ) -- value = libcmis::ObjectAction::RemoveObjectFromFolder; -- else if ( type == "canGetContentStream" ) -- value = libcmis::ObjectAction::GetContentStream; -- else if ( type == "canApplyPolicy" ) -- value = libcmis::ObjectAction::ApplyPolicy; -- else if ( type == "canGetAppliedPolicies" ) -- value = libcmis::ObjectAction::GetAppliedPolicies; -- else if ( type == "canRemovePolicy" ) -- value = libcmis::ObjectAction::RemovePolicy; -- else if ( type == "canGetChildren" ) -- value = libcmis::ObjectAction::GetChildren; -- else if ( type == "canCreateDocument" ) -- value = libcmis::ObjectAction::CreateDocument; -- else if ( type == "canCreateFolder" ) -- value = libcmis::ObjectAction::CreateFolder; -- else if ( type == "canCreateRelationship" ) -- value = libcmis::ObjectAction::CreateRelationship; -- else if ( type == "canDeleteTree" ) -- value = libcmis::ObjectAction::DeleteTree; -- else if ( type == "canGetRenditions" ) -- value = libcmis::ObjectAction::GetRenditions; -- else if ( type == "canGetACL" ) -- value = libcmis::ObjectAction::GetACL; -- else if ( type == "canApplyACL" ) -- value = libcmis::ObjectAction::ApplyACL; -- else -- throw libcmis::Exception( "Invalid AllowableAction type: " + type ); -- -- return value; -- } --} -- --AtomAllowableActions::AtomAllowableActions( AtomPubSession* session ) : -- libcmis::AllowableActions( ), -- m_url( ), -- m_session( session ) --{ --} -- --AtomAllowableActions::AtomAllowableActions( AtomPubSession* session, string url ) : -- libcmis::AllowableActions( ), -- m_url( url ), -- m_session( session ) --{ -- refresh(); --} -- --AtomAllowableActions::AtomAllowableActions( const AtomAllowableActions& copy ) : -- libcmis::AllowableActions( copy ), -- m_url( copy.m_url ), -- m_session( copy.m_session ) --{ --} -- --const AtomAllowableActions& AtomAllowableActions::operator=( const AtomAllowableActions& copy ) --{ -- AllowableActions::operator=( copy ); -- m_url = copy.m_url; -- m_session = copy.m_session; -- -- return *this; --} -- --void AtomAllowableActions::refresh( ) throw ( libcmis::Exception ) --{ -- m_states.clear( ); -- -- if ( !m_url.empty( ) ) -- { -- string buf; -- try -- { -- buf = m_session->httpGetRequest( m_url )->str( ); -- } -- catch ( const atom::CurlException& e ) -- { -- throw e.getCmisException( ); -- } -- xmlDocPtr doc = xmlReadMemory( buf.c_str(), buf.size(), m_url.c_str(), NULL, 0 ); -- -- if ( NULL == doc ) -- throw libcmis::Exception( "Failed to parse object infos" ); -- -- // Populate the m_states map -- xmlXPathContextPtr xpathCtx = xmlXPathNewContext( doc ); -- -- atom::registerNamespaces( xpathCtx ); -- -- if ( NULL != xpathCtx ) -- { -- xmlXPathObjectPtr xpathObj = xmlXPathEvalExpression( BAD_CAST( "//cmis:allowableActions" ), xpathCtx ); -- if ( xpathObj && xpathObj->nodesetval && xpathObj->nodesetval->nodeNr > 0 ) -- { -- xmlNodePtr node = xpathObj->nodesetval->nodeTab[0]; -- for ( xmlNodePtr child = node->children; child; child = child->next ) -- { -- // Check for non text children... "\n" is also a node ;) -- if ( !xmlNodeIsText( child ) ) -- { -- atom::ObjectAction action( child ); -- if ( action.isValid( ) ) -- m_states.insert( pair< libcmis::ObjectAction::Type, bool >( -- action.getType( ), -- action.isEnabled() ) ); -- } -- } -- } -- xmlXPathFreeObject( xpathObj ); -- } -- -- xmlXPathFreeContext( xpathCtx ); -- -- xmlFreeDoc( doc ); -- } --} ---- src/libcmis/atom-allowable-actions.hxx 2012-01-19 17:26:32.000000000 +0100 -+++ src/libcmis/atom-allowable-actions.hxx 1970-01-01 01:00:00.000000000 +0100 -@@ -1,56 +0,0 @@ --/* libcmis -- * Version: MPL 1.1 / GPLv2+ / LGPLv2+ -- * -- * The contents of this file are subject to the Mozilla Public License Version -- * 1.1 (the "License"); you may not use this file except in compliance with -- * the License or as specified alternatively below. You may obtain a copy of -- * the License at http://www.mozilla.org/MPL/ -- * -- * Software distributed under the License is distributed on an "AS IS" basis, -- * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -- * for the specific language governing rights and limitations under the -- * License. -- * -- * Major Contributor(s): -- * Copyright (C) 2011 SUSE <cbosdonnat@suse.com> -- * -- * -- * All Rights Reserved. -- * -- * For minor contributions see the git repository. -- * -- * Alternatively, the contents of this file may be used under the terms of -- * either the GNU General Public License Version 2 or later (the "GPLv2+"), or -- * the GNU Lesser General Public License Version 2 or later (the "LGPLv2+"), -- * in which case the provisions of the GPLv2+ or the LGPLv2+ are applicable -- * instead of those above. -- */ --#ifndef _ATOM_ALLOWABLE_ACTIONS_HXX_ --#define _ATOM_ALLOWABLE_ACTIONS_HXX_ -- --#include <string> -- --#include "atom-session.hxx" --#include "allowable-actions.hxx" --#include "exception.hxx" -- --class AtomAllowableActions : public libcmis::AllowableActions --{ -- private: -- std::string m_url; -- AtomPubSession* m_session; -- -- public: -- AtomAllowableActions( AtomPubSession* session ); -- AtomAllowableActions( AtomPubSession* session, std::string url ); -- AtomAllowableActions( const AtomAllowableActions& copy ); -- ~AtomAllowableActions( ) { }; -- -- const AtomAllowableActions& operator=( const AtomAllowableActions& copy ); -- -- void setUrl( std::string url ) { m_url = url; } -- -- void refresh( ) throw ( libcmis::Exception ); --}; -- --#endif ---- src/libcmis/atom-document.hxx 2012-06-01 15:47:01.000000000 +0200 -+++ src/libcmis/atom-document.hxx 2012-07-05 11:21:22.314674740 +0200 -@@ -35,6 +35,7 @@ - - #include "document.hxx" - #include "exception.hxx" -+#include "folder.hxx" - #include "atom-object.hxx" - - class AtomDocument : public libcmis::Document, public AtomObject ---- src/libcmis/atom-object.cxx 2012-06-08 13:43:05.000000000 +0200 -+++ src/libcmis/atom-object.cxx 2012-07-05 11:21:22.315674740 +0200 -@@ -435,12 +435,14 @@ - // Get the infos URL as we may not have it - m_infosUrl = getLink( "self", "application/atom+xml;type=entry" )->getHref( ); - -- // Get the URL to the allowableActions -- AtomLink* allowableActionsLink = getLink( "http://docs.oasis-open.org/ns/cmis/link/200908/allowableactions", "application/cmisallowableactions+xml" ); -- if ( NULL != allowableActionsLink ) -+ // Get the allowableActions -+ xpathObj = xmlXPathEvalExpression( BAD_CAST( "//cmis:allowableActions" ), xpathCtx ); -+ if ( xpathObj && xpathObj->nodesetval && xpathObj->nodesetval->nodeNr > 0 ) - { -- m_allowableActions.reset( new AtomAllowableActions( m_session, allowableActionsLink->getHref( ) ) ); -+ xmlNodePtr node = xpathObj->nodesetval->nodeTab[0]; -+ m_allowableActions.reset( new libcmis::AllowableActions( node ) ); - } -+ xmlXPathFreeObject( xpathObj ); - - // First get the type id as it will give us the property definitions - string typeIdReq( "//cmis:propertyId[@propertyDefinitionId='cmis:objectTypeId']/cmis:value/text()" ); ---- src/libcmis/atom-object.hxx 2012-06-01 15:43:27.000000000 +0200 -+++ src/libcmis/atom-object.hxx 2012-07-05 11:21:22.315674740 +0200 -@@ -30,7 +30,7 @@ - - #include <libxml/tree.h> - --#include "atom-allowable-actions.hxx" -+#include "allowable-actions.hxx" - #include "object.hxx" - - class AtomPubSession; -@@ -64,7 +64,7 @@ - libcmis::ObjectTypePtr m_typeDescription; - - std::map< std::string, libcmis::PropertyPtr > m_properties; -- boost::shared_ptr< AtomAllowableActions > m_allowableActions; -+ boost::shared_ptr< libcmis::AllowableActions > m_allowableActions; - - std::vector< AtomLink > m_links; - ---- src/libcmis/atom-object-type.cxx 2012-05-29 10:50:50.000000000 +0200 -+++ src/libcmis/atom-object-type.cxx 2012-07-05 11:21:22.317674741 +0200 -@@ -255,7 +255,7 @@ - bool createdDoc = ( NULL == doc ); - if ( createdDoc ) - { -- string pattern = m_session->getWorkspace().getUriTemplate( atom::UriTemplate::TypeById ); -+ string pattern = m_session->getAtomRepository()->getUriTemplate( UriTemplate::TypeById ); - map< string, string > vars; - vars[URI_TEMPLATE_VAR_ID] = getId( ); - string url = m_session->createUrl( pattern, vars ); ---- src/libcmis/atom-session.cxx 2012-06-08 13:43:05.000000000 +0200 -+++ src/libcmis/atom-session.cxx 2012-07-05 11:21:22.317674741 +0200 -@@ -126,8 +126,8 @@ - m_username( username ), - m_password( password ), - m_authProvided( false ), -- m_workspace( ), -- m_repositoriesIds( ), -+ m_repository( ), -+ m_repositories( ), - m_verbose( verbose ), - m_authProvider( ), - m_curlHandle( NULL ) -@@ -143,8 +143,8 @@ - m_username( copy.m_username ), - m_password( copy.m_password ), - m_authProvided( copy.m_authProvided ), -- m_workspace( copy.m_workspace ), -- m_repositoriesIds( copy.m_repositoriesIds ), -+ m_repository( copy.m_repository ), -+ m_repositories( copy.m_repositories ), - m_verbose( copy.m_verbose ), - m_authProvider( copy.m_authProvider ), - m_curlHandle( NULL ) -@@ -162,8 +162,8 @@ - m_username = copy.m_username; - m_password = copy.m_password; - m_authProvided = copy.m_authProvided; -- m_workspace = copy.m_workspace; -- m_repositoriesIds = copy.m_repositoriesIds; -+ m_repository = copy.m_repository; -+ m_repositories = copy.m_repositories; - m_verbose = copy.m_verbose; - m_authProvider = copy.m_authProvider; - m_curlHandle = NULL; -@@ -183,7 +183,7 @@ - - void AtomPubSession::initialize( ) throw ( libcmis::Exception ) - { -- if ( m_repositoriesIds.empty() ) -+ if ( m_repositories.empty() ) - { - // Pull the content from sAtomPubUrl - string buf; -@@ -221,13 +221,13 @@ - { - try - { -- atom::Workspace ws( xpathObj->nodesetval->nodeTab[i] ); -+ AtomRepositoryPtr ws( new AtomRepository( xpathObj->nodesetval->nodeTab[i] ) ); - - // SharePoint is case insensitive for the id... -- if ( lcl_tolower( ws.getId( ) ) == lcl_tolower( m_sRepository ) ) -- m_workspace = ws; -+ if ( lcl_tolower( ws->getId( ) ) == lcl_tolower( m_sRepository ) ) -+ m_repository = ws; - -- m_repositoriesIds.push_back( ws.getId() ); -+ m_repositories.push_back( ws ); - } - catch ( const libcmis::Exception& e ) - { -@@ -246,22 +246,22 @@ - - } - --list< string > AtomPubSession::getRepositories( string url, string username, string password, bool verbose ) throw ( libcmis::Exception ) -+list< libcmis::RepositoryPtr > AtomPubSession::getRepositories( string url, string username, string password, bool verbose ) throw ( libcmis::Exception ) - { - AtomPubSession session( url, string(), username, password, verbose ); - session.initialize( ); -- return session.m_repositoriesIds; -+ return session.m_repositories; - } - --atom::Workspace& AtomPubSession::getWorkspace( ) throw ( libcmis::Exception ) -+AtomRepositoryPtr AtomPubSession::getAtomRepository( ) throw ( libcmis::Exception ) - { - initialize( ); -- return m_workspace; -+ return m_repository; - } - --libcmis::FolderPtr AtomPubSession::getRootFolder() throw ( libcmis::Exception ) -+libcmis::RepositoryPtr AtomPubSession::getRepository( ) throw ( libcmis::Exception ) - { -- return getFolder( getWorkspace().getRootId() ); -+ return getAtomRepository( ); - } - - libcmis::ObjectPtr AtomPubSession::createObjectFromEntryDoc( xmlDocPtr doc ) -@@ -306,11 +306,17 @@ - return cmisObject; - } - -+libcmis::FolderPtr AtomPubSession::getRootFolder( ) throw ( libcmis::Exception ) -+{ -+ return getFolder( getRootId( ) ); -+} -+ - libcmis::ObjectPtr AtomPubSession::getObject( string id ) throw ( libcmis::Exception ) - { -- string pattern = getWorkspace().getUriTemplate( atom::UriTemplate::ObjectById ); -+ string pattern = getAtomRepository()->getUriTemplate( UriTemplate::ObjectById ); - map< string, string > vars; - vars[URI_TEMPLATE_VAR_ID] = id; -+ vars[string( "includeAllowableActions" )] = string( "true" ); - string url = createUrl( pattern, vars ); - - try -@@ -337,9 +343,10 @@ - - libcmis::ObjectPtr AtomPubSession::getObjectByPath( string path ) throw ( libcmis::Exception ) - { -- string pattern = getWorkspace().getUriTemplate( atom::UriTemplate::ObjectByPath ); -+ string pattern = getAtomRepository()->getUriTemplate( UriTemplate::ObjectByPath ); - map< string, string > vars; - vars[URI_TEMPLATE_VAR_PATH] = path; -+ vars[string( "includeAllowableActions" )] = string( "true" ); - string url = createUrl( pattern, vars ); - - try ---- src/libcmis/atom-session.hxx 2012-06-08 13:43:05.000000000 +0200 -+++ src/libcmis/atom-session.hxx 2012-07-05 11:21:22.360674743 +0200 -@@ -95,9 +95,9 @@ - std::string m_username; - std::string m_password; - bool m_authProvided; -- atom::Workspace m_workspace; -+ AtomRepositoryPtr m_repository; - -- std::list< std::string > m_repositoriesIds; -+ std::list< libcmis::RepositoryPtr > m_repositories; - - bool m_verbose; - libcmis::AuthProviderPtr m_authProvider; -@@ -113,17 +113,17 @@ - - AtomPubSession& operator=( const AtomPubSession& copy ); - -- static std::list< std::string > getRepositories( std::string url, -+ static std::list< libcmis::RepositoryPtr > getRepositories( std::string url, - std::string username, std::string password, - bool verbose = false ) throw ( libcmis::Exception ); - -- std::string getRootId( ) throw ( libcmis::Exception ) { return getWorkspace().getRootId( ); } -+ std::string getRootId( ) throw ( libcmis::Exception ) { return getRepository()->getRootId( ); } - - std::string getUsername( ) { return m_username; } - - std::string getPassword( ) { return m_password; } - -- atom::Workspace& getWorkspace( ) throw ( libcmis::Exception ); -+ AtomRepositoryPtr getAtomRepository( ) throw ( libcmis::Exception ); - - // Utility methods - -@@ -142,6 +142,8 @@ - - // Override session methods - -+ virtual libcmis::RepositoryPtr getRepository( ) throw ( libcmis::Exception ); -+ - virtual libcmis::FolderPtr getRootFolder() throw ( libcmis::Exception ); - - virtual libcmis::ObjectPtr getObject( std::string id ) throw ( libcmis::Exception ); ---- src/libcmis/atom-workspace.cxx 2011-12-06 14:12:19.000000000 +0100 -+++ src/libcmis/atom-workspace.cxx 2012-07-05 11:21:22.360674743 +0200 -@@ -31,204 +31,207 @@ - - using namespace std; - --namespace atom -+AtomRepository::AtomRepository( xmlNodePtr wsNode ) throw ( libcmis::Exception ): -+ m_id( ), -+ m_rootId( ), -+ m_name( ), -+ m_collections( ), -+ m_uriTemplates( ) - { -- Workspace::Workspace( xmlNodePtr wsNode ) throw ( libcmis::Exception ): -- m_id( ), -- m_rootId( ), -- m_collections( ), -- m_uriTemplates( ) -+ if ( wsNode != NULL ) - { -- if ( wsNode != NULL ) -- { -- xmlDocPtr doc = wrapInDoc( wsNode ); -- xmlXPathContextPtr xpathCtx = xmlXPathNewContext( doc ); -- atom::registerNamespaces( xpathCtx ); -+ xmlDocPtr doc = atom::wrapInDoc( wsNode ); -+ xmlXPathContextPtr xpathCtx = xmlXPathNewContext( doc ); -+ atom::registerNamespaces( xpathCtx ); - -- if ( NULL != xpathCtx ) -- { -- // Get the collections -- xmlXPathObjectPtr xpathObj = xmlXPathEvalExpression( BAD_CAST( "//app:collection" ), xpathCtx ); -- if ( NULL != xpathObj ) -- readCollections( xpathObj->nodesetval ); -- xmlXPathFreeObject( xpathObj ); -- -- // Get the URI templates -- xpathObj = xmlXPathEvalExpression( BAD_CAST( "//cmisra:uritemplate" ), xpathCtx ); -- if ( NULL != xpathObj ) -- readUriTemplates( xpathObj->nodesetval ); -- xmlXPathFreeObject( xpathObj ); -- -- // Get the root node id -- string rootIdXPath( "//cmisra:repositoryInfo/cmis:rootFolderId/text()" ); -- m_rootId = atom::getXPathValue( xpathCtx, rootIdXPath ); -- -- // Get the repository id -- string repoIdXPath( "//cmisra:repositoryInfo/cmis:repositoryId/text()" ); -- m_id = atom::getXPathValue( xpathCtx, repoIdXPath ); -+ if ( NULL != xpathCtx ) -+ { -+ // Get the collections -+ xmlXPathObjectPtr xpathObj = xmlXPathEvalExpression( BAD_CAST( "//app:collection" ), xpathCtx ); -+ if ( NULL != xpathObj ) -+ readCollections( xpathObj->nodesetval ); -+ xmlXPathFreeObject( xpathObj ); -+ -+ // Get the URI templates -+ xpathObj = xmlXPathEvalExpression( BAD_CAST( "//cmisra:uritemplate" ), xpathCtx ); -+ if ( NULL != xpathObj ) -+ readUriTemplates( xpathObj->nodesetval ); -+ xmlXPathFreeObject( xpathObj ); -+ -+ // Get the root node id -+ string rootIdXPath( "//cmisra:repositoryInfo/cmis:rootFolderId/text()" ); -+ m_rootId = atom::getXPathValue( xpathCtx, rootIdXPath ); -+ -+ // Get the repository id -+ string repoIdXPath( "//cmisra:repositoryInfo/cmis:repositoryId/text()" ); -+ m_id = atom::getXPathValue( xpathCtx, repoIdXPath ); -+ -+ // Get the repository name -+ string repoNameXPath( "//cmisra:repositoryInfo/cmis:repositoryName/text()" ); -+ m_name = atom::getXPathValue( xpathCtx, repoNameXPath ); - -- // TODO Extract other useful stuffs -- } -- xmlXPathFreeContext( xpathCtx ); -- xmlFreeDoc( doc ); -+ // TODO Extract other useful stuffs - } -+ xmlXPathFreeContext( xpathCtx ); -+ xmlFreeDoc( doc ); - } -+} - -- Workspace::Workspace( const Workspace& rCopy ) : -- m_id ( rCopy.m_id ), -- m_rootId( rCopy.m_rootId ), -- m_collections( rCopy.m_collections ), -- m_uriTemplates( rCopy.m_uriTemplates ) -- { -- } -- -- Workspace::~Workspace( ) -- { -- m_collections.clear( ); -- m_uriTemplates.clear( ); -- } -- -- Workspace& Workspace::operator= ( const Workspace& rCopy ) -- { -- m_id = rCopy.m_id; -- m_rootId = rCopy.m_rootId; -- m_collections = rCopy.m_collections; -- m_uriTemplates = rCopy.m_uriTemplates; -- -- return *this; -- } -- -- string Workspace::getCollectionUrl( Collection::Type type ) -- { -- return m_collections[ type ]; -- } -- -- string Workspace::getUriTemplate( UriTemplate::Type type ) -- { -- return m_uriTemplates[ type ]; -- } -+AtomRepository::AtomRepository( const AtomRepository& rCopy ) : -+ m_id ( rCopy.m_id ), -+ m_rootId( rCopy.m_rootId ), -+ m_name( rCopy.m_name ), -+ m_collections( rCopy.m_collections ), -+ m_uriTemplates( rCopy.m_uriTemplates ) -+{ -+} - -- void Workspace::readCollections( xmlNodeSetPtr nodeSet ) -- { -- int size = 0; -- if ( nodeSet ) -- size = nodeSet->nodeNr; -+AtomRepository::~AtomRepository( ) -+{ -+ m_collections.clear( ); -+ m_uriTemplates.clear( ); -+} - -- for ( int i = 0; i < size; i++ ) -- { -- xmlNodePtr node = nodeSet->nodeTab[i]; -+AtomRepository& AtomRepository::operator= ( const AtomRepository& rCopy ) -+{ -+ m_id = rCopy.m_id; -+ m_rootId = rCopy.m_rootId; -+ m_name = rCopy.m_name; -+ m_collections = rCopy.m_collections; -+ m_uriTemplates = rCopy.m_uriTemplates; - -- // Look for the href property -- xmlChar* href = xmlGetProp( node, BAD_CAST( "href" ) ); -- if ( href ) -- { -- string collectionRef( ( char* )href ); -- xmlFree( href ); -+ return *this; -+} - -- // Look for the cmisra:collectionType child -- for ( xmlNodePtr child = node->children; child; child = child->next ) -- { -- // SharePoint CMIS implementation doesn't follow the spec: -- // the cmisra namespace is omitted -- bool isCollectionType = xmlStrEqual( child->name, BAD_CAST( "collectionType" ) ); -- if ( isCollectionType ) -- { -- xmlChar* content = xmlNodeGetContent( child ); -- Collection::Type type = Collection::Root; -- bool typeDefined = false; -- -- if ( xmlStrEqual( content, BAD_CAST( "root" ) ) ) -- { -- type = Collection::Root; -- typeDefined = true; -- } -- else if ( xmlStrEqual( content, BAD_CAST( "types" ) ) ) -- { -- type = Collection::Types; -- typeDefined = true; -- } -- else if ( xmlStrEqual( content, BAD_CAST( "query" ) ) ) -- { -- type = Collection::Query; -- typeDefined = true; -- } -- else if ( xmlStrEqual( content, BAD_CAST( "checkedout" ) ) ) -- { -- type = Collection::CheckedOut; -- typeDefined = true; -- } -- else if ( xmlStrEqual( content, BAD_CAST( "unfiled" ) ) ) -- { -- type = Collection::Unfiled; -- typeDefined = true; -- } -+string AtomRepository::getCollectionUrl( Collection::Type type ) -+{ -+ return m_collections[ type ]; -+} - -- if ( typeDefined ) -- m_collections[ type ] = collectionRef; -+string AtomRepository::getUriTemplate( UriTemplate::Type type ) -+{ -+ return m_uriTemplates[ type ]; -+} - -- xmlFree( content ); -- } -- } -- } -- } -- } -+void AtomRepository::readCollections( xmlNodeSetPtr nodeSet ) -+{ -+ int size = 0; -+ if ( nodeSet ) -+ size = nodeSet->nodeNr; - -- void Workspace::readUriTemplates( xmlNodeSetPtr nodeSet ) -+ for ( int i = 0; i < size; i++ ) - { -- int size = 0; -- if ( nodeSet ) -- size = nodeSet->nodeNr; -+ xmlNodePtr node = nodeSet->nodeTab[i]; - -- for ( int i = 0; i < size; i++ ) -+ // Look for the href property -+ xmlChar* href = xmlGetProp( node, BAD_CAST( "href" ) ); -+ if ( href ) - { -- xmlNodePtr node = nodeSet->nodeTab[i]; -- -- string templateUri; -- UriTemplate::Type type = UriTemplate::ObjectById; -- bool typeDefined = false; -+ string collectionRef( ( char* )href ); -+ xmlFree( href ); - -- // Look for the cmisra:template and cmisra:type children -+ // Look for the cmisra:collectionType child - for ( xmlNodePtr child = node->children; child; child = child->next ) - { -- bool isTemplate = xmlStrEqual( child->name, BAD_CAST( "template" ) ); -- bool isType = xmlStrEqual( child->name, BAD_CAST( "type" ) ); -- -- if ( isTemplate ) -- { -- xmlChar* content = xmlNodeGetContent( child ); -- templateUri = string( ( char * )content ); -- xmlFree( content ); -- } -- else if ( isType ) -+ // SharePoint CMIS implementation doesn't follow the spec: -+ // the cmisra namespace is omitted -+ bool isCollectionType = xmlStrEqual( child->name, BAD_CAST( "collectionType" ) ); -+ if ( isCollectionType ) - { - xmlChar* content = xmlNodeGetContent( child ); -- if ( xmlStrEqual( content, BAD_CAST( "objectbyid" ) ) ) -+ Collection::Type type = Collection::Root; -+ bool typeDefined = false; -+ -+ if ( xmlStrEqual( content, BAD_CAST( "root" ) ) ) - { -- type = UriTemplate::ObjectById; -+ type = Collection::Root; - typeDefined = true; - } -- else if ( xmlStrEqual( content, BAD_CAST( "objectbypath" ) ) ) -+ else if ( xmlStrEqual( content, BAD_CAST( "types" ) ) ) - { -- type = UriTemplate::ObjectByPath; -+ type = Collection::Types; - typeDefined = true; - } - else if ( xmlStrEqual( content, BAD_CAST( "query" ) ) ) - { -- type = UriTemplate::Query; -+ type = Collection::Query; - typeDefined = true; - } -- else if ( xmlStrEqual( content, BAD_CAST( "typebyid" ) ) ) -+ else if ( xmlStrEqual( content, BAD_CAST( "checkedout" ) ) ) - { -- type = UriTemplate::TypeById; -+ type = Collection::CheckedOut; - typeDefined = true; - } -+ else if ( xmlStrEqual( content, BAD_CAST( "unfiled" ) ) ) -+ { -+ type = Collection::Unfiled; -+ typeDefined = true; -+ } -+ -+ if ( typeDefined ) -+ m_collections[ type ] = collectionRef; -+ - xmlFree( content ); - } - } -- -- if ( !templateUri.empty() && typeDefined ) -- m_uriTemplates[ type ] = templateUri; - } - } -+} -+ -+void AtomRepository::readUriTemplates( xmlNodeSetPtr nodeSet ) -+{ -+ int size = 0; -+ if ( nodeSet ) -+ size = nodeSet->nodeNr; -+ -+ for ( int i = 0; i < size; i++ ) -+ { -+ xmlNodePtr node = nodeSet->nodeTab[i]; -+ -+ string templateUri; -+ UriTemplate::Type type = UriTemplate::ObjectById; -+ bool typeDefined = false; - -+ // Look for the cmisra:template and cmisra:type children -+ for ( xmlNodePtr child = node->children; child; child = child->next ) -+ { -+ bool isTemplate = xmlStrEqual( child->name, BAD_CAST( "template" ) ); -+ bool isType = xmlStrEqual( child->name, BAD_CAST( "type" ) ); -+ -+ if ( isTemplate ) -+ { -+ xmlChar* content = xmlNodeGetContent( child ); -+ templateUri = string( ( char * )content ); -+ xmlFree( content ); -+ } -+ else if ( isType ) -+ { -+ xmlChar* content = xmlNodeGetContent( child ); -+ if ( xmlStrEqual( content, BAD_CAST( "objectbyid" ) ) ) -+ { -+ type = UriTemplate::ObjectById; -+ typeDefined = true; -+ } -+ else if ( xmlStrEqual( content, BAD_CAST( "objectbypath" ) ) ) -+ { -+ type = UriTemplate::ObjectByPath; -+ typeDefined = true; -+ } -+ else if ( xmlStrEqual( content, BAD_CAST( "query" ) ) ) -+ { -+ type = UriTemplate::Query; -+ typeDefined = true; -+ } -+ else if ( xmlStrEqual( content, BAD_CAST( "typebyid" ) ) ) -+ { -+ type = UriTemplate::TypeById; -+ typeDefined = true; -+ } -+ xmlFree( content ); -+ } -+ } -+ -+ if ( !templateUri.empty() && typeDefined ) -+ m_uriTemplates[ type ] = templateUri; -+ } - } ---- src/libcmis/atom-workspace.hxx 2012-05-29 10:50:50.000000000 +0200 -+++ src/libcmis/atom-workspace.hxx 2012-07-05 11:21:22.361674743 +0200 -@@ -31,65 +31,71 @@ - #include <map> - #include <string> - -+#include <boost/shared_ptr.hpp> - #include <curl/curl.h> - #include <libxml/xpath.h> - - #include "exception.hxx" -+#include "repository.hxx" - - #define URI_TEMPLATE_VAR_ID std::string( "id" ) - #define URI_TEMPLATE_VAR_PATH std::string( "path" ) - --namespace atom --{ -- struct Collection { -- enum Type -- { -- Root, -- Types, -- Query, -- CheckedOut, -- Unfiled -- }; -- }; -- -- struct UriTemplate { -- enum Type -- { -- ObjectById, -- ObjectByPath, -- TypeById, -- Query -- }; -+struct Collection { -+ enum Type -+ { -+ Root, -+ Types, -+ Query, -+ CheckedOut, -+ Unfiled - }; -+}; - -- class Workspace -+struct UriTemplate { -+ enum Type - { -- private: -- std::string m_id; -- std::string m_rootId; -- -- /// Collections URLs -- std::map< Collection::Type, std::string > m_collections; -- -- /// URI templates -- std::map< UriTemplate::Type, std::string > m_uriTemplates; -- -- public: -- Workspace( xmlNodePtr wsNode = NULL ) throw ( libcmis::Exception ); -- Workspace( const Workspace& rCopy ); -- ~Workspace( ); -- -- Workspace& operator= ( const Workspace& rCopy ); -- -- std::string getCollectionUrl( atom::Collection::Type ); -- std::string getUriTemplate( atom::UriTemplate::Type ); -- std::string getRootId( ) { return m_rootId; } -- std::string getId( ) { return m_id; } -- -- private: -- void readCollections( xmlNodeSetPtr pNodeSet ); -- void readUriTemplates( xmlNodeSetPtr pNodeSet ); -+ ObjectById, -+ ObjectByPath, -+ TypeById, -+ Query - }; --} -+}; -+ -+class AtomRepository : public libcmis::Repository -+{ -+ private: -+ std::string m_id; -+ std::string m_rootId; -+ std::string m_name; -+ -+ /// Collections URLs -+ std::map< Collection::Type, std::string > m_collections; -+ -+ /// URI templates -+ std::map< UriTemplate::Type, std::string > m_uriTemplates; -+ -+ public: -+ AtomRepository( xmlNodePtr wsNode = NULL ) throw ( libcmis::Exception ); -+ AtomRepository( const AtomRepository& rCopy ); -+ ~AtomRepository( ); -+ -+ AtomRepository& operator= ( const AtomRepository& rCopy ); -+ -+ std::string getCollectionUrl( Collection::Type ); -+ std::string getUriTemplate( UriTemplate::Type ); -+ -+ // Repository methods -+ -+ virtual std::string getRootId( ) { return m_rootId; } -+ virtual std::string getId( ) { return m_id; } -+ virtual std::string getName( ) { return m_name; } -+ -+ private: -+ void readCollections( xmlNodeSetPtr pNodeSet ); -+ void readUriTemplates( xmlNodeSetPtr pNodeSet ); -+}; -+ -+typedef boost::shared_ptr< AtomRepository > AtomRepositoryPtr; - - #endif ---- src/libcmis/Makefile.am 2012-06-08 13:51:36.000000000 +0200 -+++ src/libcmis/Makefile.am 2012-07-05 11:21:22.361674743 +0200 -@@ -9,6 +9,7 @@ - object.hxx \ - property-type.hxx \ - property.hxx \ -+ repository.hxx \ - session-factory.hxx \ - session.hxx \ - xml-utils.hxx \ -@@ -32,8 +33,6 @@ - atom-utils.cxx \ - atom-workspace.hxx \ - atom-workspace.cxx \ -- atom-allowable-actions.hxx \ -- atom-allowable-actions.cxx \ - allowable-actions.cxx \ - property.cxx \ - property-type.cxx \ ---- src/libcmis/Makefile.in 2012-06-08 14:17:01.000000000 +0200 -+++ src/libcmis/Makefile.in 2012-07-05 11:21:22.361674743 +0200 -@@ -80,7 +80,7 @@ - am_libcmis_@LIBCMIS_API_VERSION@_la_OBJECTS = atom-object-type.lo \ - session-factory.lo atom-document.lo atom-folder.lo \ - atom-object.lo atom-session.lo atom-utils.lo atom-workspace.lo \ -- atom-allowable-actions.lo allowable-actions.lo property.lo \ -+ allowable-actions.lo property.lo \ - property-type.lo xml-utils.lo - libcmis_@LIBCMIS_API_VERSION@_la_OBJECTS = \ - $(am_libcmis_@LIBCMIS_API_VERSION@_la_OBJECTS) -@@ -278,6 +278,7 @@ - object.hxx \ - property-type.hxx \ - property.hxx \ -+ repository.hxx \ - session-factory.hxx \ - session.hxx \ - xml-utils.hxx \ -@@ -301,8 +302,6 @@ - atom-utils.cxx \ - atom-workspace.hxx \ - atom-workspace.cxx \ -- atom-allowable-actions.hxx \ -- atom-allowable-actions.cxx \ - allowable-actions.cxx \ - property.cxx \ - property-type.cxx \ -@@ -417,7 +416,6 @@ - -rm -f *.tab.c - - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/allowable-actions.Plo@am__quote@ --@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atom-allowable-actions.Plo@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atom-document.Plo@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atom-folder.Plo@am__quote@ - @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/atom-object-type.Plo@am__quote@ ---- src/libcmis/makefile.mk 2012-05-09 12:14:57.000000000 +0200 -+++ src/libcmis/makefile.mk 2012-07-05 11:21:22.315674740 +0200 -@@ -25,7 +25,6 @@ - - SLOFILES= \ - $(SLO)$/allowable-actions.obj \ -- $(SLO)$/atom-allowable-actions.obj \ - $(SLO)$/atom-document.obj \ - $(SLO)$/atom-folder.obj \ - $(SLO)$/atom-object-type.obj \ ---- src/libcmis/repository.hxx 1970-01-01 01:00:00.000000000 +0100 -+++ src/libcmis/repository.hxx 2012-07-05 11:21:22.361674743 +0200 -@@ -0,0 +1,54 @@ -+/* libcmis -+ * Version: MPL 1.1 / GPLv2+ / LGPLv2+ -+ * -+ * The contents of this file are subject to the Mozilla Public License Version -+ * 1.1 (the "License"); you may not use this file except in compliance with -+ * the License or as specified alternatively below. You may obtain a copy of -+ * the License at http://www.mozilla.org/MPL/ -+ * -+ * Software distributed under the License is distributed on an "AS IS" basis, -+ * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License -+ * for the specific language governing rights and limitations under the -+ * License. -+ * -+ * Major Contributor(s): -+ * Copyright (C) 2011 Cédric Bosdonnat <cbosdo@users.sourceforge.net> -+ * -+ * -+ * All Rights Reserved. -+ * -+ * For minor contributions see the git repository. -+ * -+ * Alternatively, the contents of this file may be used under the terms of -+ * either the GNU General Public License Version 2 or later (the "GPLv2+"), or -+ * the GNU Lesser General Public License Version 2 or later (the "LGPLv2+"), -+ * in which case the provisions of the GPLv2+ or the LGPLv2+ are applicable -+ * instead of those above. -+ */ -+#ifndef _REPOSITORY_HXX_ -+#define _REPOSITORY_HXX_ -+ -+#include <string> -+ -+#include <boost/shared_ptr.hpp> -+ -+namespace libcmis -+{ -+ /** Class representing a repository and its infos. -+ -+ \sa 2.2.2.2 section of the CMIS specifications -+ */ -+ class Repository -+ { -+ public: -+ virtual ~Repository( ) { }; -+ -+ virtual std::string getRootId( ) = 0; -+ virtual std::string getId( ) = 0; -+ virtual std::string getName( ) = 0; -+ }; -+ -+ typedef ::boost::shared_ptr< Repository > RepositoryPtr; -+} -+ -+#endif ---- src/libcmis/session-factory.cxx 2012-05-10 15:36:32.000000000 +0200 -+++ src/libcmis/session-factory.cxx 2012-07-05 11:21:22.362674743 +0200 -@@ -74,9 +74,9 @@ - return session; - } - -- list< string > SessionFactory::getRepositories( map< int, string > params ) throw ( Exception ) -+ list< RepositoryPtr > SessionFactory::getRepositories( map< int, string > params ) throw ( Exception ) - { -- list< string > repos; -+ list< RepositoryPtr > repos; - - map< int, string >::iterator pIt = params.find( ATOMPUB_URL ); - if ( pIt != params.end( ) ) ---- src/libcmis/session-factory.hxx 2012-05-10 15:37:03.000000000 +0200 -+++ src/libcmis/session-factory.hxx 2012-07-05 11:21:22.362674743 +0200 -@@ -33,6 +33,7 @@ - #include <string> - - #include "exception.hxx" -+#include "repository.hxx" - #include "session.hxx" - - #define ATOMPUB_URL 0 -@@ -63,7 +64,7 @@ - */ - static Session* createSession( std::map< int, std::string > params ) throw ( Exception ); - -- static std::list< std::string > getRepositories( std::map< int, std::string > params ) throw ( Exception ); -+ static std::list< RepositoryPtr > getRepositories( std::map< int, std::string > params ) throw ( Exception ); - }; - } - ---- src/libcmis/session.hxx 2012-05-31 16:49:18.000000000 +0200 -+++ src/libcmis/session.hxx 2012-07-05 11:21:22.362674743 +0200 -@@ -34,6 +34,7 @@ - #include "object-type.hxx" - #include "object.hxx" - #include "folder.hxx" -+#include "repository.hxx" - - namespace libcmis - { -@@ -56,6 +57,10 @@ - - virtual ~Session() { }; - -+ /** Get the current repository. -+ */ -+ virtual RepositoryPtr getRepository( ) throw ( Exception ) = 0; -+ - /** Get the Root folder of the repository - */ - virtual FolderPtr getRootFolder() throw ( Exception )= 0; ---- src/libcmis/test-atom.cxx 2012-05-30 16:17:44.000000000 +0200 -+++ src/libcmis/test-atom.cxx 2012-07-05 11:21:22.362674743 +0200 -@@ -34,7 +34,6 @@ - #include "atom-document.hxx" - #include "atom-folder.hxx" - #include "atom-session.hxx" --#include "atom-utils.hxx" - - // InMemory local test server data - #define SERVER_ATOM_URL string( "http://localhost:8080/inmemory/atom" ) -@@ -81,7 +80,7 @@ - #define TEST_UPDATED_PROPERTY_NAME string( "cmis:name" ) - #define TEST_UPDATED_PROPERTY_VALUE string( "New name" ) - --using namespace boost; -+using boost::shared_ptr; - using namespace std; - - class AtomTest : public CppUnit::TestFixture -@@ -153,9 +152,9 @@ - - void AtomTest::getRepositoriesTest() - { -- list< string > ids = AtomPubSession::getRepositories( SERVER_ATOM_URL, SERVER_USERNAME, SERVER_PASSWORD ); -- CPPUNIT_ASSERT_EQUAL_MESSAGE( "One repository should be found", SERVER_REPOSITORIES_COUNT, ids.size() ); -- CPPUNIT_ASSERT_EQUAL_MESSAGE( "Wrong repository found", SERVER_REPOSITORY, ids.front() ); -+ list< libcmis::RepositoryPtr > repos = AtomPubSession::getRepositories( SERVER_ATOM_URL, SERVER_USERNAME, SERVER_PASSWORD ); -+ CPPUNIT_ASSERT_EQUAL_MESSAGE( "One repository should be found", SERVER_REPOSITORIES_COUNT, repos.size() ); -+ CPPUNIT_ASSERT_EQUAL_MESSAGE( "Wrong repository found", SERVER_REPOSITORY, repos.front()->getId() ); - } - - void AtomTest::sessionCreationTest( ) -@@ -164,29 +163,29 @@ - - // Check for the mandatory collection URLs - CPPUNIT_ASSERT_MESSAGE( "root collection URL missing", -- !session.getWorkspace().getCollectionUrl( atom::Collection::Root ).empty() ); -+ !session.getAtomRepository()->getCollectionUrl( Collection::Root ).empty() ); - CPPUNIT_ASSERT_MESSAGE( "types collection URL missing", -- !session.getWorkspace().getCollectionUrl( atom::Collection::Types ).empty() ); -+ !session.getAtomRepository()->getCollectionUrl( Collection::Types ).empty() ); - CPPUNIT_ASSERT_MESSAGE( "query collection URL missing", -- !session.getWorkspace().getCollectionUrl( atom::Collection::Query ).empty() ); -+ !session.getAtomRepository()->getCollectionUrl( Collection::Query ).empty() ); - - // The optional collection URLs are present on InMemory, so check them - CPPUNIT_ASSERT_MESSAGE( "checkedout collection URL missing", -- !session.getWorkspace().getCollectionUrl( atom::Collection::CheckedOut ).empty() ); -+ !session.getAtomRepository()->getCollectionUrl( Collection::CheckedOut ).empty() ); - CPPUNIT_ASSERT_MESSAGE( "unfiled collection URL missing", -- !session.getWorkspace().getCollectionUrl( atom::Collection::Unfiled ).empty() ); -+ !session.getAtomRepository()->getCollectionUrl( Collection::Unfiled ).empty() ); - - // Check for the mandatory URI template URLs - CPPUNIT_ASSERT_MESSAGE( "objectbyid URI template URL missing", -- !session.getWorkspace().getUriTemplate( atom::UriTemplate::ObjectById ).empty() ); -+ !session.getAtomRepository()->getUriTemplate( UriTemplate::ObjectById ).empty() ); - CPPUNIT_ASSERT_MESSAGE( "objectbypath URI template URL missing", -- !session.getWorkspace().getUriTemplate( atom::UriTemplate::ObjectByPath ).empty() ); -+ !session.getAtomRepository()->getUriTemplate( UriTemplate::ObjectByPath ).empty() ); - CPPUNIT_ASSERT_MESSAGE( "typebyid URI template URL missing", -- !session.getWorkspace().getUriTemplate( atom::UriTemplate::TypeById ).empty() ); -+ !session.getAtomRepository()->getUriTemplate( UriTemplate::TypeById ).empty() ); - - // The optional URI template URL is present on InMemory, so check it - CPPUNIT_ASSERT_MESSAGE( "query URI template URL missing", -- !session.getWorkspace().getUriTemplate( atom::UriTemplate::Query ).empty() ); -+ !session.getAtomRepository()->getUriTemplate( UriTemplate::Query ).empty() ); - - // Check that the root id is defined - CPPUNIT_ASSERT_MESSAGE( "Root node ID is missing", diff --git a/libcmis/libcmis-0.2.3.patch b/libcmis/libcmis-0.2.3.patch deleted file mode 100644 index 255e8073193c..000000000000 --- a/libcmis/libcmis-0.2.3.patch +++ /dev/null @@ -1,33 +0,0 @@ ---- src/libcmis/atom-document.cxx 2012-07-02 14:39:04.815222889 +0200 -+++ src/libcmis/atom-document.cxx 2012-07-02 14:41:09.088229625 +0200 -@@ -129,15 +129,22 @@ - vector< string > AtomDocument::getPaths( ) - { - vector< string > paths; -- vector< libcmis::FolderPtr > parents = getParents( ); -- for ( vector< libcmis::FolderPtr >::iterator it = parents.begin( ); -- it != parents.end(); ++it ) -+ try - { -- string path = ( *it )->getPath( ); -- if ( path[path.size() - 1] != '/' ) -- path += "/"; -- path += getName( ); -- paths.push_back( path ); -+ vector< libcmis::FolderPtr > parents = getParents( ); -+ for ( vector< libcmis::FolderPtr >::iterator it = parents.begin( ); -+ it != parents.end(); ++it ) -+ { -+ string path = ( *it )->getPath( ); -+ if ( path[path.size() - 1] != '/' ) -+ path += "/"; -+ path += getName( ); -+ paths.push_back( path ); -+ } -+ } -+ catch ( const libcmis::Exception& ) -+ { -+ // We may not have the permission to get the parents - } - return paths; - } diff --git a/ucb/source/ucp/cmis/cmis_content.cxx b/ucb/source/ucp/cmis/cmis_content.cxx index 5d198d9ae568..afd04aebe471 100644 --- a/ucb/source/ucp/cmis/cmis_content.cxx +++ b/ucb/source/ucp/cmis/cmis_content.cxx @@ -101,26 +101,15 @@ namespace cmis m_pProvider( pProvider ), m_pSession( NULL ), m_pObject( pObject ), - m_bTransient( false ) + m_sURL( Identifier->getContentIdentifier( ) ), + m_aURL( Identifier->getContentIdentifier( ) ), + m_bTransient( false ), + m_bIsFolder( false ) { - // Split the URL into bits - m_sURL = m_xIdentifier->getContentIdentifier( ); - cmis::URL url( m_sURL ); SAL_INFO( "cmisucp", "Content::Content() " << m_sURL ); - // Look for a cached session, key is binding url + repo id - rtl::OUString sSessionId = url.getBindingUrl( ) + url.getRepositoryId( ); - m_pSession = pProvider->getSession( sSessionId ); - if ( NULL == m_pSession ) - { - // Initiate a CMIS session and register it as we found nothing - m_pSession = libcmis::SessionFactory::createSession( url.getSessionParams( ) ); - pProvider->registerSession( sSessionId, m_pSession ); - } - - m_sObjectPath = url.getObjectPath( ); - m_sObjectId = url.getObjectId( ); - m_sBindingUrl = url.getBindingUrl( ); + m_sObjectPath = m_aURL.getObjectPath( ); + m_sObjectId = m_aURL.getObjectId( ); } Content::Content( const uno::Reference< lang::XMultiServiceFactory >& rxSMgr, ContentProvider *pProvider, @@ -130,47 +119,69 @@ namespace cmis : ContentImplHelper( rxSMgr, pProvider, Identifier ), m_pProvider( pProvider ), m_pSession( NULL ), - m_bTransient( true ) + m_sURL( Identifier->getContentIdentifier( ) ), + m_aURL( Identifier->getContentIdentifier( ) ), + m_bTransient( true ), + m_bIsFolder( bIsFolder ) { - // Split the URL into bits - m_sURL = m_xIdentifier->getContentIdentifier( ); - cmis::URL url( m_sURL ); SAL_INFO( "cmisucp", "Content::Content() " << m_sURL ); + m_sObjectPath = m_aURL.getObjectPath( ); + m_sObjectId = m_aURL.getObjectId( ); + } + + Content::~Content() + { + } + + libcmis::Session* Content::getSession( const uno::Reference< ucb::XCommandEnvironment >& xEnv ) + { // Look for a cached session, key is binding url + repo id - rtl::OUString sSessionId = url.getBindingUrl( ) + url.getRepositoryId( ); - m_pSession = pProvider->getSession( sSessionId ); + rtl::OUString sSessionId = m_aURL.getBindingUrl( ) + m_aURL.getRepositoryId( ); if ( NULL == m_pSession ) - { - // Initiate a CMIS session and register it as we found nothing - m_pSession = libcmis::SessionFactory::createSession( url.getSessionParams( ) ); - pProvider->registerSession( sSessionId, m_pSession ); - } + m_pSession = m_pProvider->getSession( sSessionId ); - m_sObjectPath = url.getObjectPath( ); - m_sObjectId = url.getObjectId( ); - m_sBindingUrl = url.getBindingUrl( ); + if ( NULL == m_pSession ) + { + // Get the auth credentials + AuthProvider authProvider( xEnv, m_xIdentifier->getContentIdentifier( ), m_aURL.getBindingUrl( ) ); - // Get the object type - string typeId = bIsFolder ? "cmis:folder" : "cmis:document"; - m_pObjectType = m_pSession->getType( typeId ); + string rUsername = OUSTR_TO_STDSTR( m_aURL.getUsername( ) ); + string rPassword = OUSTR_TO_STDSTR( m_aURL.getPassword( ) ); + if ( authProvider.authenticationQuery( rUsername, rPassword ) ) + { + // Initiate a CMIS session and register it as we found nothing + m_pSession = libcmis::SessionFactory::createSession( + OUSTR_TO_STDSTR( m_aURL.getBindingUrl( ) ), + rUsername, rPassword, OUSTR_TO_STDSTR( m_aURL.getRepositoryId( ) ) ); + m_pProvider->registerSession( sSessionId, m_pSession ); + } + } + return m_pSession; } - Content::~Content() + libcmis::ObjectTypePtr Content::getObjectType( const uno::Reference< ucb::XCommandEnvironment >& xEnv ) { + if ( NULL == m_pObjectType.get( ) && m_bTransient ) + { + string typeId = m_bIsFolder ? "cmis:folder" : "cmis:document"; + m_pObjectType = getSession( xEnv )->getType( typeId ); + } + return m_pObjectType; } - libcmis::ObjectPtr Content::getObject( ) throw ( libcmis::Exception ) + + libcmis::ObjectPtr Content::getObject( const uno::Reference< ucb::XCommandEnvironment >& xEnv ) throw ( libcmis::Exception ) { if ( !m_pObject.get() ) { if ( !m_sObjectPath.isEmpty( ) ) - m_pObject = m_pSession->getObjectByPath( OUSTR_TO_STDSTR( m_sObjectPath ) ); + m_pObject = getSession( xEnv )->getObjectByPath( OUSTR_TO_STDSTR( m_sObjectPath ) ); else if (!m_sObjectId.isEmpty( ) ) - m_pObject = m_pSession->getObject( OUSTR_TO_STDSTR( m_sObjectId ) ); + m_pObject = getSession( xEnv )->getObject( OUSTR_TO_STDSTR( m_sObjectId ) ); else { - m_pObject = m_pSession->getRootFolder( ); + m_pObject = getSession( xEnv )->getRootFolder( ); m_sObjectPath = "/"; m_sObjectId = rtl::OUString( ); } @@ -179,19 +190,12 @@ namespace cmis return m_pObject; } - void Content::resetAuthProvider( const uno::Reference< ucb::XCommandEnvironment >& xEnv ) - { - libcmis::AuthProviderPtr authProvider( new AuthProvider( xEnv, m_sURL, m_sBindingUrl ) ); - m_pSession->setAuthenticationProvider( authProvider ); - } - bool Content::isFolder(const uno::Reference< ucb::XCommandEnvironment >& xEnv ) { bool bIsFolder = false; try { - resetAuthProvider( xEnv ); - bIsFolder = getObject( )->getBaseType( ) == "cmis:folder"; + bIsFolder = getObject( xEnv )->getBaseType( ) == "cmis:folder"; } catch ( const libcmis::Exception& e ) { @@ -216,8 +220,6 @@ namespace cmis const uno::Sequence< beans::Property >& rProperties, const uno::Reference< ucb::XCommandEnvironment >& xEnv ) { - resetAuthProvider( xEnv ); - rtl::Reference< ::ucbhelper::PropertyValueSet > xRow = new ::ucbhelper::PropertyValueSet( m_xSMgr ); sal_Int32 nProps; @@ -236,12 +238,12 @@ namespace cmis { try { - xRow->appendBoolean( rProp, getObject()->getBaseType( ) == "cmis:document" ); + xRow->appendBoolean( rProp, getObject( xEnv )->getBaseType( ) == "cmis:document" ); } catch ( const libcmis::Exception& ) { if ( m_pObjectType.get( ) ) - xRow->appendBoolean( rProp, m_pObjectType->getBaseType()->getId( ) == "cmis:document" ); + xRow->appendBoolean( rProp, getObjectType( xEnv )->getBaseType()->getId( ) == "cmis:document" ); else xRow->appendVoid( rProp ); } @@ -250,12 +252,12 @@ namespace cmis { try { - xRow->appendBoolean( rProp, getObject()->getBaseType( ) == "cmis:folder" ); + xRow->appendBoolean( rProp, getObject( xEnv )->getBaseType( ) == "cmis:folder" ); } catch ( const libcmis::Exception& ) { if ( m_pObjectType.get( ) ) - xRow->appendBoolean( rProp, m_pObjectType->getBaseType()->getId( ) == "cmis:folder" ); + xRow->appendBoolean( rProp, getObjectType( xEnv )->getBaseType()->getId( ) == "cmis:folder" ); else xRow->appendVoid( rProp ); } @@ -265,7 +267,7 @@ namespace cmis rtl::OUString sTitle; try { - sTitle = STD_TO_OUSTR( getObject()->getName() ); + sTitle = STD_TO_OUSTR( getObject( xEnv )->getName() ); } catch ( const libcmis::Exception& ) { @@ -306,11 +308,11 @@ namespace cmis string path; try { - vector< string > paths = getObject( )->getPaths( ); + vector< string > paths = getObject( xEnv )->getPaths( ); if ( !paths.empty( ) ) path = paths.front( ); else - path = getObject()->getName( ); + path = getObject( xEnv )->getName( ); xRow->appendString( rProp, STD_TO_OUSTR( path ) ); } @@ -321,7 +323,7 @@ namespace cmis } else if ( rProp.Name == "IsReadOnly" ) { - boost::shared_ptr< libcmis::AllowableActions > allowableActions = getObject()->getAllowableActions( ); + boost::shared_ptr< libcmis::AllowableActions > allowableActions = getObject( xEnv )->getAllowableActions( ); sal_Bool bReadOnly = sal_False; if ( !allowableActions->isAllowed( libcmis::ObjectAction::SetContentStream ) ) bReadOnly = sal_True; @@ -330,19 +332,19 @@ namespace cmis } else if ( rProp.Name == "DateCreated" ) { - util::DateTime aTime = lcl_boostToUnoTime( getObject( )->getCreationDate( ) ); + util::DateTime aTime = lcl_boostToUnoTime( getObject( xEnv )->getCreationDate( ) ); xRow->appendTimestamp( rProp, aTime ); } else if ( rProp.Name == "DateModified" ) { - util::DateTime aTime = lcl_boostToUnoTime( getObject( )->getLastModificationDate( ) ); + util::DateTime aTime = lcl_boostToUnoTime( getObject( xEnv )->getLastModificationDate( ) ); xRow->appendTimestamp( rProp, aTime ); } else if ( rProp.Name == "Size" ) { try { - libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject().get( ) ); + libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject( xEnv ).get( ) ); if ( NULL != document ) xRow->appendLong( rProp, document->getContentLength() ); else @@ -361,7 +363,7 @@ namespace cmis { try { - libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject().get( ) ); + libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject( xEnv ).get( ) ); if ( NULL != document ) xRow->appendString( rProp, STD_TO_OUSTR( document->getContentType() ) ); else @@ -384,7 +386,7 @@ namespace cmis return uno::Reference< sdbc::XRow >( xRow.get() ); } - bool Content::exists( ) + bool Content::exists( const uno::Reference< ucb::XCommandEnvironment >& xEnv ) { bool bExists = true; try @@ -392,7 +394,7 @@ namespace cmis if ( !m_sObjectPath.isEmpty( ) ) m_pSession->getObjectByPath( OUSTR_TO_STDSTR( m_sObjectPath ) ); else if ( !m_sObjectId.isEmpty( ) ) - m_pSession->getObject( OUSTR_TO_STDSTR( m_sObjectId ) ); + getSession( xEnv )->getObject( OUSTR_TO_STDSTR( m_sObjectId ) ); // No need to handle the root folder case... how can it not exists? } catch ( const libcmis::Exception& ) @@ -410,7 +412,7 @@ namespace cmis bool bIsFolder = isFolder( xEnv ); // Handle the case of the non-existing file - if ( !exists( ) ) + if ( !exists( xEnv ) ) { uno::Sequence< uno::Any > aArgs( 1 ); aArgs[ 0 ] <<= m_xIdentifier->getContentIdentifier(); @@ -480,7 +482,7 @@ namespace cmis if ( aSourceUrl.GetProtocol() != INET_PROT_CMIS_ATOM ) { rtl::OUString sSrcBindingUrl = URL( rTransferInfo.SourceURL ).getBindingUrl( ); - if ( sSrcBindingUrl != m_sBindingUrl ) + if ( sSrcBindingUrl != m_aURL.getBindingUrl( ) ) { ucbhelper::cancelCommandExecution( uno::makeAny( @@ -516,7 +518,7 @@ namespace cmis libcmis::Folder* pFolder = NULL; try { - pFolder = dynamic_cast< libcmis::Folder* >( getObject( ).get( ) ); + pFolder = dynamic_cast< libcmis::Folder* >( getObject( xEnv ).get( ) ); } catch ( const libcmis::Exception& ) { @@ -541,7 +543,7 @@ namespace cmis libcmis::ObjectPtr object; try { - object = m_pSession->getObjectByPath( newPath ); + object = getSession( xEnv )->getObjectByPath( newPath ); sNewPath = STD_TO_OUSTR( newPath ); } catch ( const libcmis::Exception& ) @@ -568,14 +570,14 @@ namespace cmis boost::shared_ptr< ostream > pOut( new ostringstream ( ios_base::binary | ios_base::in | ios_base::out ) ); uno::Reference < io::XOutputStream > xOutput = new ucbhelper::StdOutputStream( pOut ); copyData( xInputStream, xOutput ); - document->setContentStream( pOut, sMime, bReplaceExisting ); + document->setContentStream( pOut, sMime, string( ), bReplaceExisting ); } } else { // We need to create a brand new object... either folder or document - bool bIsFolder = m_pObjectType->getBaseType( )->getId( ) == "cmis:folder"; - setCmisProperty( "cmis:objectTypeId", m_pObjectType->getId( ) ); + bool bIsFolder = getObjectType( xEnv )->getBaseType( )->getId( ) == "cmis:folder"; + setCmisProperty( "cmis:objectTypeId", getObjectType( xEnv )->getId( ), xEnv ); if ( bIsFolder ) { @@ -587,7 +589,7 @@ namespace cmis boost::shared_ptr< ostream > pOut( new ostringstream ( ios_base::binary | ios_base::in | ios_base::out ) ); uno::Reference < io::XOutputStream > xOutput = new ucbhelper::StdOutputStream( pOut ); copyData( xInputStream, xOutput ); - libcmis::DocumentPtr pNew = pFolder->createDocument( m_pObjectProps, pOut, string() ); + pFolder->createDocument( m_pObjectProps, pOut, string(), string() ); sNewPath = STD_TO_OUSTR( newPath ); } } @@ -631,10 +633,10 @@ namespace cmis try { // Get the already set properties if possible - if ( !m_bTransient && getObject( ).get( ) ) + if ( !m_bTransient && getObject( xEnv ).get( ) ) { - m_pObjectProps = getObject()->getProperties( ); - m_pObjectType = getObject()->getTypeDescription(); + m_pObjectProps.clear( ); + m_pObjectType = getObject( xEnv )->getTypeDescription(); } } catch ( const libcmis::Exception& e ) @@ -686,7 +688,7 @@ namespace cmis } - setCmisProperty( "cmis:name", OUSTR_TO_STDSTR( aNewTitle ) ); + setCmisProperty( "cmis:name", OUSTR_TO_STDSTR( aNewTitle ), xEnv ); bChanged = true; } else @@ -702,7 +704,7 @@ namespace cmis { if ( !m_bTransient && bChanged ) { - getObject()->updateProperties(); + getObject( xEnv )->updateProperties( m_pObjectProps ); } } catch ( const libcmis::Exception& e ) @@ -736,7 +738,7 @@ namespace cmis try { - libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject().get() ); + libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject( xEnv ).get() ); boost::shared_ptr< istream > aIn = document->getContentStream( ); uno::Reference< io::XInputStream > xIn = new ucbhelper::StdInputStream( aIn ); @@ -762,10 +764,8 @@ namespace cmis } uno::Sequence< beans::Property > Content::getProperties( - const uno::Reference< ucb::XCommandEnvironment > & xEnv ) + const uno::Reference< ucb::XCommandEnvironment > & ) { - resetAuthProvider( xEnv ); - static const beans::Property aGenericProperties[] = { beans::Property( rtl::OUString( RTL_CONSTASCII_USTRINGPARAM( "IsDocument" ) ), @@ -807,8 +807,6 @@ namespace cmis uno::Sequence< ucb::CommandInfo > Content::getCommands( const uno::Reference< ucb::XCommandEnvironment > & xEnv ) { - resetAuthProvider( xEnv ); - static ucb::CommandInfo aCommandInfoTable[] = { // Required commands @@ -845,8 +843,8 @@ namespace cmis -1, getCppuType( static_cast<ucb::ContentInfo * >( 0 ) ) ) }; - const int nProps = SAL_N_ELEMENTS(aCommandInfoTable); - return uno::Sequence< ucb::CommandInfo >(aCommandInfoTable, isFolder(xEnv) ? nProps : nProps - 2); + const int nProps = SAL_N_ELEMENTS( aCommandInfoTable ); + return uno::Sequence< ucb::CommandInfo >(aCommandInfoTable, isFolder( xEnv ) ? nProps : nProps - 2); } ::rtl::OUString Content::getParentURL( ) @@ -858,8 +856,8 @@ namespace cmis string parentPath; try { - libcmis::ObjectPtr pObj = getObject( ); - libcmis::Document* document = dynamic_cast< libcmis::Document* >( getObject( ).get( ) ); + libcmis::ObjectPtr pObj = getObject( uno::Reference< ucb::XCommandEnvironment >() ); + libcmis::Document* document = dynamic_cast< libcmis::Document* >( pObj.get( ) ); if ( NULL != document ) { vector< boost::shared_ptr< libcmis::Folder > > parents = document->getParents( ); @@ -868,7 +866,7 @@ namespace cmis } else { - libcmis::Folder* folder = dynamic_cast< libcmis::Folder* >( getObject( ).get( ) ); + libcmis::Folder* folder = dynamic_cast< libcmis::Folder* >( pObj.get( ) ); if ( NULL != folder ) parentPath = folder->getFolderParent( )->getPath( ); } @@ -933,7 +931,7 @@ namespace cmis rtl::OUString SAL_CALL Content::getContentType() throw( uno::RuntimeException ) { - return isFolder(uno::Reference< ucb::XCommandEnvironment >()) + return isFolder( uno::Reference< ucb::XCommandEnvironment >() ) ? rtl::OUString(RTL_CONSTASCII_USTRINGPARAM( CMIS_FOLDER_TYPE )) : rtl::OUString(RTL_CONSTASCII_USTRINGPARAM( CMIS_FILE_TYPE )); } @@ -945,8 +943,6 @@ namespace cmis throw( uno::Exception, ucb::CommandAbortedException, uno::RuntimeException ) { SAL_INFO( "cmisucp", "Content::execute( ) - " << aCommand.Name ); - resetAuthProvider( xEnv ); - uno::Any aRet; if ( aCommand.Name == "getPropertyValues" ) @@ -1002,11 +998,11 @@ namespace cmis { if ( !isFolder( xEnv ) ) { - getObject( )->remove( ); + getObject( xEnv )->remove( ); } else { - libcmis::Folder* folder = dynamic_cast< libcmis::Folder* >( getObject( ).get() ); + libcmis::Folder* folder = dynamic_cast< libcmis::Folder* >( getObject( xEnv ).get() ); folder->removeTree( ); } } @@ -1118,7 +1114,6 @@ namespace cmis const uno::Reference< ucb::XCommandEnvironment >& xEnv) throw( uno::RuntimeException ) { - resetAuthProvider( xEnv ); if ( isFolder( xEnv ) ) { uno::Sequence< ucb::ContentInfo > seq(2); @@ -1155,7 +1150,7 @@ namespace cmis list< uno::Reference< ucb::XContent > > results; SAL_INFO( "cmisucp", "Content::getChildren() " << m_sURL ); - libcmis::Folder* pFolder = dynamic_cast< libcmis::Folder* >( getObject( ).get( ) ); + libcmis::Folder* pFolder = dynamic_cast< libcmis::Folder* >( getObject( uno::Reference< ucb::XCommandEnvironment >() ).get( ) ); if ( NULL != pFolder ) { // Get the children from pObject @@ -1190,17 +1185,17 @@ namespace cmis return results; } - void Content::setCmisProperty( std::string sName, std::string sValue ) + void Content::setCmisProperty( std::string sName, std::string sValue, const uno::Reference< ucb::XCommandEnvironment >& xEnv ) { - if ( m_pObjectType.get( ) ) + if ( getObjectType( xEnv ).get( ) ) { map< string, libcmis::PropertyPtr >::iterator propIt = m_pObjectProps.find( sName ); vector< string > values; values.push_back( sValue ); - if ( propIt == m_pObjectProps.end( ) && m_pObjectType.get( ) ) + if ( propIt == m_pObjectProps.end( ) && getObjectType( xEnv ).get( ) ) { - map< string, libcmis::PropertyTypePtr > propsTypes = m_pObjectType->getPropertiesTypes( ); + map< string, libcmis::PropertyTypePtr > propsTypes = getObjectType( xEnv )->getPropertiesTypes( ); map< string, libcmis::PropertyTypePtr >::iterator typeIt = propsTypes.find( sName ); if ( typeIt != propsTypes.end( ) ) diff --git a/ucb/source/ucp/cmis/cmis_content.hxx b/ucb/source/ucp/cmis/cmis_content.hxx index 2b5c6b2a5fec..3273517042cc 100644 --- a/ucb/source/ucp/cmis/cmis_content.hxx +++ b/ucb/source/ucp/cmis/cmis_content.hxx @@ -76,15 +76,17 @@ private: rtl::OUString m_sObjectPath; rtl::OUString m_sObjectId; rtl::OUString m_sURL; - rtl::OUString m_sBindingUrl; + cmis::URL m_aURL; // Members to be set for non-persistent content bool m_bTransient; + bool m_bIsFolder; libcmis::ObjectTypePtr m_pObjectType; std::map< std::string, libcmis::PropertyPtr > m_pObjectProps; - bool isFolder(const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv); - void setCmisProperty( std::string sName, std::string sValue ); + bool isFolder( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); + void setCmisProperty( std::string sName, std::string sValue, + const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); com::sun::star::uno::Any getBadArgExcept(); @@ -93,7 +95,10 @@ private: const com::sun::star::uno::Sequence< com::sun::star::beans::Property >& rProperties, const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); - bool exists( ); + libcmis::Session* getSession( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); + libcmis::ObjectTypePtr getObjectType( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); + + bool exists( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); private: typedef rtl::Reference< Content > ContentRef; @@ -125,8 +130,6 @@ private: sal_Bool feedSink( com::sun::star::uno::Reference< com::sun::star::uno::XInterface> aSink, const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); - void resetAuthProvider( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ); - public: Content( const com::sun::star::uno::Reference< com::sun::star::lang::XMultiServiceFactory >& rxSMgr, ContentProvider *pProvider, @@ -191,7 +194,7 @@ public: virtual std::list< com::sun::star::uno::Reference< com::sun::star::ucb::XContent > > getChildren( ); - libcmis::ObjectPtr getObject( ) throw ( libcmis::Exception ); + libcmis::ObjectPtr getObject( const com::sun::star::uno::Reference< com::sun::star::ucb::XCommandEnvironment >& xEnv ) throw ( libcmis::Exception ); }; } diff --git a/ucb/source/ucp/cmis/cmis_repo_content.cxx b/ucb/source/ucp/cmis/cmis_repo_content.cxx index 410f7b53d4d9..791cf6efdf81 100644 --- a/ucb/source/ucp/cmis/cmis_repo_content.cxx +++ b/ucb/source/ucp/cmis/cmis_repo_content.cxx @@ -147,13 +147,10 @@ namespace cmis string rPassword = OUSTR_TO_STDSTR( m_aURL.getPassword( ) ); if ( authProvider.authenticationQuery( rUsername, rPassword ) ) { - map< int, string > params = m_aURL.getSessionParams( ); - params[USERNAME] = rUsername; - params[PASSWORD] = rPassword; - try { - m_aRepositories = libcmis::SessionFactory::getRepositories( params ); + m_aRepositories = libcmis::SessionFactory::getRepositories( + OUSTR_TO_STDSTR( m_aURL.getBindingUrl( ) ), rUsername, rPassword ); } catch (const libcmis::Exception&) { diff --git a/ucb/source/ucp/cmis/cmis_url.cxx b/ucb/source/ucp/cmis/cmis_url.cxx index 3357a247c3ed..e184d709d745 100644 --- a/ucb/source/ucp/cmis/cmis_url.cxx +++ b/ucb/source/ucp/cmis/cmis_url.cxx @@ -63,17 +63,6 @@ namespace cmis m_sPath = rtl::OUString( ); } - map< int, string > URL::getSessionParams( ) - { - map< int, string > params; - params[ATOMPUB_URL] = OUSTR_TO_STDSTR( m_sBindingUrl ); - params[REPOSITORY_ID] = OUSTR_TO_STDSTR( m_sRepositoryId ); - params[USERNAME] = OUSTR_TO_STDSTR( m_sUser ); - params[PASSWORD] = OUSTR_TO_STDSTR( m_sPass ); - - return params; - } - rtl::OUString& URL::getObjectPath( ) { return m_sPath; diff --git a/ucb/source/ucp/cmis/cmis_url.hxx b/ucb/source/ucp/cmis/cmis_url.hxx index aa3d93ce4fa0..6283d7aa874e 100644 --- a/ucb/source/ucp/cmis/cmis_url.hxx +++ b/ucb/source/ucp/cmis/cmis_url.hxx @@ -49,7 +49,6 @@ namespace cmis public: URL( rtl::OUString const & urlStr ); - std::map< int, std::string > getSessionParams( ); rtl::OUString& getObjectPath( ); rtl::OUString& getObjectId( ); rtl::OUString& getBindingUrl( ); |