Pass the vhost in as a parameter
[catagits/Gitalist.git] / lib / Gitalist / Model / CollectionOfRepos.pm
CommitLineData
7bf1a6f5 1package Gitalist::Model::CollectionOfRepos;
21336a02 2
3use Moose;
ea772511 4use MooseX::Types::Moose qw/Undef Maybe ArrayRef Str/;
bddfb71e 5use MooseX::Types::Common::String qw/NonEmptySimpleStr/;
eef1fb14 6use MooseX::Types::LoadableClass qw/ LoadableClass /;
ea772511 7use Gitalist::Git::Types qw/ ArrayRefOfDirs Dir DirOrUndef /;
a18818fd 8use Moose::Util::TypeConstraints;
a7010acf 9use Moose::Autobox;
ea772511 10use Path::Class qw/ dir /;
21336a02 11use namespace::autoclean;
12
bddfb71e 13extends 'Catalyst::Model';
21336a02 14
5e26dc93 15with 'Catalyst::Component::ApplicationAttribute';
bddfb71e 16with 'Catalyst::Component::InstancePerContext';
17
e33993c9 18has class => (
eef1fb14 19 isa => LoadableClass,
e33993c9 20 is => 'ro',
ea772511 21 lazy => 1,
22 coerce => 1,
eef1fb14 23 builder => '_build_class',
e33993c9 24);
25
eef1fb14 26sub _build_class {
ea772511 27 my ($self) = @_;
eef1fb14 28
29 if($self->whitelist && -f $self->whitelist) {
30 return 'Gitalist::Git::CollectionOfRepositories::FromDirectory::WhiteList';
ea772511 31 }
32 elsif($self->search_recursively) {
eef1fb14 33 return 'Gitalist::Git::CollectionOfRepositories::FromDirectoryRecursive';
34 }
ea772511 35 elsif ($self->repos) {
36 return 'Gitalist::Git::CollectionOfRepositories::FromListOfDirectories';
37 }
38 elsif ($self->repos_dir) {
39 return 'Gitalist::Git::CollectionOfRepositories::FromDirectory';
40 }
41 else {
42 return "Don't know where to get repositores from. Try a --repos_dir option, or setting up config";
43 }
eef1fb14 44}
45
e33993c9 46has args => (
47 isa => 'HashRef',
48 is => 'ro',
49 default => sub { {} },
50);
1891c774 51
52has search_recursively => (
53 is => 'ro',
54 isa => 'Bool',
55 default => 0,
56);
57
ea772511 58## XX What is this for?
1d727634 59has export_ok => (
60 is => 'ro',
61 isa => 'Str',
62);
63
b70462a4 64has whitelist => (
65 is => 'ro',
66 isa => 'Str',
ea772511 67 predicate => '_has_whitelist',
b70462a4 68);
69
91b8538e 70has repo_dir => (
71 is => 'ro',
72 isa => DirOrUndef,
73 coerce => 1,
74 predicate => '_has_repo_dir',
75);
76
ea772511 77# Simple directory of repositories (for list)
78has repos_dir => (
79 is => 'ro',
80 isa => DirOrUndef,
81 coerce => 1,
82 builder => '_build_repos_dir',
83 lazy => 1,
84);
5e26dc93 85
ea772511 86# Directory containing list of one or more repositories
87has repos => (
88 is => 'ro',
89 isa => ArrayRefOfDirs,
90 coerce => 1,
91);
a18818fd 92
ea772511 93sub _build_repos_dir {
a18818fd 94 my $self = shift;
91b8538e 95 my $opts = $self->_application->run_options || {};
96 return $self->_has_repo_dir && $self->repo_dir
97 || $opts->{repos_dir} || $ENV{GITALIST_REPO_DIR} || undef;
ea772511 98}
a18818fd 99
ea772511 100sub BUILD {
101 my $self = shift;
102 $self->class();
103 if ($self->repos_dir) { $self->repos_dir->resolve }
104}
e33993c9 105
106sub build_per_context_instance {
2a285433 107 my ($self, $ctx) = @_;
e33993c9 108
109 my %args = (
110 export_ok => $self->export_ok || '',
ea772511 111 $self->_has_whitelist ? (whitelist => $self->whitelist) : (),
112 repos => $self->repos,
113 repo_dir => $self->repos_dir,
2a285433 114 vhost => $ctx->request->uri->host,
e33993c9 115 %{ $self->args }
116 );
117
2a285433 118 my $class = $self->class;
119
120 $ctx->log->debug("Using class '$class'") if $c->debug;
121
122 return $class->new(%args);
21336a02 123}
124
125__PACKAGE__->meta->make_immutable;
bddfb71e 126
775e96e0 127__END__
128
2298d93f 129=encoding UTF-8
130
131=head1 NAME
132
133Gitalist::Model::CollectionOfRepos - Model::CollectionOfRepos module for Gitalist
134
eef1fb14 135=head1 DESCRIPTION
136
137This Model is a factory for an object implementing the L<Gitalist::Git::CollectionOfRepositories>
138interface.
139
140The simple options passed on the command line (like C<--repos_dir>), a class will by picked by default
141L<Gitalist::Git::CollectionOfRepositories::FromDirectory>.
142
143This can be overridden from config by explicitly passing in a class name and args for that class
144in config:
145
146 <Model::CollectionOfRepos>
147 class MyClassName
148 <args>
149 ...
150 </args>
151 </Model::CollectionOfRepos>
152
775e96e0 153=head1 AUTHORS
154
155See L<Gitalist> for authors.
156
157=head1 LICENSE
158
159See L<Gitalist> for the license.
160
161=cut