55 lines
1.3 KiB
Ruby
55 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class AppSignUpService < BaseService
|
|
include RegistrationHelper
|
|
|
|
def call(app, remote_ip, params)
|
|
@app = app
|
|
@remote_ip = remote_ip
|
|
@params = params
|
|
|
|
raise Mastodon::NotPermittedError unless allowed_registration?(remote_ip, invite)
|
|
|
|
ApplicationRecord.transaction do
|
|
create_user!
|
|
create_access_token!
|
|
end
|
|
|
|
@access_token
|
|
end
|
|
|
|
private
|
|
|
|
def create_user!
|
|
@user = User.create!(
|
|
user_params.merge(created_by_application: @app, sign_up_ip: @remote_ip, password_confirmation: user_params[:password], account_attributes: account_params, invite_request_attributes: invite_request_params)
|
|
)
|
|
end
|
|
|
|
def create_access_token!
|
|
@access_token = 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
|
|
|
|
def invite
|
|
Invite.find_by(code: @params[:invite_code]) if @params[:invite_code].present?
|
|
end
|
|
|
|
def user_params
|
|
@params.slice(:email, :password, :agreement, :locale, :time_zone, :invite_code)
|
|
end
|
|
|
|
def account_params
|
|
@params.slice(:username)
|
|
end
|
|
|
|
def invite_request_params
|
|
{ text: @params[:reason] }
|
|
end
|
|
end
|