2018-12-24 10:12:38 -08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class AppSignUpService < BaseService
|
|
|
|
def call(app, params)
|
|
|
|
return unless allowed_registrations?
|
|
|
|
|
2019-01-07 05:50:20 -08:00
|
|
|
user_params = params.slice(:email, :password, :agreement, :locale)
|
2018-12-24 10:12:38 -08:00
|
|
|
account_params = params.slice(:username)
|
|
|
|
user = User.create!(user_params.merge(created_by_application: app, password_confirmation: user_params[:password], account_attributes: account_params))
|
|
|
|
|
|
|
|
Doorkeeper::AccessToken.create!(application: app,
|
|
|
|
resource_owner_id: user.id,
|
|
|
|
scopes: app.scopes,
|
|
|
|
expires_in: Doorkeeper.configuration.access_token_expires_in,
|
|
|
|
use_refresh_token: Doorkeeper.configuration.refresh_token_enabled?)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def allowed_registrations?
|
|
|
|
Setting.open_registrations && !Rails.configuration.x.single_user_mode
|
|
|
|
end
|
|
|
|
end
|