Sha256: bb75409caf94b666cab2adbe27448234a48ce97ce6165fed7e9756a46255a71c
Contents?: true
Size: 1.58 KB
Versions: 2
Compression:
Stored size: 1.58 KB
Contents
# frozen_string_literal: true module Ibrain::Auth::Mutations class SsoSignInMutation < BaseMutation field :user, Types::Objects::UserType, null: true field :token, String, null: true field :result, Boolean, null: true field :is_verified, Boolean, null: true argument :id_token, String, description: 'Id Token from SSO', required: true argument :device_token, String, description: 'Device token for notificaiton', required: false def resolve(args) # TODO: define logic inside repository repo = ::AuthRepository.new(nil, normalize_params(args)) user = repo.sign_in return OpenStruct.new({ user: nil, token: nil, result: false, is_verified: false }) if user.blank? sign_in(resource_name, user) @current_user = warden.authenticate!(auth_options) warden.set_user(current_user) current_user.jwt_token, jti = auth_headers(request, user) current_user.jti = jti current_user.save! if args[:device_token].present? device_token = current_user.device_tokens.find_by(token: args[:device_token]) current_user.device_tokens.create!({ token: args[:device_token] }) if device_token.blank? end context[:current_user] = current_user OpenStruct.new( user: user_signed_in? ? current_user : nil, token: current_user.try(:jwt_token), result: user_signed_in?, is_verified: true ) end private def normalize_params(args) ActionController::Parameters.new({ auth: args }) end def auth_options { scope: resource_name } end end end
Version data entries
2 entries across 2 versions & 1 rubygems
Version | Path |
---|---|
ibrain-auth-0.2.1 | app/graphql/ibrain/auth/mutations/sso_sign_in_mutation.rb |
ibrain-auth-0.2.0 | app/graphql/ibrain/auth/mutations/sso_sign_in_mutation.rb |