105 lines
2.6 KiB
Ruby
105 lines
2.6 KiB
Ruby
class MetacodesController < ApplicationController
|
|
|
|
before_filter :require_admin, except: [:index]
|
|
|
|
# GET /metacodes
|
|
# GET /metacodes.json
|
|
def index
|
|
@metacodes = Metacode.order("name").all
|
|
@metacodes.map do |metacode|
|
|
metacode.icon = asset_path(metacode.icon)
|
|
end
|
|
|
|
respond_to do |format|
|
|
format.html {
|
|
unless authenticated? && user.admin
|
|
redirect_to root_url, notice: "You need to be an admin for that."
|
|
return false
|
|
end
|
|
render action: "index"
|
|
}
|
|
format.json { render json: @metacodes }
|
|
end
|
|
end
|
|
|
|
### SHOW IS CURRENTLY DISABLED
|
|
# GET /metacodes/1
|
|
# GET /metacodes/1.json
|
|
# def show
|
|
# @metacode = Metacode.find(params[:id])
|
|
#
|
|
# respond_to do |format|
|
|
# format.html # show.html.erb
|
|
# format.json { render json: @metacode }
|
|
# end
|
|
# end
|
|
|
|
# GET /metacodes/new
|
|
# GET /metacodes/new.json
|
|
def new
|
|
@metacode = Metacode.new
|
|
|
|
respond_to do |format|
|
|
format.html # new.html.erb
|
|
format.json { render json: @metacode }
|
|
end
|
|
end
|
|
|
|
# GET /metacodes/1/edit
|
|
def edit
|
|
@metacode = Metacode.find(params[:id])
|
|
end
|
|
|
|
# POST /metacodes
|
|
# POST /metacodes.json
|
|
def create
|
|
@metacode = Metacode.new(metacode_params)
|
|
|
|
respond_to do |format|
|
|
if @metacode.save
|
|
format.html { redirect_to metacodes_url, notice: 'Metacode was successfully created.' }
|
|
format.json { render json: @metacode, status: :created, location: metacodes_url }
|
|
else
|
|
format.html { render action: "new" }
|
|
format.json { render json: @metacode.errors, status: :unprocessable_entity }
|
|
end
|
|
end
|
|
end
|
|
|
|
# PUT /metacodes/1
|
|
# PUT /metacodes/1.json
|
|
def update
|
|
@metacode = Metacode.find(params[:id])
|
|
|
|
respond_to do |format|
|
|
if @metacode.update_attributes(metacode_params)
|
|
format.html { redirect_to metacodes_url, notice: 'Metacode was successfully updated.' }
|
|
format.json { head :no_content }
|
|
else
|
|
format.html { render action: "edit" }
|
|
format.json { render json: @metacode.errors, status: :unprocessable_entity }
|
|
end
|
|
end
|
|
end
|
|
|
|
|
|
### DESTROY IS CURRENTLY DISABLED
|
|
# DELETE /metacodes/1
|
|
# DELETE /metacodes/1.json
|
|
# def destroy
|
|
# @metacode = Metacode.find(params[:id])
|
|
# @metacode.destroy
|
|
#
|
|
# respond_to do |format|
|
|
# format.html { redirect_to metacodes_url }
|
|
# format.json { head :no_content }
|
|
# end
|
|
# end
|
|
|
|
private
|
|
|
|
# Never trust parameters from the scary internet, only allow the white list through.
|
|
def metacode_params
|
|
params.require(:metacode).permit(:id, :name, :icon, :color)
|
|
end
|
|
end
|