PerlDAV -- A WebDAV client library for Perl5 PerlDAV is a Perl library for modifying content on webservers using the WebDAV protocol. Now you can LOCK, DELETE and PUT files and much more on a DAV-enabled webserver. The PerlDAV library consists of: * HTTP::DAV - an object-oriented Web-DAV client API. * dave - the DAV Explorer, an end-user Unix console program for interacting with WebDAV servers. dave looks and feels like a standard Unix ftp program. Learn more about WebDAV at http://www.webdav.org/ LATEST VERSION AND WHAT'S NEW The latest version is: v0.36 (released 2009/02/25) Download: http://search.cpan.org/dist/HTTP-DAV/ * bug fixes Fixed RT #19616 (http://rt.cpan.org/Public/Bug/Display.html?id=19616), LWP::UserAgent::redirect_ok() is not changed anymore. We're subclassing it from HTTP::DAV::UserAgent and overriding redirect_ok() there. * bug fixes Fixed RT #42877 (http://rt.cpan.org/Public/Bug/Display.html?id=42877), HTTP::DAV::UserAgent::credentials() has been modified to behave like LWP::UserAgent::credentials(), otherwise basic authentication breakages can occur. * bug fixes Fixed a problem with "-depth" argument to "HTTP::DAV::propfind()" that could lead to massive performance degradation, especially when running "propfind()" against large folders. "-depth" was set to 1 even when passed as zero. * bug fixes - Fixed RT #40318 (http://rt.cpan.org/Public/Bug/Display.html?id=40318), about getting single or multiple files directly to \*STDOUT. * bug fixes - Fixed RT #39150 (http://rt.cpan.org/Public/Bug/Display.html?id=39150), about downloading multiple files in the same directory. * documentation - Clearly state that Opera Software ASA is now co-maintainer of HTTP::DAV - Fixed various inconsistencies in the v0.32 documentation * incompatibilities - Now HTTP::DAV requires Perl 5.6.0+ and Scalar::Util (core in 5.8.x). * bug fixes - Now HTTP::DAV objects are correctly released from memory when they go out of scope. Now it should be possible to use multiple instances of HTTP::DAV even in long-running processes. Was caused by circular references between HTTP::DAV and HTTP::DAV::Resource. * Windows support - Multiple people have confirmed that PerlDAV install and runs under Windows (subject to fixing the binmode bug below). * Apache 2 mod_dav support - Now works with mod_dav under Apache 2. See the Changes file for previous releases. INSTALLING PERLDAV The lazy way to install PerlDAV: $ perl -MCPAN -e shell cpan> install HTTP::DAV Or the normal way: Retrieve the latest copy from CPAN: http://www.cpan.org/authors/id/P/PC/PCOLLINS/ $ perl Makefile.PL # Creates the Makefile $ make # Runs the makefile $ make test # Optional (See Interopability below) $ make install # Installs dave and HTTP::DAV With this method you will first have to install the pre-requisites: LWP and XML::DOM, see "what are the prerequisites?". When you install PerlDAV, the HTTP::DAV library will be installed to your Perl library location (usually /usr/local/lib/perl5) "dave" will be installed to /usr/local/bin. This suits most people but you can modify this by using the INSTALLBIN flag: $ perl Makefile.PL INSTALLBIN="/home/pcollins/bin" What Are The Prerequisites? * Perl 5.6.0+ * LWP (Have not tested lower than v5.48) * Scalar::Util (standard library from 5.8.0+) * XML::DOM (Have not tested lower than v1.26). Requires James Clark's expat library: Optional Prerequisites. * Crypt::SSLeay if you'd like to use https. Crypt::SSLeay requires the openssl library as well. See Crypt::SSLeay's excellent install instructions for how to get https support into LWP (and hence HTTP::DAV). I've tested HTTP::DAV and Crypt::SSLeay against Apache/mod_dav with the mod_ssl plugin. Works seamlessly. * MD5 if you'd like to use LWP's Digest authentication. To get the latest versions of these prerequisite modules you can simply type this at the command prompt: $ then: $ perl -MCPAN -e shell cpan> install LWP cpan> install XML::DOM or if you just 'install HTTP::DAV' the lovely CPAN module should just magically install all of the prerequisites for you (you'll still need to manually instal expat though). What Systems Does It Work With? HTTP::DAV and dave are pure perl so only needs Perl 5.6.0 (or later). PerlDAV is known to run under Windows (although I haven't tried it myself) and should run under all Unix systems. WHERE ARE THE MANUALS? Once you've installed PerlDAV, you can type: $ perldoc HTTP::DAV $ man dave GETTING HELP The perldav mailing list There is a mailing list for PerlDAV for use by Developers and Users. Please see http://mailman.webdav.org/mailman/listinfo/perldav THE TEST SUITE & INTEROPERABILITY You will notice that the standard "make test" command invokes a large set of test procedures, but most will be skipped. This standard test is sufficient to give you a good indication that PerlDAV has installed properly. If you'd like to see how well PerlDAV performs against a particular DAV server then you should set the URL (and username,password) in the test suite t/TestDetails.pm. Then you can run "make test" again and watch the test suite perform as many operations as the server supports. Please note that the test suite will perofrm well over 200 HTTP requests to your server. I have tested PerlDAV against IIS5, mod_dav and the Xythos WFS. Out of the box, the test suite should NOT fail on any tests. The test suite is the best way to test interopability between PerlDAV and other servers. I'd really like help with testing PerlDAV's interoperability. So if one or more tests fail against your server please follow the following steps: * Determine which test is failing. * set DEBUG to on: edit the script and change HTTP::DAV::DebugLevel(0) to (3). * Delete previous server output: rm /tmp/perldav_debug.txt * Run that single test again: $make test TEST_FILES=t/thetest.t TEST_VERBOSE=1 > testoutput.log * Then gzip and mail me both testoutput.log and /tmp/perldav_debug.txt with details of the test environment. (My email is at the bottom) Alternatively, you could have a shot at solving the bug yourself :) BUGS and TODO Need to convert XML::DOM to a DOM Level 2 compliant parser like XML::Gdome. See TODO for what is left to be done. AUTHOR AND COPYRIGHT This module is Copyright (C) 2001-2008 by Patrick Collins G03 Gloucester Place, Kensington Sydney, Australia mailto:pcollins@cpan.org Phone: +61 2 9663 4916 All rights reserved. MAINTAINER The current maintainer for HTTP::DAV is Opera Software ASA. Contact us at C LICENSE You may distribute this module under the terms of either the GNU General Public License or the Artistic License, as specified in the Perl README file. $Id: README 160 2009-02-24 23:03:39Z cosimo $ ** This file was automatically generated from ** ** doc/Changes.pod. To edit it, see there. **