diff options
author | HombreLaser <sebastian-440@live.com> | 2023-02-25 00:20:23 -0600 |
---|---|---|
committer | HombreLaser <sebastian-440@live.com> | 2023-02-25 00:20:23 -0600 |
commit | a64b2dfeb543ef38f4c7cd38eb05baec9e84a2d9 (patch) | |
tree | 4448177d2a8f2a567d7dd5b75074a30f805528c1 | |
parent | 10ec03fbdfa0c7394c58aa64094c94aeb1887d86 (diff) |
Refactoriza las clases de logic
3 files changed, 55 insertions, 7 deletions
diff --git a/app/controllers/api/authentications_controller/create_logic.rb b/app/controllers/api/authentications_controller/create_logic.rb index c62c300..2f42852 100644 --- a/app/controllers/api/authentications_controller/create_logic.rb +++ b/app/controllers/api/authentications_controller/create_logic.rb @@ -4,6 +4,8 @@ module Api class AuthenticationsController # The logic for the create method of AuthenticationsController. class CreateLogic + include TokenGenerationConcern + def initialize(params) @email = params[:email] @password = params[:password] @@ -13,17 +15,12 @@ module Api def call return unless @user_account&.authenticate(@password) - @user_account.session_key = SecureRandom.hex(16) - @user_account.save - { token: service.call(DateTime.current + 30.minutes), refresh: service.call(DateTime.current + 3.days) } + generate_user_session_key + generate_token end private - def service - @service ||= Services::TokenGenerationService.new(service_params) - end - def service_params { email: @email, role: @user_account.role, session_key: @user_account.session_key } end diff --git a/app/controllers/api/user_accounts_controller/create_logic.rb b/app/controllers/api/user_accounts_controller/create_logic.rb new file mode 100644 index 0000000..3876c00 --- /dev/null +++ b/app/controllers/api/user_accounts_controller/create_logic.rb @@ -0,0 +1,31 @@ +# frozen_string_literal: true + +module Api + class UserAccountsController + # The UserAccountsController CreateLogic class. + class CreateLogic + attr_reader :user_account + + include TokenGenerationConcern + + def initialize(params) + @params = params + end + + def call + @user_account = UserAccount.new(@params) + + return unless @user_account.save + + generate_user_session_key + generate_token + end + + private + + def service_params + { email: @user_account.email, role: @user_account.role, session_key: @user_account.session_key } + end + end + end +end diff --git a/app/controllers/concerns/token_generation_concern.rb b/app/controllers/concerns/token_generation_concern.rb new file mode 100644 index 0000000..7f43e4c --- /dev/null +++ b/app/controllers/concerns/token_generation_concern.rb @@ -0,0 +1,20 @@ +# frozen_string_literal: true + +# Common logic for all the logics that require the token generation +# service. +module TokenGenerationConcern + extend ActiveSupport::Concern + + def service + @service ||= Services::TokenGenerationService.new(service_params) + end + + def generate_user_session_key + @user_account.session_key = SecureRandom.hex(16) + @user_account.save + end + + def generate_token + { token: service.call(DateTime.current + 30.minutes), refresh: service.call(DateTime.current + 3.days) } + end +end |