Merge pull request '组织开启cla时,其他人提交PR时增加一条消息' (#65) from KingChan/forgeplus:chenjing into standalone_develop

This commit is contained in:
KingChan 2023-06-16 10:21:44 +08:00
commit 3eb59b0281
9 changed files with 64 additions and 9 deletions

View File

@ -1,6 +1,7 @@
class Organizations::ClasController < Organizations::BaseController
before_action :load_organization
before_action :load_cla, only: [:show, :update, :destroy]
before_action :check_user_can_edit_org, only: [:create, :update, :destroy]
def index
@cla = @organization.cla

View File

@ -67,6 +67,7 @@ class PullRequestsController < ApplicationController
Issues::CreateForm.new({subject: params[:title], description: params[:body].blank? ? params[:body] : params[:body].b}).validate!
@pull_request, @gitea_pull_request = PullRequests::CreateService.call(current_user, @owner, @project, params)
if @gitea_pull_request[:status] == :success
PullRequests::SendJournalService.call(@project, @pull_request, current_user)
@pull_request.bind_gitea_pull_request!(@gitea_pull_request[:body]["number"], @gitea_pull_request[:body]["id"])
reviewers = User.where(id: params[:reviewer_ids])
@pull_request.reviewers = reviewers

View File

@ -1,19 +1,33 @@
class Users::ClasController < Users::BaseController
before_action :require_login
before_action :private_user_resources!
def index
@user_clas = UserCla.where(user: @_observed_user)
@user_clas = UserCla.where(user: current_user)
end
def create
tip_exception("已签署过该组织CLA!") if @_observed_user.user_clas.where(cla_id: params[:cla_id]).size > 0
@user_cla = current_user.user_clas.find_by(cla_id: params[:cla_id])
if @user_cla
@user_cla.update_attributes(state: 1)
else
ActiveRecord::Base.transaction do
Users::UserClaForm.new(user_cla_params).validate!
@user_cla = UserCla.build(user_cla_params, @_observed_user.id)
render_ok
@user_cla = UserCla.build(user_cla_params, current_user.id)
end
end
render_ok
rescue Exception => e
uid_logger_error(e.message)
tip_exception(e.message)
end
def destroy
@user_cla = current_user.user_clas.find_by(cla_id: params[:cla_id])
@user_cla.update_attributes(state: 2)
render_ok
end
private
def user_cla_params

View File

@ -36,7 +36,9 @@ class Cla < ApplicationRecord
)
end
def valid_sign(user_id)
user_clas.where(user_id: user_id, state:1).present?
end
def fresh_count
update(count:self.users.count)
end

View File

@ -0,0 +1,32 @@
class PullRequests::SendJournalService < ApplicationService
def initialize(project, pull_request,current_user)
@project = project
@issue = pull_request
@current_user = current_user
@org = project.owner
end
def call
if @org.enabling_cla && @org.cla.present? && @org.cla.pr_need && !@org.is_member?(@current_user&.id) && !@org.cla.valid_sign(@current_user&.id)
ActiveRecord::Base.transaction do
sender_id = if Rails.env.development?
User.last.id
else
87461
end
journal_params = {
journalized_id: @issue.id ,
journalized_type: "Issue",
user_id: sender_id ,
notes: "@xxx 您好!欢迎参与 #{@project.name} 的贡献。首次进行贡献请完成《<a href='/#{@project.owner.login}/cla/#{@project.owner.cla.key}' target='_blank'>#{@project.owner.cla.name}</a>》的签署,签署完成后,项目成员才可查看到您的合并请求",
}
journal = Journal.new journal_params
if journal.save
TouchWebhookJob.set(wait: 5.seconds).perform_later('PullRequestComment', @issue&.id, sender_id, journal.id, 'created', {})
push_activity_2_blockchain("issue_comment_create", journal) if Site.has_blockchain? && @project.use_blockchain
end
end
end
end
end

View File

@ -3,6 +3,7 @@ json.identifier project.identifier
json.name project.name
json.description project.description
json.is_public project.is_public
json.pr_need @project.owner&.cla.try(:pr_need)
json.owner do
json.partial! "/users/user_simple", locals: {user: project.owner}
end

View File

@ -11,6 +11,7 @@ json.project_author @project.owner.try(:login)
json.project_author_name @project.owner.try(:show_real_name)
json.has_created_pull_requests @project.pull_requests.size > 0
json.disable_pr_vew @project.pr_view_admin? && !@project.manager?(current_user)
json.pr_need @project.owner&.cla.try(:pr_need)
json.issues do
json.array! @issues.to_a do |issue|

View File

@ -6,3 +6,6 @@ json.created_at format_time(user_cla.created_at)
json.cla do
json.partial! "/organizations/clas/detail", locals: {cla: user_cla.cla}
end
json.organization do
json.partial! "organizations/organizations/simple", organization: user_cla.cla.organization
end

View File

@ -390,7 +390,7 @@ Rails.application.routes.draw do
scope module: :users do
resource :interest, only: [:create]
resources :clas, only: [:index,:create]
resources :clas
resources :accounts, only: [:show, :update] do
resource :phone_bind, only: [:create]
resource :email_bind, only: [:create]