/app/controllers/books_controller.rb
Ruby | 77 lines | 52 code | 10 blank | 15 comment | 2 complexity | 4d7cc725cb8db6090229fb72d7cbb441 MD5 | raw file
- class BooksController < ApplicationController
- before_action :set_book, only: [:show, :edit, :update, :destroy]
- before_action :authenticate_user!
- # GET /books
- # GET /books.json
- def index
- #@books = Book.all
- @q = Book.ransack(params[:q])
- @books = @q.result
- end
- # GET /books/1
- # GET /books/1.json
- def show
- end
- # GET /books/new
- def new
- @book = Book.new
- end
- # GET /books/1/edit
- def edit
- end
- # POST /books
- # POST /books.json
- def create
- @book = Book.new(book_params)
- respond_to do |format|
- if @book.save
- format.html { redirect_to @book, notice: 'Book was successfully created.' }
- format.json { render :show, status: :created, location: @book }
- else
- format.html { render :new }
- format.json { render json: @book.errors, status: :unprocessable_entity }
- end
- end
- end
- # PATCH/PUT /books/1
- # PATCH/PUT /books/1.json
- def update
- respond_to do |format|
- if @book.update(book_params)
- format.html { redirect_to @book, notice: 'Book was successfully updated.' }
- format.json { render :show, status: :ok, location: @book }
- else
- format.html { render :edit }
- format.json { render json: @book.errors, status: :unprocessable_entity }
- end
- end
- end
- # DELETE /books/1
- # DELETE /books/1.json
- def destroy
- @book.destroy
- respond_to do |format|
- format.html { redirect_to books_url, notice: 'Book was successfully destroyed.' }
- format.json { head :no_content }
- end
- end
- private
- # Use callbacks to share common setup or constraints between actions.
- def set_book
- @book = Book.find(params[:id])
- end
- # Never trust parameters from the scary internet, only allow the white list through.
- def book_params
- params.require(:book).permit(:name, :id_publisher, :id_author, :synopsis, :pages, :releaseYear, :language)
- end
- end