mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-03 03:40:49 +08:00
init project
This commit is contained in:
42
app/interactors/projects/add_member_interactor.rb
Normal file
42
app/interactors/projects/add_member_interactor.rb
Normal file
@@ -0,0 +1,42 @@
|
||||
module Projects
|
||||
class AddMemberInteractor
|
||||
def self.call(owner, project, collaborator, permission="write")
|
||||
interactor = new(owner, project, collaborator, permission)
|
||||
interactor.run
|
||||
interactor
|
||||
end
|
||||
|
||||
attr_reader :error, :result
|
||||
|
||||
def initialize(owner, project, collaborator, permission)
|
||||
@owner = owner
|
||||
@project = project
|
||||
@collaborator = collaborator
|
||||
@permission = permission
|
||||
end
|
||||
|
||||
def success?
|
||||
@error.nil?
|
||||
end
|
||||
|
||||
def run
|
||||
ActiveRecord::Base.transaction do
|
||||
gitea_result = Gitea::Repository::Members::AddService.new(owner, project.identifier, collaborator.login, permission).call
|
||||
if gitea_result.status == 204
|
||||
project.add_member!(collaborator.id)
|
||||
end
|
||||
fail!(nil)
|
||||
end
|
||||
rescue Exception => exception
|
||||
fail!(exception.message)
|
||||
end
|
||||
|
||||
private
|
||||
attr_reader :owner, :project, :collaborator, :permission
|
||||
|
||||
def fail!(error)
|
||||
@error = error
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
51
app/interactors/projects/change_member_role_interactor.rb
Normal file
51
app/interactors/projects/change_member_role_interactor.rb
Normal file
@@ -0,0 +1,51 @@
|
||||
module Projects
|
||||
class ChangeMemberRoleInteractor
|
||||
def self.call(owner, project, collaborator, role)
|
||||
interactor = new(owner, project, collaborator, role)
|
||||
interactor.run
|
||||
interactor
|
||||
end
|
||||
|
||||
attr_reader :error, :result
|
||||
|
||||
def initialize(owner, project, collaborator, role)
|
||||
@owner = owner
|
||||
@collaborator = collaborator
|
||||
@project = project
|
||||
@role = role
|
||||
end
|
||||
|
||||
def success?
|
||||
@error.nil?
|
||||
end
|
||||
|
||||
def run
|
||||
Projects::ChangeMemberRoleForm.new({user_id: collaborator.id, role: role}).validate!
|
||||
ActiveRecord::Base.transaction do
|
||||
gitea_result = Gitea::Repository::Members::AddService.new(owner, project.identifier, collaborator.login, treated_role).call
|
||||
if gitea_result.status == 204
|
||||
Projects::ChangeMemberRoleService.new(project, collaborator.id, role).call
|
||||
fail!(nil)
|
||||
end
|
||||
end
|
||||
rescue Exception => exception
|
||||
fail!(exception.message)
|
||||
end
|
||||
|
||||
private
|
||||
attr_reader :role, :project, :collaborator, :owner
|
||||
|
||||
def fail!(error)
|
||||
@error = error
|
||||
end
|
||||
|
||||
def treated_role
|
||||
case role
|
||||
when "Manager" then "admin"
|
||||
when "Developer" then "write"
|
||||
when "Reporter" then "read"
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
41
app/interactors/projects/delete_member_interactor.rb
Normal file
41
app/interactors/projects/delete_member_interactor.rb
Normal file
@@ -0,0 +1,41 @@
|
||||
module Projects
|
||||
class DeleteMemberInteractor
|
||||
def self.call(owner, project, collaborator)
|
||||
interactor = new(owner, project, collaborator)
|
||||
interactor.run
|
||||
interactor
|
||||
end
|
||||
|
||||
attr_reader :error, :result
|
||||
|
||||
def initialize(owner, project, collaborator)
|
||||
@owner = owner
|
||||
@project = project
|
||||
@collaborator = collaborator
|
||||
end
|
||||
|
||||
def success?
|
||||
@error.nil?
|
||||
end
|
||||
|
||||
def run
|
||||
ActiveRecord::Base.transaction do
|
||||
gitea_result = Gitea::Repository::Members::DeleteService.new(owner, project.identifier, collaborator.login).call
|
||||
if gitea_result.status == 204
|
||||
project.remove_member!(collaborator.id)
|
||||
end
|
||||
fail!(nil)
|
||||
end
|
||||
rescue Exception => exception
|
||||
fail!(exception.message)
|
||||
end
|
||||
|
||||
private
|
||||
attr_reader :owner, :project, :collaborator
|
||||
|
||||
def fail!(error)
|
||||
@error = error
|
||||
end
|
||||
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user