package Gitalist::Model::CollectionOfRepos;
use Moose;
-use Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive;
-use Gitalist::Git::CollectionOfRepositories::FromListOfDirectories;
-use Gitalist::Git::CollectionOfRepositories::FromDirectory::WhiteList;
use MooseX::Types::Moose qw/Maybe ArrayRef/;
use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
+use MooseX::Types::LoadableClass qw/ LoadableClass /;
use Moose::Util::TypeConstraints;
use Moose::Autobox;
use namespace::autoclean;
extends 'Catalyst::Model';
+with 'Catalyst::Component::ApplicationAttribute';
with 'Catalyst::Component::InstancePerContext';
my $repo_dir_t = subtype NonEmptySimpleStr,
coerce => 1,
);
+has class => (
+ isa => LoadableClass,
+ is => 'ro',
+ is => 'lazy',
+ builder => '_build_class',
+);
+
+sub _build_class {
+ my($self) = @_;
+
+ if($self->whitelist && -f $self->whitelist) {
+ return 'Gitalist::Git::CollectionOfRepositories::FromDirectory::WhiteList';
+ } elsif ($self->_repos_count && !$self->search_recursively) {
+ return 'Gitalist::Git::CollectionOfRepositories::FromListOfDirectories';
+ } elsif($self->search_recursively) {
+ return 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive';
+ }
+
+ return 'Gitalist::Git::CollectionOfRepositories::FromDirectory';
+}
+
+has args => (
+ isa => 'HashRef',
+ is => 'ro',
+ default => sub { {} },
+);
has search_recursively => (
is => 'ro',
sub _build_repo_dir {
my $self = shift;
- $ENV{GITALIST_REPO_DIR} ?
- $ENV{GITALIST_REPO_DIR}
+ my $repo_dir = $self->_application->run_options->{repo_dir};
+
+ $repo_dir ?
+ $repo_dir
: $self->has_config_repo_dir
? $self->config_repo_dir
: '';
$self->_repos_count || $self->repo_dir;
};
+
sub build_per_context_instance {
my ($self, $app) = @_;
- my %args = (export_ok => $self->export_ok || '');
- my $class;
- if($self->whitelist && -f $self->whitelist) {
- $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectory::WhiteList';
- $args{repo_dir} = $self->repo_dir;
- $args{whitelist} = $self->whitelist;
- } elsif ($self->_repos_count && !$self->search_recursively) {
- $class = 'Gitalist::Git::CollectionOfRepositories::FromListOfDirectories';
- $args{repos} = $self->repos;
- } elsif($self->search_recursively) {
- $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive';
- $args{repo_dir} = $self->repo_dir;
- } else {
- $class = 'Gitalist::Git::CollectionOfRepositories::FromDirectory';
- $args{repo_dir} = $self->repo_dir;
- }
+ my %args = (
+ export_ok => $self->export_ok || '',
+ $self->_has_whitelist ? (whitelist => $self->whistlist) : (),
+ $self->_has_repos ? (repos => $self->repos) : ()
+ $self->_has_repo_dir ? (repo_dir => $self->repo_dir) : ()
+ %{ $self->args }
+ );
+
+ my $class = $self->class;
+
+ $app->log->debug("Using class '$class'");
return $class->new(%args);
}
__END__
+=encoding UTF-8
+
+=head1 NAME
+
+Gitalist::Model::CollectionOfRepos - Model::CollectionOfRepos module for Gitalist
+
+=head1 DESCRIPTION
+
+This Model is a factory for an object implementing the L<Gitalist::Git::CollectionOfRepositories>
+interface.
+
+The simple options passed on the command line (like C<--repos_dir>), a class will by picked by default
+L<Gitalist::Git::CollectionOfRepositories::FromDirectory>.
+
+This can be overridden from config by explicitly passing in a class name and args for that class
+in config:
+
+ <Model::CollectionOfRepos>
+ class MyClassName
+ <args>
+ ...
+ </args>
+ </Model::CollectionOfRepos>
+
=head1 AUTHORS
See L<Gitalist> for authors.