The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    Catalyst::Model::SVN - Catalyst Model to browse Subversion repositories

SYNOPSIS
        # Model
        __PACKAGE__->config(
            repository => '/path/to/svn/root/or/path'
        );

        # Controller
        sub default : Private {
            my ($self, $c) = @_;
            my $path = join('/', $c->req->args);
            my $revision = $c->req->param('revision') || 'HEAD';

            $c->stash->{'repository_revision'} = MyApp::M::SVN->revision;
            $c->stash->{'items'} = MyApp::M::SVN->ls($path, $revision);

            $c->stash->{'template'} = 'blog.tt';
        };

DESCRIPTION
    This model class uses the perl-subversion bindings to access a
    Subversion repository and list items and view their contents. It is
    currently only a read-only client but may expand to be a fill fledged
    client at a later time.

CONFIG
    The following configuration options are available:

  repository
    This is the full path to the root of, or any directory in your
    Subversion repository. This can be one of http://, svn://, or file:///
    schemes.

  revision
    This is the default revision to use when no revision is specified. By
    default, this will be "HEAD".

METHODS
  cat($path [, $revision])
    Returns the contents of the path specified. If "path" is a copy, the
    logs are transversed to find original. The request is then reissued for
    the original path for the "revision" specified.

  ls($path [, $revision])
    Returns a array of "Catalyst::Model::SVN::Item" objects in list context,
    each representing an entry in the specified repository path. In scalar
    context, it returns an array reference. If "path" is a copy, the logs
    are transversed to find the original. The request is then reissued for
    the original path for the "revision" specified.

    Each "Catalyst::Model::SVN::Item" object has the following methods:

    author
        The author of the latest revision of the current item.

    contents
        The contents of the of the current item. This is the same as calling
        "Catalyst::Model::SVN-"cat($item->uri, $item->revision)

    is_directory
        Returns 1 if the current item is a directory; 0 otherwise.

    is_file
        Returns 1 if the current item is a file; 0 otherwise.

    kind
        Returns the kind of the current item. See SVN::Core for the possible
        types, usually $SVN::Node::path or $SVN::Node::file.

    log Returns the last log entry for the current item. Be forewarned, this
        makes an extra call to the repository, which is slow. Only use this
        if you are listing a single item, and not when looping through large
        collections of items. If the current item is a copy, the logs are
        transversed to find the original. The request is then reissued for
        the original path for the "revision" specified.

    name
        Returns the name of the current item.

    path
        Returns the path of the current item relative to the repository
        root.

    revision
        Returns the revision of the current item.

    size
        Returns the raw file size in bytes for the current item.

    time
        Returns the last modified time of the current item as a DateTime
        object.

    uri Returns the full repository path of the current item.

  repository
    Returns the repository specified in the configuration "repository"
    option.

  revision
    Returns the latest revisions of the repository you are connected to.

SEE ALSO
    Catalyst::Manual, Catalyst::Helper, SVN::Client, SVN::Ra

AUTHOR
        Christopher H. Laco
        CPAN ID: CLACO
        claco@chrislaco.com
        http://today.icantfocus.com/blog/