/************************************************************** * * 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. * *************************************************************/ // MARKER(update_precomp.py): autogen include statement, do not remove #include "precompiled_ucb.hxx" #include #include #include #include #include using namespace com::sun::star; namespace http_dav_ucp { SerfPropFindReqProcImpl::SerfPropFindReqProcImpl( const char* inPath, const Depth inDepth, const std::vector< ::rtl::OUString > & inPropNames, std::vector< DAVResource > & ioResources ) : SerfRequestProcessorImpl( inPath ) , mDepthStr( 0 ) , mpPropNames( &inPropNames ) , mpResources( &ioResources ) , mpResInfo( 0 ) , mbOnlyPropertyNames( false ) , xInputStream( new SerfInputStream() ) { init( inDepth ); } SerfPropFindReqProcImpl::SerfPropFindReqProcImpl( const char* inPath, const Depth inDepth, std::vector< DAVResourceInfo > & ioResInfo ) : SerfRequestProcessorImpl( inPath ) , mDepthStr( 0 ) , mpPropNames( 0 ) , mpResources( 0 ) , mpResInfo( &ioResInfo ) , mbOnlyPropertyNames( true ) , xInputStream( new SerfInputStream() ) { init( inDepth ); } void SerfPropFindReqProcImpl::init( const Depth inDepth ) { switch ( inDepth ) { case DAVZERO: mDepthStr = "0"; break; case DAVONE: mDepthStr = "1"; break; case DAVINFINITY: mDepthStr = "infinity"; break; } } SerfPropFindReqProcImpl::~SerfPropFindReqProcImpl() { } #define PROPFIND_HEADER "" #define PROPFIND_TRAILER "" serf_bucket_t * SerfPropFindReqProcImpl::createSerfRequestBucket( serf_request_t * inSerfRequest ) { serf_bucket_alloc_t* pSerfBucketAlloc = serf_request_get_alloc( inSerfRequest ); // body bucket - certain properties OR all properties OR only property names serf_bucket_t* body_bkt = 0; sal_Int32 nDataLen = 0; { // create and fill body bucket with requested properties body_bkt = serf_bucket_aggregate_create( pSerfBucketAlloc ); serf_bucket_t* tmp = 0; const int nPropCount = ( !mbOnlyPropertyNames && mpPropNames ) ? mpPropNames->size() : 0; if ( nPropCount > 0 ) { SerfPropName thePropName; for ( int theIndex = 0; theIndex < nPropCount; theIndex ++ ) { // split fullname into namespace and name! DAVProperties::createSerfPropName( (*mpPropNames)[ theIndex ], thePropName ); /* <*propname* xmlns="*propns*" /> */ tmp = SERF_BUCKET_SIMPLE_STRING_LEN("<", 1, pSerfBucketAlloc ); serf_bucket_aggregate_append( body_bkt, tmp ); nDataLen += 1; tmp = SERF_BUCKET_SIMPLE_STRING( thePropName.name, pSerfBucketAlloc ); serf_bucket_aggregate_append( body_bkt, tmp ); nDataLen += strlen(thePropName.name); tmp = SERF_BUCKET_SIMPLE_STRING_LEN( " xmlns=\"", sizeof(" xmlns=\"")-1, pSerfBucketAlloc ); serf_bucket_aggregate_append( body_bkt, tmp ); nDataLen += sizeof(" xmlns=\"")-1; tmp = SERF_BUCKET_SIMPLE_STRING( thePropName.nspace, pSerfBucketAlloc ); serf_bucket_aggregate_append( body_bkt, tmp ); nDataLen += strlen(thePropName.nspace); tmp = SERF_BUCKET_SIMPLE_STRING_LEN( "\"/>", sizeof("\"/>")-1, pSerfBucketAlloc ); serf_bucket_aggregate_append( body_bkt, tmp ); nDataLen += sizeof("\"/>")-1; } tmp = SERF_BUCKET_SIMPLE_STRING_LEN("", sizeof("")-1, pSerfBucketAlloc ); serf_bucket_aggregate_prepend(body_bkt, tmp); nDataLen += sizeof("")-1; tmp = SERF_BUCKET_SIMPLE_STRING_LEN("", sizeof("")-1, pSerfBucketAlloc ); serf_bucket_aggregate_append(body_bkt, tmp); nDataLen += sizeof("")-1; } else { if ( mbOnlyPropertyNames ) { tmp = SERF_BUCKET_SIMPLE_STRING_LEN( "", sizeof("")-1, pSerfBucketAlloc ); nDataLen += sizeof("")-1; } else { tmp = SERF_BUCKET_SIMPLE_STRING_LEN( "", sizeof("")-1, pSerfBucketAlloc ); nDataLen += sizeof("")-1; } serf_bucket_aggregate_append( body_bkt, tmp ); } tmp = SERF_BUCKET_SIMPLE_STRING_LEN( PROPFIND_HEADER, sizeof(PROPFIND_HEADER)-1, pSerfBucketAlloc ); serf_bucket_aggregate_prepend(body_bkt, tmp); nDataLen += sizeof(PROPFIND_HEADER)-1; tmp = SERF_BUCKET_SIMPLE_STRING_LEN(PROPFIND_TRAILER, sizeof(PROPFIND_TRAILER)-1, pSerfBucketAlloc ); serf_bucket_aggregate_append(body_bkt, tmp); nDataLen += sizeof(PROPFIND_TRAILER)-1; } // create serf request serf_bucket_t *req_bkt = serf_request_bucket_request_create( inSerfRequest, "PROPFIND", getPathStr(), body_bkt, serf_request_get_alloc( inSerfRequest ) ); // TODO - correct header data // set request header fields serf_bucket_t* hdrs_bkt = serf_bucket_request_get_headers( req_bkt ); serf_bucket_headers_setn( hdrs_bkt, "User-Agent", "www.openoffice.org/ucb/" ); serf_bucket_headers_setn( hdrs_bkt, "Accept-Encoding", "gzip"); // request specific header fields serf_bucket_headers_setn( hdrs_bkt, "Depth", mDepthStr ); serf_bucket_headers_setn( hdrs_bkt, "Content-Type", "application/xml" ); serf_bucket_headers_setn( hdrs_bkt, "Content-Length", rtl::OUStringToOString( rtl::OUString::valueOf( nDataLen ), RTL_TEXTENCODING_UTF8 ) ); return req_bkt; } bool SerfPropFindReqProcImpl::processSerfResponseBucket( serf_request_t * /*inSerfRequest*/, serf_bucket_t * inSerfResponseBucket, apr_pool_t * /*inAprPool*/, apr_status_t & outStatus ) { const char* data; apr_size_t len; while (1) { outStatus = serf_bucket_read(inSerfResponseBucket, 2048, &data, &len); if (SERF_BUCKET_READ_ERROR(outStatus)) { return true; } if ( len > 0 ) { xInputStream->AddToStream( data, len ); } /* are we done yet? */ if (APR_STATUS_IS_EOF(outStatus)) { if ( mbOnlyPropertyNames ) { const std::vector< DAVResourceInfo > rResInfo( parseWebDAVPropNameResponse( xInputStream.get() ) ); *mpResInfo = rResInfo; } else { const std::vector< DAVResource > rResources( parseWebDAVPropFindResponse( xInputStream.get() ) ); *mpResources = rResources; } outStatus = APR_EOF; return true; } /* have we drained the response so far? */ if ( APR_STATUS_IS_EAGAIN( outStatus ) ) { return false; } } /* NOTREACHED */ return true; } } // namespace http_dav_ucp