To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / app / controllers / sys_controller.rb @ 767:dd33798e514d

History | View | Annotate | Download (3.85 KB)

1
# Redmine - project management software
2
# Copyright (C) 2006-2009  Jean-Philippe Lang
3
#
4
# This program is free software; you can redistribute it and/or
5
# modify it under the terms of the GNU General Public License
6
# as published by the Free Software Foundation; either version 2
7
# of the License, or (at your option) any later version.
8
# 
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12
# GNU General Public License for more details.
13
# 
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17

    
18
class SysController < ActionController::Base
19
  before_filter :check_enabled
20
  
21
  def projects
22
    p = Project.active.has_module(:repository).find(:all, :include => :repository, :order => 'identifier')
23
    render :xml => p.to_xml(:include => :repository)
24
  end
25
  
26
  def create_project_repository
27
    project = Project.find(params[:id])
28
    if project.repository
29
      render :nothing => true, :status => 409
30
    else
31
      logger.info "Repository for #{project.name} was reported to be created by #{request.remote_ip}."
32
      project.repository = Repository.factory(params[:vendor], params[:repository])
33
      if project.repository && project.repository.save
34
        render :xml => project.repository, :status => 201
35
      else
36
        render :nothing => true, :status => 422
37
      end
38
    end
39
  end
40
  
41
  def fetch_changesets
42
    projects = []
43
    if params[:id]
44
      projects << Project.active.has_module(:repository).find(params[:id])
45
    else
46
      projects = Project.active.has_module(:repository).find(:all, :include => :repository)
47
    end
48
    projects.each do |project|
49
      if project.repository
50
        project.repository.fetch_changesets
51
      end
52
    end
53
    render :nothing => true, :status => 200
54
  rescue ActiveRecord::RecordNotFound
55
    render :nothing => true, :status => 404
56
  end
57

    
58
  def get_external_repo_url
59
    project = Project.find(params[:id])
60
    if project.repository
61
      repo = project.repository
62
      if repo.is_external?
63
        render :text => repo.external_url, :status => 200
64
      else
65
        render :nothing => true, :status => 200
66
      end
67
    end
68
  rescue ActiveRecord::RecordNotFound
69
    render :nothing => true, :status => 404
70
  end
71

    
72
  def clear_repository_cache
73
    project = Project.find(params[:id])
74
    if project.repository
75
      project.repository.clear_cache
76
    end
77
    render :nothing => true, :status => 200
78
  rescue ActiveRecord::RecordNotFound
79
    render :nothing => true, :status => 404
80
  end
81
  
82
  def set_embedded_active
83
    project = Project.find(params[:id])
84
    mods = project.enabled_modules
85
    enable = (params[:enable] == "1")
86
    if mods.detect {|m| m.name == "embedded"}
87
      logger.info "Project #{project.name} currently has Embedded enabled"
88
      if !enable
89
        logger.info "Disabling Embedded"
90
        modnames = mods.all(:select => :name).collect{|m| m.name}.reject{|n| n == "embedded"}
91
        project.enabled_module_names = modnames
92
      end
93
    else
94
      logger.info "Project #{project.name} currently has Embedded disabled"
95
      if enable
96
        logger.info "Enabling Embedded"
97
        modnames = mods.all(:select => :name).collect{|m| m.name}
98
        modnames << "embedded"
99
        project.enabled_module_names = modnames
100
      end
101
    end
102
    render :nothing => true, :status => 200
103
  rescue ActiveRecord::RecordNotFound
104
    render :nothing => true, :status => 404
105
  end
106

    
107
  protected
108

    
109
  def check_enabled
110
    User.current = nil
111
    unless Setting.sys_api_enabled? && params[:key].to_s == Setting.sys_api_key
112
      render :text => 'Access denied. Repository management WS is disabled or key is invalid.', :status => 403
113
      return false
114
    end
115
  end
116
end