OpenProject is the leading open source project management software.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
openproject/app/controllers/enumerations_controller.rb

117 lines
3.3 KiB

#-- encoding: UTF-8
#-- copyright
# OpenProject is a project management system.
# Copyright (C) 2012-2015 the OpenProject Foundation (OPF)
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License version 3.
#
# OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
# Copyright (C) 2006-2013 Jean-Philippe Lang
# Copyright (C) 2010-2013 the ChiliProject Team
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License
# as published by the Free Software Foundation; either version 2
# of the License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
#
# See doc/COPYRIGHT.rdoc for more details.
#++
class EnumerationsController < ApplicationController
layout 'admin'
before_filter :require_admin
before_filter :find_enumeration, only: [:edit, :update, :destroy]
include CustomFieldsHelper
def index; end
def edit; end
def new
enum_class = enumeration_class(permitted_params.enumeration_type)
if enum_class
@enumeration = enum_class.new
else
render_400 # bad request
end
end
def create
enum_params = permitted_params.enumeration
type = params[:enumeration][:type]
@enumeration = (enumeration_class(type) || Enumeration).new do |e|
e.attributes = enum_params
end
if @enumeration.save
flash[:notice] = l(:notice_successful_create)
redirect_to action: 'index', type: @enumeration.type
else
render action: 'new'
end
end
def update
enum_params = permitted_params.enumeration
type = params[:enumeration][:type]
@enumeration.type = enumeration_class(type).try(:name) || @enumeration.type
if @enumeration.update_attributes enum_params
flash[:notice] = l(:notice_successful_update)
redirect_to enumerations_path(type: @enumeration.type)
else
render action: 'edit'
end
end
def destroy
if !@enumeration.in_use?
# No associated objects
@enumeration.destroy
redirect_to action: 'index'
return
elsif params[:reassign_to_id]
if reassign_to = @enumeration.class.find_by(id: params[:reassign_to_id])
@enumeration.destroy(reassign_to)
redirect_to action: 'index'
return
end
end
@enumerations = @enumeration.class.find(:all) - [@enumeration]
end
protected
def default_breadcrumb
l(:label_enumerations)
end
def find_enumeration
@enumeration = Enumeration.find(params[:id])
end
##
# Find an enumeration class with the given Name
# this should be fail save for nonsense names or names
# which are no enumerations to prevent remote code execution attacks.
# params: type (string)
def enumeration_class(type)
klass = type.to_s.constantize
raise NameError unless klass.ancestors.include? Enumeration
klass
rescue NameError
nil
end
end