Browse Source

新增:流水线接口代码

pull/347/head
yystopf 2 years ago
parent
commit
8eefb8ca07
10 changed files with 174 additions and 1 deletions
  1. +1
    -1
      Gemfile
  2. +31
    -0
      app/controllers/api/v1/projects/actions/actions_controller.rb
  3. +4
    -0
      app/controllers/api/v1/projects/actions/base_controller.rb
  4. +12
    -0
      app/controllers/api/v1/projects/actions/runs_controller.rb
  5. +42
    -0
      app/services/api/v1/projects/actions/runs/job_show_service.rb
  6. +36
    -0
      app/services/api/v1/projects/actions/runs/list_service.rb
  7. +4
    -0
      app/views/api/v1/projects/actions/actions/index.json.jbuilder
  8. +19
    -0
      app/views/api/v1/projects/actions/runs/index.json.jbuilder
  9. +16
    -0
      app/views/api/v1/projects/actions/runs/job_show.json.jbuilder
  10. +9
    -0
      config/routes/api.rb

+ 1
- 1
Gemfile View File

@@ -143,4 +143,4 @@ gem 'doorkeeper'

gem 'doorkeeper-jwt'

gem 'gitea-client', '~> 1.4.5'
gem 'gitea-client', '~> 1.4.6'

+ 31
- 0
app/controllers/api/v1/projects/actions/actions_controller.rb View File

@@ -0,0 +1,31 @@
class Api::V1::Projects::Actions::ActionsController < Api::V1::Projects::Actions::BaseController

def index
begin
gitea_result = $gitea_hat_client.get_repos_actions_by_owner_repo(@project&.owner&.login, @project&.identifier)
@data = gitea_result[:data]["Workflows"]
rescue
@data = []
end
end

def disable
return render_error("请输入正确的流水线文件!") if params[:workflow].blank?
gitea_result = $gitea_hat_client.post_repos_actions_disable(@project&.owner&.login, @project&.identifier, {query: {workflow: params[:workflow]}}) rescue nil
if gitea_result
render_ok
else
render_error("禁用流水线失败")
end
end

def enable
return render_error("请输入正确的流水线文件!") if params[:workflow].blank?
gitea_result = $gitea_hat_client.post_repos_actions_enable(@project&.owner&.login, @project&.identifier, {query: {workflow: params[:workflow]}}) rescue nil
if gitea_result
render_ok
else
render_error("取消禁用流水线失败")
end
end
end

+ 4
- 0
app/controllers/api/v1/projects/actions/base_controller.rb View File

@@ -0,0 +1,4 @@
class Api::V1::Projects::Actions::BaseController < Api::V1::BaseController
before_action :require_public_and_member_above

end

+ 12
- 0
app/controllers/api/v1/projects/actions/runs_controller.rb View File

@@ -0,0 +1,12 @@
class Api::V1::Projects::Actions::RunsController < Api::V1::Projects::Actions::BaseController

def index
@result_object = Api::V1::Projects::Actions::Runs::ListService.call(@project, params[:workflow], current_user&.gitea_token)
end

def job_show
@result_object = Api::V1::Projects::Actions::Runs::JobShowService.call(@project, params[:run_id], params[:job], params[:log_cursors], current_user&.gitea_token)
puts @result_object
end

end

+ 42
- 0
app/services/api/v1/projects/actions/runs/job_show_service.rb View File

@@ -0,0 +1,42 @@
class Api::V1::Projects::Actions::Runs::JobShowService < ApplicationService
include ActiveModel::Model

attr_reader :project, :token, :owner, :repo, :run, :job, :log_cursors
attr_accessor :gitea_data

validates :run, :job, :log_cursors, presence: true

def initialize(project, run, job, log_cursors, token = nil)
@project = project
@owner = project&.owner.login
@repo = project&.identifier
@run = run
@job = job
@log_cursors = log_cursors
@token = token
end

def call
raise Error, errors.full_messages.join(",") unless valid?
load_gitea_data

@gitea_data
end

private
def request_params
{
access_token: token
}
end

def request_body
{
logCursors: log_cursors
}
end

def load_gitea_data
@gitea_data = $gitea_hat_client.post_repos_actions_runs_jobs_by_owner_repo_run_job(owner, repo, run, job, {query: request_params, body: request_body.to_json})
end
end

+ 36
- 0
app/services/api/v1/projects/actions/runs/list_service.rb View File

@@ -0,0 +1,36 @@
class Api::V1::Projects::Actions::Runs::ListService < ApplicationService
include ActiveModel::Model

attr_reader :project, :token, :owner, :repo, :workflow
attr_accessor :gitea_data

validates :workflow, presence: true

def initialize(project, workflow, token =nil)
@project = project
@owner = project&.owner.login
@repo = project&.identifier
@workflow = workflow
@token = token
end

def call
raise Error, errors.full_messages.join(",") unless valid?
load_gitea_data

@gitea_data
end

private
def request_params
{
access_token: token,
workflow: workflow
}
end

def load_gitea_data
@gitea_data = $gitea_hat_client.get_repos_actions_by_owner_repo(owner, repo, {query: request_params}) rescue nil
raise Error, '获取流水线执行记录失败!' unless @gitea_data.is_a?(Hash)
end
end

+ 4
- 0
app/views/api/v1/projects/actions/actions/index.json.jbuilder View File

@@ -0,0 +1,4 @@
json.total_count @data.size
json.files @data.each do |file|
json.name file["Name"]
end

+ 19
- 0
app/views/api/v1/projects/actions/runs/index.json.jbuilder View File

@@ -0,0 +1,19 @@
json.total_data @result_object[:total_data].to_i
json.runs @result_object[:data]["Runs"].each do |run|
json.workflow run["WorkflowID"]
json.index run["Index"]
json.title run["Title"]
json.trigger_user do
json.partial! 'api/v1/users/commit_user', locals: { user: render_cache_commit_author(run['TriggerUser']), name: run['TriggerUser']['Name'] }
end

if run["Ref"].starts_with?("refs/tags")
json.ref run["Ref"].gsub!("/refs/tags/", "")
else
json.ref run["Ref"].gsub!("refs/heads/", "")
end

json.status run["Status"]
json.time_ago time_from_now(run["Stopped"])
json.holding_time run["Stopped"]-run["Started"]
end

+ 16
- 0
app/views/api/v1/projects/actions/runs/job_show.json.jbuilder View File

@@ -0,0 +1,16 @@
json.state do
json.run do
json.title @result_object["state"]["run"]["title"]
json.status @result_object["state"]["run"]["status"]
json.done @result_object["state"]["run"]["done"]
json.jobs @result_object["state"]["run"]["jobs"]
json.current_job do
json.title @result_object["state"]["currentJob"]["title"]
json.detail @result_object["state"]["currentJob"]["detail"]
json.steps @result_object["state"]["currentJob"]["steps"]
end
end
end
json.logs do
json.steps_log @result_object["logs"]["stepsLog"]
end

+ 9
- 0
config/routes/api.rb View File

@@ -60,6 +60,15 @@ defaults format: :json do

# projects文件夹下的
scope module: :projects do
resources :actions, module: 'actions' do
collection do
post :disable
post :enable
resources :runs, only: [:index] do
post '/jobs/:job', to: 'runs#job_show'
end
end
end
resources :pulls, module: 'pulls' do
resources :versions, only: [:index] do
member do


Loading…
Cancel
Save