summaryrefslogtreecommitdiffstats
path: root/extra
diff options
context:
space:
mode:
authorJean-Philippe Lang <jp_lang@yahoo.fr>2012-06-25 20:08:49 +0000
committerJean-Philippe Lang <jp_lang@yahoo.fr>2012-06-25 20:08:49 +0000
commit21ac4a3d0e074b7ec4b3b7bc88ec28440b99ce15 (patch)
tree153b8b678461321d36e53d7b45ac2f46a9b780c0 /extra
parent2ceb6b8230a35be04b6f541e681abae8f034867e (diff)
downloadredmine-21ac4a3d0e074b7ec4b3b7bc88ec28440b99ce15.tar.gz
redmine-21ac4a3d0e074b7ec4b3b7bc88ec28440b99ce15.zip
Makes Redmine.pm handle project status (#3640).
Repositories of archived projects are no longer accessible. Repositories of closed projects are read-only. git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9887 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'extra')
-rw-r--r--extra/svn/Redmine.pm9
1 files changed, 6 insertions, 3 deletions
diff --git a/extra/svn/Redmine.pm b/extra/svn/Redmine.pm
index a370c3a47..2aeb352d4 100644
--- a/extra/svn/Redmine.pm
+++ b/extra/svn/Redmine.pm
@@ -239,7 +239,7 @@ sub RedmineDSN {
my ($self, $parms, $arg) = @_;
$self->{RedmineDSN} = $arg;
my $query = "SELECT
- hashed_password, salt, auth_source_id, permissions
+ users.hashed_password, users.salt, users.auth_source_id, roles.permissions, projects.status
FROM projects, users, roles
WHERE
users.login=?
@@ -381,7 +381,7 @@ sub is_public_project {
my $dbh = connect_database($r);
my $sth = $dbh->prepare(
- "SELECT is_public FROM projects WHERE projects.identifier = ?;"
+ "SELECT is_public FROM projects WHERE projects.identifier = ? AND projects.status <> 9;"
);
$sth->execute($project_id);
@@ -460,7 +460,10 @@ sub is_member {
$sth->execute($redmine_user, $project_id);
my $ret;
- while (my ($hashed_password, $salt, $auth_source_id, $permissions) = $sth->fetchrow_array) {
+ while (my ($hashed_password, $salt, $auth_source_id, $permissions, $project_status) = $sth->fetchrow_array) {
+ if ($project_status eq "9" || ($project_status ne "1" && $access_mode eq "W")) {
+ last;
+ }
unless ($auth_source_id) {
my $method = $r->method;