|
|
|
class Users::ApplyAuthenticationService < ApplicationService
|
|
|
|
attr_reader :user, :params
|
|
|
|
|
|
|
|
def initialize(user, params)
|
|
|
|
@user = user
|
|
|
|
@params = params
|
|
|
|
end
|
|
|
|
|
|
|
|
def call
|
|
|
|
raise Error, '请先完善基本信息' unless user.profile_completed?
|
|
|
|
|
|
|
|
Users::ApplyAuthenticationForm.new(params).validate!
|
|
|
|
raise Error, '您已经申请过实名认证了' if ApplyUserAuthentication.real_name_auth.processing.exists?(user_id: user.id)
|
|
|
|
|
|
|
|
user.lastname = params[:name].to_s.strip
|
|
|
|
user.firstname = ''
|
|
|
|
user.ID_number = params[:id_number].to_s.strip.presence
|
|
|
|
|
|
|
|
ActiveRecord::Base.transaction do
|
|
|
|
user.authentication = false
|
|
|
|
user.save!
|
|
|
|
|
|
|
|
user.user_extension.update!(gender: params[:gender].to_i) if params[:gender].present?
|
|
|
|
|
|
|
|
user.apply_user_authentication.create!(auth_type: 1, status: 0)
|
|
|
|
|
|
|
|
move_image_file! unless params[:upload_image].to_s == 'false'
|
|
|
|
end
|
|
|
|
|
|
|
|
sms_notify_admin
|
|
|
|
|
|
|
|
user
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def move_image_file!
|
|
|
|
image_url = ApplicationController.helpers.disk_real_name_auth_filename(user.id)
|
|
|
|
temp_image_url = image_url + 'temp'
|
|
|
|
|
|
|
|
FileUtils.mv(temp_image_url, image_url, force: true) if File.exist?(temp_image_url)
|
|
|
|
rescue RuntimeError => ex
|
|
|
|
Util.logger_error(ex)
|
|
|
|
raise Error, '申请失败'
|
|
|
|
ensure
|
|
|
|
File.delete(temp_image_url) if File.exist?(temp_image_url)
|
|
|
|
end
|
|
|
|
|
|
|
|
def sms_notify_admin
|
|
|
|
Educoder::Sms.notify_admin(send_type: 'apply_auth')
|
|
|
|
rescue => ex
|
|
|
|
Util.logger_error(ex)
|
|
|
|
end
|
|
|
|
end
|