Sha256: 6c2c3320ff4d8f62129fd804e06eb6a63627d73ee0a39ac697ac228720459860

Contents?: true

Size: 1.74 KB

Versions: 85

Compression:

Stored size: 1.74 KB

Contents

module Api::V1::Users::ControllerBase
  extend ActiveSupport::Concern

  module StrongParameters
    # Only allow a list of trusted parameters through.
    def user_params
      password_fields = [
        :email,
        :password,
        :current_password,
        :password_confirmation
      ]
      general_fields = [
        :first_name,
        :last_name,
        :time_zone,
        :locale,
        :profile_photo_id, # For Cloudinary
        :profile_photo,    # For ActiveStorage
        :profile_photo_removal
      ]

      selected_fields = if params.is_a?(BulletTrain::Api::StrongParametersReporter)
        password_fields + general_fields
      else
        (params["commit"] == t(".buttons.update_email_and_password")) ? password_fields : general_fields
      end

      strong_params = params.require(:user).permit(
        *permitted_fields,
        *selected_fields,
        # 🚅 super scaffolding will insert new fields above this line.
        *permitted_arrays,
        # 🚅 super scaffolding will insert new arrays above this line.
      )

      process_params(strong_params)

      strong_params
    end
  end

  included do
    load_and_authorize_resource :user, class: "User", prepend: true,
      member_actions: (defined?(MEMBER_ACTIONS) ? MEMBER_ACTIONS : []),
      collection_actions: (defined?(COLLECTION_ACTIONS) ? COLLECTION_ACTIONS : [])

    prepend_before_action :resolve_me

    private

    include StrongParameters
  end

  # GET /api/v1/users
  def index
  end

  def resolve_me
    if current_user && params[:id]&.downcase == "me"
      params[:id] = current_user.id
    end
  end

  # GET /api/v1/users/:id
  def show
  end

  # PUT /api/v1/users/:id
  # TODO: Implement this!
  def update
    raise "Not implemented"
  end
end

Version data entries

85 entries across 85 versions & 1 rubygems

Version Path
bullet_train-api-1.7.18 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.17 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.16 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.15 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.14 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.13 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.12 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.11 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.10 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.9 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.3 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.2 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.1 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.7.0 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.38 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.37 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.36 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.35 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.34 app/controllers/concerns/api/v1/users/controller_base.rb
bullet_train-api-1.6.33 app/controllers/concerns/api/v1/users/controller_base.rb