/************************************************************************* * * OpenOffice.org - a multi-platform office productivity suite * * $RCSfile: NeonHeadRequest.cxx,v $ * * $Revision: 1.10 $ * * last change: $Author: rt $ $Date: 2008-02-19 12:34:28 $ * * The Contents of this file are made available subject to * the terms of GNU Lesser General Public License Version 2.1. * * * GNU Lesser General Public License Version 2.1 * ============================================= * Copyright 2005 by Sun Microsystems, Inc. * 901 San Antonio Road, Palo Alto, CA 94303, USA * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License version 2.1, as published by the Free Software Foundation. * * This library 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 for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, * MA 02111-1307 USA * ************************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_ucb.hxx" #ifndef _OSL_DIAGNOSE_H_ #include #endif #ifndef _COM_SUN_STAR_BEANS_PROPERTYVALUE_HPP_ #include #endif #ifndef _COM_SUN_STAR_BEANS_PROPERTYSTATE_HPP_ #include #endif #ifndef _NEONHEADREQUEST_HXX_ #include "NeonHeadRequest.hxx" #endif using namespace webdav_ucp; using namespace com::sun::star; namespace { #if NEON_VERSION >= 0x0250 void process_headers(ne_request *req, DAVResource &rResource, const std::vector< ::rtl::OUString > &rHeaderNames) { void *cursor = NULL; const char *name, *value; while ((cursor = ne_response_header_iterate(req, cursor, &name, &value)) != NULL) { rtl::OUString aHeaderName( rtl::OUString::createFromAscii( name ) ); rtl::OUString aHeaderValue( rtl::OUString::createFromAscii( value ) ); // Note: Empty vector means that all headers are requested. bool bIncludeIt = ( rHeaderNames.size() == 0 ); if ( !bIncludeIt ) { // Check whether this header was requested. std::vector< ::rtl::OUString >::const_iterator it( rHeaderNames.begin() ); const std::vector< ::rtl::OUString >::const_iterator end( rHeaderNames.end() ); while ( it != end ) { if ( (*it) == aHeaderName ) break; ++it; } if ( it != end ) bIncludeIt = true; } if ( bIncludeIt ) { // Create & set the PropertyValue DAVPropertyValue thePropertyValue; thePropertyValue.Name = aHeaderName; thePropertyValue.IsCaseSensitive = false; thePropertyValue.Value <<= aHeaderValue; // Add the newly created PropertyValue rResource.properties.push_back( thePropertyValue ); } } } #else struct NeonHeadRequestContext { DAVResource * pResource; const std::vector< ::rtl::OUString > * pHeaderNames; NeonHeadRequestContext( DAVResource * p, const std::vector< ::rtl::OUString > * pHeaders ) : pResource( p ), pHeaderNames( pHeaders ) {} }; extern "C" void NHR_ResponseHeaderCatcher( void * userdata, const char * value ) { rtl::OUString aHeader( rtl::OUString::createFromAscii( value ) ); sal_Int32 nPos = aHeader.indexOf( ':' ); if ( nPos != -1 ) { rtl::OUString aHeaderName( aHeader.copy( 0, nPos ) ); NeonHeadRequestContext * pCtx = static_cast< NeonHeadRequestContext * >( userdata ); // Note: Empty vector means that all headers are requested. bool bIncludeIt = ( pCtx->pHeaderNames->size() == 0 ); if ( !bIncludeIt ) { // Check whether this header was requested. std::vector< ::rtl::OUString >::const_iterator it( pCtx->pHeaderNames->begin() ); const std::vector< ::rtl::OUString >::const_iterator end( pCtx->pHeaderNames->end() ); while ( it != end ) { if ( (*it) == aHeaderName ) break; ++it; } if ( it != end ) bIncludeIt = true; } if ( bIncludeIt ) { // Create & set the PropertyValue DAVPropertyValue thePropertyValue; thePropertyValue.Name = aHeaderName; thePropertyValue.IsCaseSensitive = false; if ( nPos < aHeader.getLength() ) thePropertyValue.Value <<= aHeader.copy( nPos + 1 ).trim(); // Add the newly created PropertyValue pCtx->pResource->properties.push_back( thePropertyValue ); } } } #endif } // namespace // ------------------------------------------------------------------- // Constructor // ------------------------------------------------------------------- NeonHeadRequest::NeonHeadRequest( HttpSession* inSession, const rtl::OUString & inPath, const std::vector< ::rtl::OUString > & inHeaderNames, DAVResource & ioResource, int & nError ) { ioResource.uri = inPath; ioResource.properties.clear(); // Create and dispatch HEAD request. Install catcher for all response // header fields. ne_request * req = ne_request_create( inSession, "HEAD", rtl::OUStringToOString( inPath, RTL_TEXTENCODING_UTF8 ) ); #if NEON_VERSION < 0x0250 NeonHeadRequestContext aCtx( &ioResource, &inHeaderNames ); ne_add_response_header_catcher( req, NHR_ResponseHeaderCatcher, &aCtx ); #endif nError = ne_request_dispatch( req ); #if NEON_VERSION >= 0x0250 process_headers(req, ioResource, inHeaderNames); #endif if ( nError == NE_OK && ne_get_status( req )->klass != 2 ) nError = NE_ERROR; ne_request_destroy( req ); } // ------------------------------------------------------------------- // Destructor // ------------------------------------------------------------------- NeonHeadRequest::~NeonHeadRequest() { }