mirror of
https://github.com/internetee/registry.git
synced 2025-07-28 21:46:24 +02:00
Moved switch user method to accounts
This commit is contained in:
parent
6c9fb2b025
commit
de5872fb40
5 changed files with 26 additions and 23 deletions
|
@ -73,6 +73,22 @@ module Repp
|
||||||
message: I18n.t('registrar.settings.balance_auto_reload.destroy.disabled'))
|
message: I18n.t('registrar.settings.balance_auto_reload.destroy.disabled'))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
api :put, '/repp/v1/accounts/switch_user'
|
||||||
|
desc 'Switch user to another api user'
|
||||||
|
def switch_user
|
||||||
|
new_user = ApiUser.find(account_params[:new_user_id])
|
||||||
|
unless current_user.linked_with?(new_user)
|
||||||
|
handle_non_epp_errors(new_user, 'Cannot switch to unlinked user')
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
@current_user = new_user
|
||||||
|
data = auth_values_to_data(registrar: current_user.registrar)
|
||||||
|
message = I18n.t('registrar.current_user.switch.switched', new_user: new_user)
|
||||||
|
token = Base64.urlsafe_encode64("#{new_user.username}:#{new_user.plain_text_password}")
|
||||||
|
render_success(data: { token: token, registrar: data }, message: message)
|
||||||
|
end
|
||||||
|
|
||||||
api :get, '/repp/v1/accounts/balance'
|
api :get, '/repp/v1/accounts/balance'
|
||||||
desc "Get account's balance"
|
desc "Get account's balance"
|
||||||
def balance
|
def balance
|
||||||
|
@ -90,7 +106,7 @@ module Repp
|
||||||
private
|
private
|
||||||
|
|
||||||
def account_params
|
def account_params
|
||||||
params.require(:account).permit(:billing_email, :iban)
|
params.require(:account).permit(:billing_email, :iban, :new_user_id)
|
||||||
end
|
end
|
||||||
|
|
||||||
def index_params
|
def index_params
|
||||||
|
|
|
@ -11,6 +11,7 @@ module Repp
|
||||||
q = records.ransack(search_params)
|
q = records.ransack(search_params)
|
||||||
q.sorts = 'created_at desc' if q.sorts.empty?
|
q.sorts = 'created_at desc' if q.sorts.empty?
|
||||||
invoices = q.result(distinct: true)
|
invoices = q.result(distinct: true)
|
||||||
|
|
||||||
limited_invoices = invoices.limit(limit).offset(offset)
|
limited_invoices = invoices.limit(limit).offset(offset)
|
||||||
.includes(:items, :account_activity, :buyer)
|
.includes(:items, :account_activity, :buyer)
|
||||||
|
|
||||||
|
|
|
@ -23,22 +23,6 @@ module Repp
|
||||||
render_success(data: { token: token, username: user.username })
|
render_success(data: { token: token, username: user.username })
|
||||||
end
|
end
|
||||||
|
|
||||||
api :put, '/repp/v1/registrar/auth/switch_user'
|
|
||||||
desc 'Switch session to another api user'
|
|
||||||
def switch_user
|
|
||||||
new_user = ApiUser.find(auth_params[:new_user_id])
|
|
||||||
unless current_user.linked_with?(new_user)
|
|
||||||
handle_non_epp_errors(new_user, 'Cannot switch to unlinked user')
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
@current_user = new_user
|
|
||||||
data = auth_values_to_data(registrar: current_user.registrar)
|
|
||||||
message = I18n.t('registrar.current_user.switch.switched', new_user: new_user)
|
|
||||||
token = Base64.urlsafe_encode64("#{new_user.username}:#{new_user.plain_text_password}")
|
|
||||||
render_success(data: { token: token, registrar: data }, message: message)
|
|
||||||
end
|
|
||||||
|
|
||||||
private
|
private
|
||||||
|
|
||||||
def auth_params
|
def auth_params
|
||||||
|
|
|
@ -83,6 +83,9 @@ Rails.application.routes.draw do
|
||||||
post 'update_auto_reload_balance'
|
post 'update_auto_reload_balance'
|
||||||
get 'disable_auto_reload_balance'
|
get 'disable_auto_reload_balance'
|
||||||
end
|
end
|
||||||
|
member do
|
||||||
|
put 'switch_user'
|
||||||
|
end
|
||||||
end
|
end
|
||||||
resources :invoices, only: %i[index show] do
|
resources :invoices, only: %i[index show] do
|
||||||
collection do
|
collection do
|
||||||
|
@ -117,7 +120,6 @@ Rails.application.routes.draw do
|
||||||
resources :auth, only: %i[index] do
|
resources :auth, only: %i[index] do
|
||||||
collection do
|
collection do
|
||||||
post '/tara_callback', to: 'auth#tara_callback'
|
post '/tara_callback', to: 'auth#tara_callback'
|
||||||
put '/switch_user', to: 'auth#switch_user'
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
require 'test_helper'
|
require 'test_helper'
|
||||||
|
|
||||||
class ReppV1RegistrarSwitchUserTest < ActionDispatch::IntegrationTest
|
class ReppV1AccountsSwitchUserTest < ActionDispatch::IntegrationTest
|
||||||
def setup
|
def setup
|
||||||
@user = users(:api_bestnames)
|
@user = users(:api_bestnames)
|
||||||
token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}")
|
token = Base64.encode64("#{@user.username}:#{@user.plain_text_password}")
|
||||||
|
@ -13,12 +13,12 @@ class ReppV1RegistrarSwitchUserTest < ActionDispatch::IntegrationTest
|
||||||
new_user = users(:api_goodnames)
|
new_user = users(:api_goodnames)
|
||||||
new_user.update(identity_code: '1234')
|
new_user.update(identity_code: '1234')
|
||||||
request_body = {
|
request_body = {
|
||||||
auth: {
|
account: {
|
||||||
new_user_id: new_user.id,
|
new_user_id: new_user.id,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
put '/repp/v1/registrar/auth/switch_user', headers: @auth_headers, params: request_body
|
put '/repp/v1/accounts/switch_user', headers: @auth_headers, params: request_body
|
||||||
json = JSON.parse(response.body, symbolize_names: true)
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
assert_response :ok
|
assert_response :ok
|
||||||
|
@ -38,12 +38,12 @@ class ReppV1RegistrarSwitchUserTest < ActionDispatch::IntegrationTest
|
||||||
new_user = users(:api_goodnames)
|
new_user = users(:api_goodnames)
|
||||||
new_user.update(identity_code: '4444')
|
new_user.update(identity_code: '4444')
|
||||||
request_body = {
|
request_body = {
|
||||||
auth: {
|
account: {
|
||||||
new_user_id: new_user.id,
|
new_user_id: new_user.id,
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
put '/repp/v1/registrar/auth/switch_user', headers: @auth_headers, params: request_body
|
put '/repp/v1/accounts/switch_user', headers: @auth_headers, params: request_body
|
||||||
json = JSON.parse(response.body, symbolize_names: true)
|
json = JSON.parse(response.body, symbolize_names: true)
|
||||||
|
|
||||||
assert_response :bad_request
|
assert_response :bad_request
|
Loading…
Add table
Add a link
Reference in a new issue