##// END OF EJS Templates
Upgraded to Rails 2.3.4 (#3597)...
Upgraded to Rails 2.3.4 (#3597) * Ran the Rails upgrade * Upgraded to Rails Engines 2.3.2 * Added a plugin to let Engines override application views. * Converted tests to use the new classes: ** ActionController::TestCase for functional ** ActiveSupport::TestCase for units * Converted ActiveRecord::Error message to a string. * ActiveRecord grouping returns an ordered hash which doesn't have #sort! * Updated the I18n storage_units format. * Added some default initializers from a fresh rails app * Changed the order of check_box_tags and hidden_field_tags. The hidden tag needs to appear first in Rails 2.3, otherwise it will override any value in the check_box_tag. * Removed the custom handler for when the cookie store is tampered with. Rails 2.3 removed the TamperedWithCookie exception and instead Rails will not load the data from it when it's been tampered with (e.g. no user login). * Fixed mail layouts, 2.3 has problems with implicit multipart emails that use layouts. Also removed some custom Redmine mailer code. * Fixed a bug that occurred in tests where the "required" span tag would be added to the :field_status translation. This resulted in an email string of: <li>Status<span class="required"> *</span><span class="required"> *</span> Instead of: <li>Status: New</li> git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2887 e93f8b46-1217-0410-a6f0-8f06a7374b81

File last commit:

r2633:bae7579a7222
r2773:7b0cb6aba871
Show More
Redmine.pm
345 lines | 9.6 KiB | text/x-perl | PerlLexer
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 package Apache::Authn::Redmine;
=head1 Apache::Authn::Redmine
Redmine - a mod_perl module to authenticate webdav subversion users
against redmine database
=head1 SYNOPSIS
This module allow anonymous users to browse public project and
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 registred users to browse and commit their project. Authentication is
done against the redmine database or the LDAP configured in redmine.
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903
This method is far simpler than the one with pam_* and works with all
database without an hassle but you need to have apache/mod_perl on the
svn server.
=head1 INSTALLATION
For this to automagically work, you need to have a recent reposman.rb
(after r860) and if you already use reposman, read the last section to
migrate.
Sorry ruby users but you need some perl modules, at least mod_perl2,
DBI and DBD::mysql (or the DBD driver for you database as it should
work on allmost all databases).
On debian/ubuntu you must do :
aptitude install libapache-dbi-perl libapache2-mod-perl2 libdbd-mysql-perl
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 If your Redmine users use LDAP authentication, you will also need
Jean-Philippe Lang
Redmine.pm doc update...
r1322 Authen::Simple::LDAP (and IO::Socket::SSL if LDAPS is used):
aptitude install libauthen-simple-ldap-perl libio-socket-ssl-perl
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 =head1 CONFIGURATION
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 ## This module has to be in your perl path
## eg: /usr/lib/perl5/Apache/Authn/Redmine.pm
PerlLoadModule Apache::Authn::Redmine
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 <Location /svn>
DAV svn
SVNParentPath "/var/svn"
AuthType Basic
AuthName redmine
Require valid-user
PerlAccessHandler Apache::Authn::Redmine::access_handler
PerlAuthenHandler Apache::Authn::Redmine::authen_handler
## for mysql
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 RedmineDSN "DBI:mysql:database=databasename;host=my.db.server"
Liwiusz Ociepa
Memory leak (postgres -> zlib + ssl) has been fixed by apache developers....
r1423 ## for postgres
# RedmineDSN "DBI:Pg:dbname=databasename;host=my.db.server"
Liwiusz Ociepa
Merge changes from branch swistak....
r1410
RedmineDbUser "redmine"
RedmineDbPass "password"
## Optional where clause (fulltext search would be slow and
## database dependant).
# RedmineDbWhereClause "and members.role_id IN (1,2)"
## Optional credentials cache size
# RedmineCacheCredsMax 50
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 </Location>
To be able to browse repository inside redmine, you must add something
like that :
<Location /svn-private>
DAV svn
SVNParentPath "/var/svn"
Order deny,allow
Deny from all
# only allow reading orders
<Limit GET PROPFIND OPTIONS REPORT>
Allow from redmine.server.ip
</Limit>
</Location>
and you will have to use this reposman.rb command line to create repository :
reposman.rb --redmine my.redmine.server --svn-dir /var/svn --owner www-data -u http://svn.server/svn-private/
=head1 MIGRATION FROM OLDER RELEASES
If you use an older reposman.rb (r860 or before), you need to change
rights on repositories to allow the apache user to read and write
S<them :>
sudo chown -R www-data /var/svn/*
sudo chmod -R u+w /var/svn/*
And you need to upgrade at least reposman.rb (after r860).
=cut
use strict;
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 use warnings FATAL => 'all', NONFATAL => 'redefine';
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903
use DBI;
use Digest::SHA1;
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 # optional module for LDAP authentication
my $CanUseLDAPAuth = eval("use Authen::Simple::LDAP; 1");
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903
use Apache2::Module;
use Apache2::Access;
use Apache2::ServerRec qw();
use Apache2::RequestRec qw();
use Apache2::RequestUtil qw();
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 use Apache2::Const qw(:common :override :cmd_how);
use APR::Pool ();
use APR::Table ();
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 # use Apache2::Directive qw();
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 my @directives = (
{
name => 'RedmineDSN',
req_override => OR_AUTHCFG,
args_how => TAKE1,
errmsg => 'Dsn in format used by Perl DBI. eg: "DBI:Pg:dbname=databasename;host=my.db.server"',
},
{
name => 'RedmineDbUser',
req_override => OR_AUTHCFG,
args_how => TAKE1,
},
{
name => 'RedmineDbPass',
req_override => OR_AUTHCFG,
args_how => TAKE1,
},
{
name => 'RedmineDbWhereClause',
req_override => OR_AUTHCFG,
args_how => TAKE1,
},
{
name => 'RedmineCacheCredsMax',
req_override => OR_AUTHCFG,
args_how => TAKE1,
errmsg => 'RedmineCacheCredsMax must be decimal number',
},
);
sub RedmineDSN {
my ($self, $parms, $arg) = @_;
$self->{RedmineDSN} = $arg;
my $query = "SELECT
Jean-Philippe Lang
Merged nbc branch @ r1812 (commit access permission and reposman improvements)....
r1812 hashed_password, auth_source_id, permissions
Jean-Philippe Lang
Fixes Redmine.pm broken by r2726 (#3330)....
r2633 FROM members, projects, users, roles, member_roles
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 WHERE
Jean-Philippe Lang
Fixes Redmine.pm broken by r2726 (#3330)....
r2633 projects.id=members.project_id
AND member_roles.member_id=members.id
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 AND users.id=members.user_id
Jean-Philippe Lang
Fixes Redmine.pm broken by r2726 (#3330)....
r2633 AND roles.id=member_roles.role_id
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 AND users.status=1
AND login=?
AND identifier=? ";
$self->{RedmineQuery} = trim($query);
}
Jean-Philippe Lang
Fixes Redmine.pm broken by r2726 (#3330)....
r2633
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 sub RedmineDbUser { set_val('RedmineDbUser', @_); }
sub RedmineDbPass { set_val('RedmineDbPass', @_); }
sub RedmineDbWhereClause {
my ($self, $parms, $arg) = @_;
$self->{RedmineQuery} = trim($self->{RedmineQuery}.($arg ? $arg : "")." ");
}
sub RedmineCacheCredsMax {
my ($self, $parms, $arg) = @_;
if ($arg) {
$self->{RedmineCachePool} = APR::Pool->new;
$self->{RedmineCacheCreds} = APR::Table::make($self->{RedmineCachePool}, $arg);
$self->{RedmineCacheCredsCount} = 0;
$self->{RedmineCacheCredsMax} = $arg;
}
}
sub trim {
my $string = shift;
$string =~ s/\s{2,}/ /g;
return $string;
}
sub set_val {
my ($key, $self, $parms, $arg) = @_;
$self->{$key} = $arg;
}
Apache2::Module::add(__PACKAGE__, \@directives);
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 my %read_only_methods = map { $_ => 1 } qw/GET PROPFIND REPORT OPTIONS/;
sub access_handler {
my $r = shift;
unless ($r->some_auth_required) {
$r->log_reason("No authentication has been configured");
return FORBIDDEN;
}
my $method = $r->method;
Nicolas Chuche
bug in read only access handling...
r1775 return OK unless defined $read_only_methods{$method};
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903
my $project_id = get_project_identifier($r);
$r->set_handlers(PerlAuthenHandler => [\&OK])
if is_public_project($project_id, $r);
return OK
}
sub authen_handler {
my $r = shift;
my ($res, $redmine_pass) = $r->get_basic_auth_pw();
return $res unless $res == OK;
if (is_member($r->user, $redmine_pass, $r)) {
return OK;
} else {
$r->note_auth_failure();
return AUTH_REQUIRED;
}
}
sub is_public_project {
my $project_id = shift;
my $r = shift;
my $dbh = connect_database($r);
my $sth = $dbh->prepare(
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 "SELECT * FROM projects WHERE projects.identifier=? and projects.is_public=true;"
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 );
$sth->execute($project_id);
my $ret = $sth->fetchrow_array ? 1 : 0;
Jean-Philippe Lang
Close statement handler in Redmine.pm (#1433)....
r1525 $sth->finish();
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 $dbh->disconnect();
$ret;
}
# perhaps we should use repository right (other read right) to check public access.
# it could be faster BUT it doesn't work for the moment.
# sub is_public_project_by_file {
# my $project_id = shift;
# my $r = shift;
# my $tree = Apache2::Directive::conftree();
# my $node = $tree->lookup('Location', $r->location);
# my $hash = $node->as_hash;
# my $svnparentpath = $hash->{SVNParentPath};
# my $repos_path = $svnparentpath . "/" . $project_id;
# return 1 if (stat($repos_path))[2] & 00007;
# }
sub is_member {
my $redmine_user = shift;
my $redmine_pass = shift;
my $r = shift;
my $dbh = connect_database($r);
my $project_id = get_project_identifier($r);
my $pass_digest = Digest::SHA1::sha1_hex($redmine_pass);
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 my $cfg = Apache2::Module::get_config(__PACKAGE__, $r->server, $r->per_dir_config);
my $usrprojpass;
if ($cfg->{RedmineCacheCredsMax}) {
$usrprojpass = $cfg->{RedmineCacheCreds}->get($redmine_user.":".$project_id);
return 1 if (defined $usrprojpass and ($usrprojpass eq $pass_digest));
}
my $query = $cfg->{RedmineQuery};
my $sth = $dbh->prepare($query);
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 $sth->execute($redmine_user, $project_id);
my $ret;
Jean-Philippe Lang
Merged nbc branch @ r1812 (commit access permission and reposman improvements)....
r1812 while (my ($hashed_password, $auth_source_id, $permissions) = $sth->fetchrow_array) {
unless ($auth_source_id) {
my $method = $r->method;
if ($hashed_password eq $pass_digest && (defined $read_only_methods{$method} || $permissions =~ /:commit_access/) ) {
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 $ret = 1;
last;
}
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 } elsif ($CanUseLDAPAuth) {
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 my $sthldap = $dbh->prepare(
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 "SELECT host,port,tls,account,account_password,base_dn,attr_login from auth_sources WHERE id = ?;"
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 );
Jean-Philippe Lang
Merged nbc branch @ r1812 (commit access permission and reposman improvements)....
r1812 $sthldap->execute($auth_source_id);
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 while (my @rowldap = $sthldap->fetchrow_array) {
my $ldap = Authen::Simple::LDAP->new(
Jean-Philippe Lang
Redmine.pm for webdav authentication:...
r1321 host => ($rowldap[2] == 1 || $rowldap[2] eq "t") ? "ldaps://$rowldap[0]" : $rowldap[0],
port => $rowldap[1],
basedn => $rowldap[5],
binddn => $rowldap[3] ? $rowldap[3] : "",
bindpw => $rowldap[4] ? $rowldap[4] : "",
filter => "(".$rowldap[6]."=%s)"
);
$ret = 1 if ($ldap->authenticate($redmine_user, $redmine_pass));
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 }
$sthldap->finish();
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 }
}
Jean-Philippe Lang
Redmine.pm support for LDAP authentication (patch by Liwiusz Ociepa). Closes #879, #918....
r1320 $sth->finish();
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 $dbh->disconnect();
Liwiusz Ociepa
Merge changes from branch swistak....
r1410 if ($cfg->{RedmineCacheCredsMax} and $ret) {
if (defined $usrprojpass) {
$cfg->{RedmineCacheCreds}->set($redmine_user.":".$project_id, $pass_digest);
} else {
if ($cfg->{RedmineCacheCredsCount} < $cfg->{RedmineCacheCredsMax}) {
$cfg->{RedmineCacheCreds}->set($redmine_user.":".$project_id, $pass_digest);
$cfg->{RedmineCacheCredsCount}++;
} else {
$cfg->{RedmineCacheCreds}->clear();
$cfg->{RedmineCacheCredsCount} = 0;
}
}
}
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 $ret;
}
sub get_project_identifier {
my $r = shift;
my $location = $r->location;
my ($identifier) = $r->uri =~ m{$location/*([^/]+)};
$identifier;
}
sub connect_database {
my $r = shift;
Liwiusz Ociepa
Merge changes from branch swistak....
r1410
my $cfg = Apache2::Module::get_config(__PACKAGE__, $r->server, $r->per_dir_config);
return DBI->connect($cfg->{RedmineDSN}, $cfg->{RedmineDbUser}, $cfg->{RedmineDbPass});
Nicolas Chuche
* add Redmine.pm to authenticate with mod_perl...
r903 }
1;