ensl.org/app/controllers/custom_urls_controller.rb

81 lines
2.2 KiB
Ruby
Raw Normal View History

class CustomUrlsController < ApplicationController
2017-11-09 17:25:52 +00:00
def administrate
raise AccessError unless cuser && cuser.admin?
2017-11-12 00:26:00 +00:00
@custom_urls = CustomUrl.all
@custom_url = CustomUrl.new
2017-11-09 17:25:52 +00:00
end
def create
2017-11-12 00:26:00 +00:00
administrate
@custom_url.name = params[:custom_url][:name]
@custom_url.article_id = params[:custom_url][:article_id].to_i
if @custom_url.save
flash[:notice] = "Created URL with name #{@custom_url.name}"
redirect_to custom_urls_url
else
flash[:error] = 'Error creating URL!'
render :administrate
end
2017-11-09 17:25:52 +00:00
end
def show
2017-11-10 09:42:35 +00:00
custom_url = CustomUrl.find_by_name(params[:name])
@article = custom_url.article
raise AccessError unless @article.can_show? cuser
@article.read_by! cuser if cuser
render 'articles/show'
2017-11-09 17:25:52 +00:00
end
def update
raise AccessError unless request.xhr?
2017-11-12 00:26:00 +00:00
response = {}
if cuser && cuser.admin?
url = CustomUrl.find(params[:id]) rescue nil
if url
2018-05-03 17:25:50 +00:00
url.article_id = params[:custom_url][:article_id]
url.name= params[:custom_url][:name]
if url.save
2017-11-12 00:26:00 +00:00
response[:status] = 200
response[:message] = 'Successfully updated!'
2018-05-03 17:25:50 +00:00
resobj = {name: url.name, title: url.article.title}
response[:obj] = resobj
2017-11-12 00:26:00 +00:00
else
response[:status] = 400
message = 'Update failed! Errors:'
url.errors.full_messages.each do |error|
message += "\n * " + error
end
response[:message] = message
end
else
response[:status] = 404
response[:message] = 'Error! No Custom URL with this id exists.'
end
else
response[:status] = 403
response[:message] = 'You are not allowed to do this!'
end
render json: response, status: response[:status]
2017-11-09 17:25:52 +00:00
end
def destroy
raise AccessError unless request.xhr?
2017-11-12 00:26:00 +00:00
response = {}
if cuser && cuser.admin?
url = CustomUrl.destroy(params[:id])
response[:status] = 200
response[:message] = "Successfully deleted url with name: #{url.name}!"
else
response[:status] = 403
response[:message] = 'You are not allowed to do this!'
end
render json: response, status: response[:status]
2017-11-09 17:25:52 +00:00
end
end