2017-01-21 5 views
-1

Je crée une application ruby ​​on rails de base similaire à zapier ou ifttt. Les utilisateurs créent des recettes. Je voudrais afficher uniquement les recettes créées par l'utilisateur.Ruby on rails - Devise - Afficher uniquement le contenu créé par l'utilisateur

J'ai utilisé un périphérique gem pour l'authentification.

Mes questions:

-je ajouter "si user_signed_in?" en haut de chaque page? Puis-je ajouter le rendement ci-dessus sur les mises en page d'applications? Y a-t-il un meilleur moyen?

Dois-je imbriquer des recettes au sein des utilisateurs?

+1

Montrez du code avec lequel vous avez déjà essayé. – 31piy

Répondre

0

En supposant que vous avez un a plusieurs entre l'utilisateur et la recette

Vous pouvez faire quelque chose comme ça. Utilisez l'assistant current_user fourni par concevoir et référencez vos recettes en utilisant current_user.

Par conséquent, sur n'importe quelle page concernant les recettes, vous recherchez uniquement les recettes créées par l'utilisateur.

class RecipesController < ApplicationController 
    before_action :set_recipe, only: [:show, :edit, :update, :destroy] 

    # GET /recipes 
    # GET /recipes.json 
    def index 
    @recipes = current_user.recipes 
    end 

    # GET /recipes/1 
    # GET /recipes/1.json 
    def show 
    end 

    # GET /recipes/new 
    def new 
    @recipe = current_user.recipes.build 
    end 

    # GET /recipes/1/edit 
    def edit 
    end 

    # POST /recipes 
    # POST /recipes.json 
    def create 
    @recipe = current_user.recipes.build(recipe_params) 

    respond_to do |format| 
     if @recipe.save 
     format.html { redirect_to @recipe, notice: 'Recipie was successfully created.' } 
     format.json { render :show, status: :created, location: @recipe } 
     else 
     format.html { render :new } 
     format.json { render json: @recipe.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

    # PATCH/PUT /recipes/1 
    # PATCH/PUT /recipes/1.json 
    def update 
    respond_to do |format| 
     if @recipe.update(recipe_params) 
     format.html { redirect_to @recipe, notice: 'Recipie was successfully updated.' } 
     format.json { render :show, status: :ok, location: @recipe } 
     else 
     format.html { render :edit } 
     format.json { render json: @recipe.errors, status: :unprocessable_entity } 
     end 
    end 
    end 

    # DELETE /recipes/1 
    # DELETE /recipes/1.json 
    def destroy 
    @recipe.destroy 
    respond_to do |format| 
     format.html { redirect_to recipes_url, notice: 'Recipie was successfully destroyed.' } 
     format.json { head :no_content } 
    end 
    end 

    private 
    # Use callbacks to share common setup or constraints between actions. 
    def set_recipe 
     @recipe = current_user.recipes.find(params[:id]) 
    end 

    # Never trust parameters from the scary internet, only allow the white list through. 
    def recipe_params 
     params.fetch(:recipe, {...}) 
    end 
end 
+0

Merci. Ça a marché! –