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:
-
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/