debian-mirror-gitlab/app/controllers/projects/labels_controller.rb
2016-04-02 18:10:28 +05:30

82 lines
1.9 KiB
Ruby

class Projects::LabelsController < Projects::ApplicationController
before_action :module_enabled
before_action :label, only: [:edit, :update, :destroy]
before_action :authorize_read_label!
before_action :authorize_admin_labels!, except: [:index]
respond_to :js, :html
def index
@labels = @project.labels.page(params[:page]).per(PER_PAGE)
end
def new
@label = @project.labels.new
end
def create
@label = @project.labels.create(label_params)
if @label.valid?
redirect_to namespace_project_labels_path(@project.namespace, @project)
else
render 'new'
end
end
def edit
end
def update
if @label.update_attributes(label_params)
redirect_to namespace_project_labels_path(@project.namespace, @project)
else
render 'edit'
end
end
def generate
Gitlab::IssuesLabels.generate(@project)
if params[:redirect] == 'issues'
redirect_to namespace_project_issues_path(@project.namespace, @project)
elsif params[:redirect] == 'merge_requests'
redirect_to namespace_project_merge_requests_path(@project.namespace,
@project)
else
redirect_to namespace_project_labels_path(@project.namespace, @project)
end
end
def destroy
@label.destroy
respond_to do |format|
format.html do
redirect_to(namespace_project_labels_path(@project.namespace, @project),
notice: 'Label was removed')
end
format.js
end
end
protected
def module_enabled
unless @project.issues_enabled || @project.merge_requests_enabled
return render_404
end
end
def label_params
params.require(:label).permit(:title, :description, :color)
end
def label
@label = @project.labels.find(params[:id])
end
def authorize_admin_labels!
return render_404 unless can?(current_user, :admin_label, @project)
end
end