現在SNSアプリの作成をしている者です。
各ユーザーのマイページにて各ユーザーの投稿を表示させたいのですが、stack level too deepとなり、サーバーがストップしてしまいます。
こちらが該当のソースコードです。
users/show.html.erb
<% @user.posts.each do |post| %> <div class="title"><%= post.title %></div> <div class="picture"><%= image_tag post.picture.to_s %></div> <div class="user"><%= link_to post.user.name, post.user %></div> <div class="time"><%= post.created_at.to_s(:datetime_base) %></div> <div class="postdetail"><%= link_to "詳細" , post,class: 'btn btn-outline-info' %></div> <div class="delatebtn"><%= link_to "削除" , post, class: 'btn btn-outline-info', method: :delete, data: {confirm: "投稿記事を削除しますか?", cancel: "キャンセル", commit: "削除する", title: "削除の確認"} %></div> <% end %>
posts_controller.rb
class PostsController < ApplicationController def index @posts = params[:tag_id].present? ? Tag.find(params[:tag_id]).posts : Post.all @posts = Post.page(params[:page]) end def new @post = Post.new(flash[:board]) end def create @post = Post.new(post_params) @post.user = current_user @Post = Post.new( content: params[:content],user_id: @current_user.id ) if @post.save flash[:notice] = "「#{@post.title}」の記事が投稿されました!" redirect_to @post else redirect_to new_post_path, flash: { post: @post, error_messages: @post.errors.full_messages } end end def show @post = Post.find(params[:id]) @comment = Comment.new(post_id: @post.id) end def edit @post = Post.find(params[:id]) end def update post = Post.find(params[:id]) post.update(post_params) flash[:notice] = "「#{@post.title}」の記事を更新しました!" redirect_to @post end def destroy @post = Post.find(params[:id]) @post.delete flash[:notice] = "「#{@post.title}」の記事を削除しました!" redirect_to posts_path end private def post_params params.require(:post).permit(:title, :content, :picture, tag_ids:[]) end def set_target_post @post = Post.find(params[:id]) end def ensure_correct_user @post = Post.find_by(id:params[:id]) if @post.user_id != @current_user.id flash[:notice] = "権限がありません" redirect_to("/posts/index") end end end
users_controller.rb
class UsersController < ApplicationController def show @user = User.find(params[:id]) end def new @user = User.new end def create @user = User.new(user_params) if @user.save log_in @user flash[:success] = "Tsukutta!へようこそ" redirect_to @user else flash[:error_messages] = @user.errors.full_messages render 'new' end end def edit @user = User.find(params[:id]) end def update @user = User.find(params[:id]) if @user.update_attributes(user_params) flash[:success] = "プロフィールが更新されました!" redirect_to @user else render'edit' end end private def user_params params.require(:user).permit(:name, :email, :password, :password_confirmation) end end
##参考にしたサイト
また、以下のサイトも参考にし、確認してみましたが当方と異なるパターンだったため、こちらに質問させていただきました。
stack level too deepのエラーを解決したい
##開発環境
AWSのcloud9を使用しています。
rubyのバージョンは 2.4.1p111
railsのバージョンはRails 5.0.7 です。
どなたか解決方法をご存知の方がいらっしゃればご教示いただけないでしょうか。
よろしくお願いします。
【追記】
モデルのコードを掲載します。
user.rb
class User < ApplicationRecord attr_accessor :remember_token has_many :favorites, through: :favorites, source: :post, dependent: :destroy has_many :posts, through: :favorites, dependent: :destroy ,foreign_key: 'user' before_save { email.downcase! } validates :name, presence: true, length: { maximum: 50 } VALID_EMAIL_REGEX = /\A[\w+\-.]+@[a-z\d\-]+(.[a-z\d\-]+)*.[a-z]+\z/i validates :email, presence: true, length: { maximum: 255 }, format: { with: VALID_EMAIL_REGEX }, uniqueness: { case_sensitive: false } has_secure_password validates :password, presence: true, length: { minimum: 6 }, allow_nil: true def self.digest(string) cost = ActiveModel::SecurePassword.min_cost ? BCrypt::Engine::MIN_COST : BCrypt::Engine.cost BCrypt::Password.create(string, cost: cost) end def self.new_token SecureRandom.urlsafe_base64 end def remember self.remember_token = User.new_token update_attribute(:remember_digest, User.digest(remember_token)) end def authenticated?(remember_token) return false if remember_digest.nil? BCrypt::Password.new(remember_digest).is_password?(remember_token) end def forget update_attribute(:remember_digest, nil) end end
post.rb
class Post < ApplicationRecord has_many :posts, dependent: :destroy has_many :comments, dependent: :delete_all has_many :post_tag_relations, dependent: :delete_all has_many :tags, through: :post_tag_relations belongs_to :user validates :user_id, presence: true default_scope -> { order(created_at: :desc) } # presence -> # length -> # validates :name, presence: true, length: { maximum: 30 } validates :title, presence: true, length: { maximum: 30 } validates :content, presence: true, length: { maximum: 1000 } mount_uploader :picture, PictureUploader validates :user, presence:true has_many :favorites, dependent: :destroy has_many :users, through: :favorites validates :user_id,presence: true validates :content, presence: true, length: { maximum: 140 } end
回答2件