Skip to content
Extraits de code Groupes Projets
users_controller.rb 6,3 ko
Newer Older
danielgrippi's avatar
danielgrippi a validé
#   Copyright (c) 2010-2011, Diaspora Inc.  This file is
Raphael's avatar
Raphael a validé
#   licensed under the Affero General Public License version 3 or later.  See
Raphael's avatar
Raphael a validé
#   the COPYRIGHT file.
class UsersController < ApplicationController
Augier's avatar
Augier a validé
  before_action :authenticate_user!, except: %i(new create public user_photo)
Raphael's avatar
Raphael a validé

  def edit
    @user = current_user
    set_email_preferences
Raphael's avatar
Raphael a validé
  end

  def privacy_settings
    @blocks = current_user.blocks.includes(:person)
  end

Raphael's avatar
Raphael a validé
  def update
    @user = current_user
James Fleming's avatar
James Fleming a validé
    if u = user_params
      # change email notifications
      if u[:email_preferences]
        @user.update_user_preferences(u[:email_preferences])
aoh0x7DE's avatar
aoh0x7DE a validé
        flash[:notice] = I18n.t "users.update.email_notifications_changed"
      elsif params[:change_password]
        if @user.update_with_password(u)
          password_changed = true
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.password_changed"
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:error] = I18n.t "users.update.password_not_changed"
      elsif u[:show_community_spotlight_in_stream] || u[:getting_started]
        if @user.update_attributes(u)
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.settings_updated"
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.settings_not_updated"
      elsif u[:strip_exif]
        if @user.update_attributes(u)
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.settings_updated"
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.settings_not_updated"
        if @user.update_attributes(u)
          I18n.locale = @user.language
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.language_changed"
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:error] = I18n.t "users.update.language_not_changed"
      elsif u[:email]
        @user.unconfirmed_email = u[:email]
        if @user.save
          @user.send_confirm_email
movilla's avatar
movilla a validé
          if @user.unconfirmed_email
aoh0x7DE's avatar
aoh0x7DE a validé
            flash[:notice] = I18n.t "users.update.unconfirmed_email_changed"
movilla's avatar
movilla a validé
          end
aoh0x7DE's avatar
aoh0x7DE a validé
          @user.reload # match user object with the database
          flash[:error] = I18n.t "users.update.unconfirmed_email_not_changed"
      elsif u[:auto_follow_back]
        if  @user.update_attributes(u)
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:notice] = I18n.t "users.update.follow_settings_changed"
aoh0x7DE's avatar
aoh0x7DE a validé
          flash[:error] = I18n.t "users.update.follow_settings_not_changed"
      elsif u[:color_theme]
        if @user.update_attributes(u)
          flash[:notice] = I18n.t "users.update.color_theme_changed"
        else
          flash[:error] = I18n.t "users.update.color_theme_not_changed"
        end
danielvincent's avatar
danielvincent a validé

    respond_to do |format|
      format.js   { render :nothing => true, :status => 204 }
      format.all  do
        if password_changed
          redirect_to new_user_session_path
        else
          render :edit
        end
      end
Raphael's avatar
Raphael a validé
  end
ilya's avatar
ilya a validé
  def destroy
Sarah Mei's avatar
Sarah Mei a validé
    if params[:user] && params[:user][:current_password] && current_user.valid_password?(params[:user][:current_password])
      sign_out current_user
      redirect_to(new_user_session_path(format: request[:format]), notice: I18n.t("users.destroy.success"))
      if params[:user].present? && params[:user][:current_password].present?
aoh0x7DE's avatar
aoh0x7DE a validé
        flash[:error] = t "users.destroy.wrong_password"
aoh0x7DE's avatar
aoh0x7DE a validé
        flash[:error] = t "users.destroy.no_password"
ilya's avatar
ilya a validé
  end

    if @user = User.find_by_username(params[:username])
      respond_to do |format|
Jonne Haß's avatar
Jonne Haß a validé
          @posts = Post.where(author_id: @user.person_id, public: true)
aoh0x7DE's avatar
aoh0x7DE a validé
                       .order("created_at DESC")
                       .limit(25)
                       .map {|post| post.is_a?(Reshare) ? post.absolute_root : post }
                       .compact
        format.any { redirect_to person_path(@user.person) }
aoh0x7DE's avatar
aoh0x7DE a validé
      redirect_to stream_path, error: I18n.t("users.public.does_not_exist", username: params[:username])
danielvincent's avatar
danielvincent a validé
  def getting_started
    @user     = current_user
    @person   = @user.person
    @profile  = @user.profile
    gon.preloads[:inviter] = PersonPresenter.new(current_user.invited_by.try(:person), current_user).as_json
    render "users/getting_started"
danielvincent's avatar
danielvincent a validé
  end

  def getting_started_completed
    user = current_user
James Fleming's avatar
James Fleming a validé
    user.getting_started = false
    user.save
  def export_profile
    current_user.queue_export
aoh0x7DE's avatar
aoh0x7DE a validé
    flash[:notice] = I18n.t("users.edit.export_in_progress")
    redirect_to edit_user_path
  end

  def download_profile
    redirect_to current_user.export.url
  def export_photos
    current_user.queue_export_photos
aoh0x7DE's avatar
aoh0x7DE a validé
    flash[:notice] = I18n.t("users.edit.export_photos_in_progress")
    redirect_to edit_user_path
  def download_photos
    redirect_to current_user.exported_photos_file.url
  end
  def user_photo
    username = params[:username].split('@')[0]
    user = User.find_by_username(username)
    if user.present?
      redirect_to user.image_url
    else
      render :nothing => true, :status => 404
    end
  end

  def confirm_email
    if current_user.confirm_email(params[:token])
aoh0x7DE's avatar
aoh0x7DE a validé
      flash[:notice] = I18n.t("users.confirm_email.email_confirmed", email: current_user.email)
    elsif current_user.unconfirmed_email.present?
aoh0x7DE's avatar
aoh0x7DE a validé
      flash[:error] = I18n.t("users.confirm_email.email_not_confirmed")
    end
    redirect_to edit_user_path
  end
James Fleming's avatar
James Fleming a validé

  private

  def user_params
    params.fetch(:user).permit(
      :email,
      :current_password,
      :password,
      :password_confirmation,
      :language,
      :color_theme,
      :disable_mail,
      :invitation_service,
      :invitation_identifier,
      :show_community_spotlight_in_stream,
      :strip_exif,
      :auto_follow_back,
      :auto_follow_back_aspect_id,
      :remember_me,
      :getting_started,
      email_preferences: [
        :also_commented,
        :mentioned,
        :comment_on_post,
        :private_message,
        :started_sharing,
        :liked,
        :reshared
      ]
    )
James Fleming's avatar
James Fleming a validé
  end

  def set_email_preferences
    @email_prefs = Hash.new(true)

    @user.user_preferences.each do |pref|
      @email_prefs[pref.email_type] = false
    end
  end
Jamie Wilkinson's avatar
Jamie Wilkinson a validé
end