You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
1.3 KiB

class UsersController < ApplicationController
before_action :require_signin, except: [:new, :create]
before_action :set_user, only: [:show, :edit, :update, :destroy, :require_correct_user]
before_action :require_correct_user, only: [:edit, :update, :destroy]
def index
@users = User.all
end
def new
@user = User.new
end
def show
@reviews = @user.reviews
@favorite_movies = @user.favorite_movies
end
def create
@user = User.new(user_params)
if @user.save
session[:user_id] = @user.id
redirect_to @user, notice: "Thanks for signing up!"
else
render :new, status: :unprocessable_entity
end
end
def edit
end
def update
if @user.update(user_params)
redirect_to @user, notice: "Account successfully updated!"
else
render :edit, status: :unprocessable_entity
end
end
def destroy
@user.destroy
session[:user_id] = nil
redirect_to movies_url, status: :see_other, alert: "Account successfully deleted!"
end
private
def set_user
@user = User.find(params[:id])
end
def user_params
params.require(:user).permit(:name, :email, :password, :password_confirmation)
end
def require_correct_user
unless current_user?(@user)
redirect_to root_url, status: :see_other
end
end
end