Sha256: 84eea3e30ab17c24412b2ea4b1d0a4ba18a51e209c54e9ed658946f9c8928d01
Contents?: true
Size: 1.94 KB
Versions: 67
Compression:
Stored size: 1.94 KB
Contents
class ProductsController < ApplicationController before_action :set_product, only: %i[ show edit update destroy ] # GET /products or /products.json def index @products = Product.all end # GET /products/1 or /products/1.json def show end # GET /products/new def new # remove this comment to see error in Honeybadger raise 'Oh No!' @product = Product.new end # GET /products/1/edit def edit end # POST /products or /products.json def create @product = Product.new(product_params) respond_to do |format| if @product.save format.html { redirect_to product_url(@product), notice: "Product was successfully created." } format.json { render :show, status: :created, location: @product } else format.html { render :new, status: :unprocessable_entity } format.json { render json: @product.errors, status: :unprocessable_entity } end end end # PATCH/PUT /products/1 or /products/1.json def update respond_to do |format| if @product.update(product_params) format.html { redirect_to product_url(@product), notice: "Product was successfully updated." } format.json { render :show, status: :ok, location: @product } else format.html { render :edit, status: :unprocessable_entity } format.json { render json: @product.errors, status: :unprocessable_entity } end end end # DELETE /products/1 or /products/1.json def destroy @product.destroy respond_to do |format| format.html { redirect_to products_url, notice: "Product was successfully destroyed." } format.json { head :no_content } end end private # Use callbacks to share common setup or constraints between actions. def set_product @product = Product.find(params[:id]) end # Only allow a list of trusted parameters through. def product_params params.require(:product).permit(:name, :price) end end
Version data entries
67 entries across 67 versions & 1 rubygems