forked from jasder/forgeplus
21 lines
606 B
Ruby
21 lines
606 B
Ruby
|
class ForksController < ApplicationController
|
||
|
before_action :require_login, :find_project_with_id
|
||
|
before_action :authenticate_project!, :authenticate_user!
|
||
|
|
||
|
def create
|
||
|
@new_project = Projects::ForkService.new(current_user, @project, params[:organization]).call
|
||
|
end
|
||
|
|
||
|
private
|
||
|
def authenticate_project!
|
||
|
return if current_user != @project.owner
|
||
|
render_result(1, "自己不能fork自己的项目")
|
||
|
end
|
||
|
|
||
|
def authenticate_user!
|
||
|
return if @project.is_public
|
||
|
return if @project.member?(current_user) || current_user.admin?
|
||
|
render_forbidden('你没有权限操作')
|
||
|
end
|
||
|
end
|