mirror of
https://github.com/lingble/chatwoot.git
synced 2025-11-01 19:48:08 +00:00
* feat: add clearbit lookup * chore: fix typo in .env.example * refactor: split lookup to reduce cognitive complexity * feat: add more fields to lookup * feat: extend accounts controller * feat: save extra data to custom_attributes * feat: allow v2 update with custom_attributes * feat: add update route * refactor: reduce complexity * feat: move update to v1 controller * test: add locale test * feat: remove update from routes * test: update API for custom attributes * test: all custom attributes * fix: v2 tests * test: enterprise accounts controller * fix: clearbit payload * fix: with modified env * feat: allow custom attributes updates to profile * refactor: reduce complexity * feat: allow clearbit api key in installation config * refactor: move clearbit to internal * feat: allow clearbit * chore: add display_title for June * feat: allow more internal options * refactor: use globalconfig to fetch clearbit token * test: move response body to a factory * refactor: update ops * chore: remove clearbit from .env.example * chore: apply suggestions from code review Co-authored-by: sojan-official <sojan@chatwoot.com> --------- Co-authored-by: sojan-official <sojan@chatwoot.com>
79 lines
1.8 KiB
Ruby
79 lines
1.8 KiB
Ruby
class Api::V1::ProfilesController < Api::BaseController
|
|
before_action :set_user
|
|
|
|
def show; end
|
|
|
|
def update
|
|
if password_params[:password].present?
|
|
render_could_not_create_error('Invalid current password') and return unless @user.valid_password?(password_params[:current_password])
|
|
|
|
@user.update!(password_params.except(:current_password))
|
|
end
|
|
|
|
@user.assign_attributes(profile_params)
|
|
@user.custom_attributes.merge!(custom_attributes_params)
|
|
@user.save!
|
|
end
|
|
|
|
def avatar
|
|
@user.avatar.attachment.destroy! if @user.avatar.attached?
|
|
head :ok
|
|
end
|
|
|
|
def auto_offline
|
|
@user.account_users.find_by!(account_id: auto_offline_params[:account_id]).update!(auto_offline: auto_offline_params[:auto_offline] || false)
|
|
end
|
|
|
|
def availability
|
|
@user.account_users.find_by!(account_id: availability_params[:account_id]).update!(availability: availability_params[:availability])
|
|
end
|
|
|
|
def set_active_account
|
|
@user.account_users.find_by(account_id: profile_params[:account_id]).update(active_at: Time.now.utc)
|
|
head :ok
|
|
end
|
|
|
|
def resend_confirmation
|
|
@user.send_confirmation_instructions unless @user.confirmed?
|
|
head :ok
|
|
end
|
|
|
|
private
|
|
|
|
def set_user
|
|
@user = current_user
|
|
end
|
|
|
|
def availability_params
|
|
params.require(:profile).permit(:account_id, :availability)
|
|
end
|
|
|
|
def auto_offline_params
|
|
params.require(:profile).permit(:account_id, :auto_offline)
|
|
end
|
|
|
|
def profile_params
|
|
params.require(:profile).permit(
|
|
:email,
|
|
:name,
|
|
:display_name,
|
|
:avatar,
|
|
:message_signature,
|
|
:account_id,
|
|
ui_settings: {}
|
|
)
|
|
end
|
|
|
|
def custom_attributes_params
|
|
params.require(:profile).permit(:phone_number)
|
|
end
|
|
|
|
def password_params
|
|
params.require(:profile).permit(
|
|
:current_password,
|
|
:password,
|
|
:password_confirmation
|
|
)
|
|
end
|
|
end
|