Calligraphy
Calligraphy is a Web Distributed Authoring and Versioning (WebDAV) solution for Rails that:
- Provides a framework for handling WebDAV requests (e.g.
PROPFIND,PROPPATCH) - Allows you to extend WedDAV functionality to any type of resource
- Passes all of the Litmus tests (using
Calligraphy::FileResourceand digest authentication)
Getting Started
Add the following line to your Gemfile:
gem 'calligraphy'
Then, run bundle install
Next, run the generator:
rails generate calligraphy:install
The generator will install an initializer which describes Calligraphy's configuration options.
Finally, set up a calligraphy_resource route in config/routes.rb with a resource_class.
# config/routes.rb
calligraphy_resource :webdav, resource_class: Calligraphy::FileResource
The above will create a route, /webdav that will be able to handle the following HTTP request methods:
OPTIONSGETPUTDELETECOPYMOVEMKCOLPROPFINDPROPPATCHLOCKUNLOCK
The routes will also use the Calligraphy::FileResource, enabling Rails to carry out WebDAV actions on files.
Additionally, when using the FileResource class the resource root path (the location you'd like to serve files from) with the resource_root_path key:
# config/routes.rb
calligraphy_resource :webdav, resource_class: Calligraphy::FileResource, resource_root_path: '/home/webdav'
This will serve local files from /home/webdav on the server through the /webdav endpoint.
Extensibility
The Calligraphy::Resource class exposes all the methods used in the various Calligraphy::WebDavRequest classes.
To create a custom resource, simply inherit from Calligraphy::Resource and redefine the public methods you'd like to customize.
For example, to create a CalendarResource:
module Calligraphy
class CalendarResource < Resource
def propfind(nodes)
# custom implementation of propfind for CalendarResource
end
...
end
end
License
Calligraphy is Copyright © 2017 Brandon Robins. It is free software, and may be redistributed under the terms specified in the LICENSE file.