mirror of
https://gitlink.org.cn/Gitlink/forgeplus.git
synced 2026-05-13 08:15:55 +08:00
Merge branch 'develop' into standalone_develop
This commit is contained in:
30
app/services/api/v1/projects/git/blobs_service.rb
Normal file
30
app/services/api/v1/projects/git/blobs_service.rb
Normal file
@@ -0,0 +1,30 @@
|
||||
class Api::V1::Projects::Git::BlobsService < ApplicationService
|
||||
include ActiveModel::Model
|
||||
|
||||
attr_accessor :project, :sha, :token, :owner, :repo
|
||||
attr_accessor :gitea_data
|
||||
|
||||
validates :sha, presence: :true
|
||||
|
||||
|
||||
def initialize(project, sha, token=nil)
|
||||
@project = project
|
||||
@owner = project&.owner.login
|
||||
@repo = project&.identifier
|
||||
@sha = sha
|
||||
@token = token
|
||||
end
|
||||
|
||||
def call
|
||||
$gitea_client.token = token unless token.blank?
|
||||
load_gitea_data
|
||||
|
||||
$gitea_client.token = nil unless token.blank?
|
||||
gitea_data
|
||||
end
|
||||
|
||||
private
|
||||
def load_gitea_data
|
||||
@gitea_data = $gitea_client.get_repos_git_blobs_by_owner_repo_sha(owner, repo, sha)
|
||||
end
|
||||
end
|
||||
50
app/services/api/v1/projects/git/trees_service.rb
Normal file
50
app/services/api/v1/projects/git/trees_service.rb
Normal file
@@ -0,0 +1,50 @@
|
||||
class Api::V1::Projects::Git::TreesService < ApplicationService
|
||||
include ActiveModel::Model
|
||||
|
||||
attr_accessor :project, :token, :sha, :recursive, :page, :limit, :owner, :repo
|
||||
attr_accessor :gitea_data
|
||||
|
||||
validates :sha, presence: :true
|
||||
validates :recursive, inclusion: {in: [nil, '', true, false]}
|
||||
|
||||
def initialize(project, sha, params, token=nil)
|
||||
@project = project
|
||||
@owner = project&.owner.login
|
||||
@repo = project&.identifier
|
||||
@token = token
|
||||
@sha = sha
|
||||
@recursive = params[:recursive]
|
||||
@page = params[:page] || 1
|
||||
@limit = params[:limit] || 15
|
||||
end
|
||||
|
||||
def call
|
||||
raise Error, errors.full_messages.join(", ") unless valid?
|
||||
$gitea_client.token = token unless token.blank?
|
||||
load_gitea_data
|
||||
|
||||
$gitea_client.token = nil unless token.blank?
|
||||
gitea_data
|
||||
end
|
||||
|
||||
private
|
||||
def request_query
|
||||
if recursive.present?
|
||||
{
|
||||
recursive: recursive,
|
||||
page: page,
|
||||
per_page: limit
|
||||
}
|
||||
else
|
||||
{
|
||||
page: page,
|
||||
per_page: limit
|
||||
}
|
||||
end
|
||||
end
|
||||
|
||||
def load_gitea_data
|
||||
@gitea_data = $gitea_client.get_repos_git_trees_by_owner_repo_sha(owner, repo, sha, {query: request_query})
|
||||
raise Error, '获取文件树列表失败!' unless @gitea_data.is_a?(Hash)
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user