parent
485267021a
commit
7f52fa5b6e
@ -0,0 +1,24 @@
|
|||||||
|
class Gitea::UserForm
|
||||||
|
EMAIL_REGEX = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/
|
||||||
|
|
||||||
|
include ActiveModel::Model
|
||||||
|
attr_accessor :username, :email, :password
|
||||||
|
|
||||||
|
validates :username, presence: true
|
||||||
|
validates :email, presence: true, format: { with: EMAIL_REGEX, multiline: true }
|
||||||
|
validates :password, presence: true
|
||||||
|
|
||||||
|
attr_reader :record
|
||||||
|
|
||||||
|
def persist
|
||||||
|
@record = id ? User.find(id) : User.new
|
||||||
|
|
||||||
|
if valid?
|
||||||
|
@record.attributes = attributes.except(:password_confirmation, :id)
|
||||||
|
@record.save!
|
||||||
|
true
|
||||||
|
else
|
||||||
|
false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,31 @@
|
|||||||
|
class Gitea::RegisterInteractor
|
||||||
|
def self.call(params)
|
||||||
|
interactor = new(params)
|
||||||
|
interactor.run
|
||||||
|
interactor
|
||||||
|
end
|
||||||
|
|
||||||
|
attr_reader :error
|
||||||
|
|
||||||
|
def initialize(params)
|
||||||
|
@params = params
|
||||||
|
end
|
||||||
|
|
||||||
|
def success?
|
||||||
|
@error.nil?
|
||||||
|
end
|
||||||
|
|
||||||
|
def run
|
||||||
|
Gitea::Users::RegisterService.new(params).call
|
||||||
|
rescue Exception => exception
|
||||||
|
fail!(exception.message)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
attr_reader :params
|
||||||
|
|
||||||
|
def fail!(error)
|
||||||
|
@error = error
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,32 @@
|
|||||||
|
class Gitea::APIService < ApplicationService
|
||||||
|
|
||||||
|
def self.render_status(response)
|
||||||
|
mark = " --from gitea platform."
|
||||||
|
case response.status
|
||||||
|
when 201
|
||||||
|
JSON.parse(response&.body)
|
||||||
|
when 401
|
||||||
|
raise Error, "401 Unauthorized from gitea #{mark}"
|
||||||
|
when 403, 422
|
||||||
|
body = JSON.parse(response&.body)
|
||||||
|
raise Error, body['message'] + mark
|
||||||
|
else
|
||||||
|
false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.base_url
|
||||||
|
Gitea.gitea_config[:base_url]
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.domain
|
||||||
|
Gitea.gitea_config[:domain]
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def logger
|
||||||
|
Rails.logger
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
@ -0,0 +1,27 @@
|
|||||||
|
# 根据对应的用户名和秘密生成token
|
||||||
|
class Gitea::Users::GenerateTokenService < Gitea::APIService
|
||||||
|
attr_reader :username, :password
|
||||||
|
|
||||||
|
def initialize(username, password)
|
||||||
|
@username = username
|
||||||
|
@password = password
|
||||||
|
end
|
||||||
|
|
||||||
|
def call
|
||||||
|
response = Gitea.client(user_params).post do |req|
|
||||||
|
req.url "#{Gitea::APIService.base_url}/users/#{username}/tokens".freeze
|
||||||
|
req.headers['Content-Type'] = 'application/json'
|
||||||
|
req.body = user_params.slice(:name).to_json
|
||||||
|
end
|
||||||
|
puts "-----------generate token response boby: #{response.body}"
|
||||||
|
Gitea::APIService.render_status(response)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
def user_params
|
||||||
|
{
|
||||||
|
name: username,
|
||||||
|
password: password
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
@ -0,0 +1,31 @@
|
|||||||
|
class Gitea::Users::RegisterService < Gitea::APIService
|
||||||
|
REQUEST_URL = [Gitea::APIService.base_url, "/admin/users"].join('').freeze
|
||||||
|
|
||||||
|
def initialize(options = {})
|
||||||
|
options.each_pair do |key, value|
|
||||||
|
instance_variable_set("@#{key}", value)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def call
|
||||||
|
response = Gitea.client.post do |req|
|
||||||
|
req.url "#{REQUEST_URL}"
|
||||||
|
req.headers['Content-Type'] = 'application/json'
|
||||||
|
req.body = user_params.to_json
|
||||||
|
end
|
||||||
|
Gitea::APIService.render_status(response)
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
attr_reader :email, :username, :password
|
||||||
|
|
||||||
|
def user_params
|
||||||
|
{
|
||||||
|
email: email,
|
||||||
|
username: username,
|
||||||
|
password: password,
|
||||||
|
must_change_password: false #允许不更改秘密就可以登录
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in new issue